* Move db related basic functions to models/db * Fix lint * Fix lint * Fix test * Fix lint * Fix lint * revert unnecessary change * Fix test * Fix wrong replace string * Use *Context * Correct committer spelling and fix wrong replaced words Co-authored-by: zeripath <art27@cantab.net>
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2018 The Gitea Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a MIT-style
 | 
						|
// license that can be found in the LICENSE file.
 | 
						|
 | 
						|
package models
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/models/db"
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestUpdateAssignee(t *testing.T) {
 | 
						|
	assert.NoError(t, db.PrepareTestDatabase())
 | 
						|
 | 
						|
	// Fake issue with assignees
 | 
						|
	issue, err := GetIssueWithAttrsByID(1)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	// Assign multiple users
 | 
						|
	user2, err := GetUserByID(2)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	_, _, err = issue.ToggleAssignee(&User{ID: 1}, user2.ID)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	user3, err := GetUserByID(3)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	_, _, err = issue.ToggleAssignee(&User{ID: 1}, user3.ID)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	user1, err := GetUserByID(1) // This user is already assigned (see the definition in fixtures), so running  UpdateAssignee should unassign him
 | 
						|
	assert.NoError(t, err)
 | 
						|
	_, _, err = issue.ToggleAssignee(&User{ID: 1}, user1.ID)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	// Check if he got removed
 | 
						|
	isAssigned, err := IsUserAssignedToIssue(issue, user1)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.False(t, isAssigned)
 | 
						|
 | 
						|
	// Check if they're all there
 | 
						|
	assignees, err := GetAssigneesByIssue(issue)
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	var expectedAssignees []*User
 | 
						|
	expectedAssignees = append(expectedAssignees, user2, user3)
 | 
						|
 | 
						|
	for in, assignee := range assignees {
 | 
						|
		assert.Equal(t, assignee.ID, expectedAssignees[in].ID)
 | 
						|
	}
 | 
						|
 | 
						|
	// Check if the user is assigned
 | 
						|
	isAssigned, err = IsUserAssignedToIssue(issue, user2)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.True(t, isAssigned)
 | 
						|
 | 
						|
	// This user should not be assigned
 | 
						|
	isAssigned, err = IsUserAssignedToIssue(issue, &User{ID: 4})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.False(t, isAssigned)
 | 
						|
}
 | 
						|
 | 
						|
func TestMakeIDsFromAPIAssigneesToAdd(t *testing.T) {
 | 
						|
	assert.NoError(t, db.PrepareTestDatabase())
 | 
						|
 | 
						|
	_ = db.AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | 
						|
	_ = db.AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
 | 
						|
 | 
						|
	IDs, err := MakeIDsFromAPIAssigneesToAdd("", []string{""})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.Equal(t, []int64{}, IDs)
 | 
						|
 | 
						|
	IDs, err = MakeIDsFromAPIAssigneesToAdd("", []string{"none_existing_user"})
 | 
						|
	assert.Error(t, err)
 | 
						|
 | 
						|
	IDs, err = MakeIDsFromAPIAssigneesToAdd("user1", []string{"user1"})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.Equal(t, []int64{1}, IDs)
 | 
						|
 | 
						|
	IDs, err = MakeIDsFromAPIAssigneesToAdd("user2", []string{""})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.Equal(t, []int64{2}, IDs)
 | 
						|
 | 
						|
	IDs, err = MakeIDsFromAPIAssigneesToAdd("", []string{"user1", "user2"})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.Equal(t, []int64{1, 2}, IDs)
 | 
						|
}
 |