mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 12:53:43 +01:00 
			
		
		
		
	* keep sure if assigneeIDs == nil -> do nothing * fix #8872 * Revert "keep sure if assigneeIDs == nil -> do nothing" -> go handle it itself preaty well This reverts commit e72d94129c4666d5151f6131cb2f8c1de127d9d0. * clarity comparson Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * simplify * Update models/issue_assignees.go Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * Update issue_assignees.go * simplify more * add --if oneAssignee != ""-- again * Update models/issue_assignees.go Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> * CI.restart() * Update issue_assignees.go * add Test for GetUserIDsByNames * add Test for MakeIDsFromAPIAssigneesToAdd * fix test
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.3 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"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestUpdateAssignee(t *testing.T) {
 | 
						|
	assert.NoError(t, 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) {
 | 
						|
	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)
 | 
						|
}
 |