 3d7d750a99
			
		
	
	
		3d7d750a99
		
			
		
	
	
	
	
		
			
			* Decouple TestAction_GetRepoLink and TestSizedAvatarLink. * Load database for TestCheckGPGUserEmail. * Load database for TestMakeIDsFromAPIAssigneesToAdd. * Load database for TestGetUserIDsByNames and TestGetMaileableUsersByIDs. * Load database for TestUser_ToUser. * Load database for TestRepository_EditWikiPage. * Include AppSubURL in test. * Prevent panic with empty slice. Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			87 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"
 | |
| 
 | |
| 	"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) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	_ = AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
 | |
| 	_ = 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)
 | |
| }
 |