 4de909747b
			
		
	
	
	4de909747b
	
	
	
		
			
			go-require lint is ignored for now Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4535 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: TheFox0x7 <thefox0x7@gmail.com> Co-committed-by: TheFox0x7 <thefox0x7@gmail.com>
		
			
				
	
	
		
			129 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package issues_test
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	issues_model "code.gitea.io/gitea/models/issues"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestIssueList_LoadRepositories(t *testing.T) {
 | |
| 	require.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	issueList := issues_model.IssueList{
 | |
| 		unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 1}),
 | |
| 		unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2}),
 | |
| 		unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 4}),
 | |
| 	}
 | |
| 
 | |
| 	repos, err := issueList.LoadRepositories(db.DefaultContext)
 | |
| 	require.NoError(t, err)
 | |
| 	assert.Len(t, repos, 2)
 | |
| 	for _, issue := range issueList {
 | |
| 		assert.EqualValues(t, issue.RepoID, issue.Repo.ID)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestIssueList_LoadAttributes(t *testing.T) {
 | |
| 	require.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	setting.Service.EnableTimetracking = true
 | |
| 	issueList := issues_model.IssueList{
 | |
| 		unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 1}),
 | |
| 		unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 4}),
 | |
| 	}
 | |
| 
 | |
| 	require.NoError(t, issueList.LoadAttributes(db.DefaultContext))
 | |
| 	for _, issue := range issueList {
 | |
| 		assert.EqualValues(t, issue.RepoID, issue.Repo.ID)
 | |
| 		for _, label := range issue.Labels {
 | |
| 			assert.EqualValues(t, issue.RepoID, label.RepoID)
 | |
| 			unittest.AssertExistsAndLoadBean(t, &issues_model.IssueLabel{IssueID: issue.ID, LabelID: label.ID})
 | |
| 		}
 | |
| 		if issue.PosterID > 0 {
 | |
| 			assert.EqualValues(t, issue.PosterID, issue.Poster.ID)
 | |
| 		}
 | |
| 		if issue.AssigneeID > 0 {
 | |
| 			assert.EqualValues(t, issue.AssigneeID, issue.Assignee.ID)
 | |
| 		}
 | |
| 		if issue.MilestoneID > 0 {
 | |
| 			assert.EqualValues(t, issue.MilestoneID, issue.Milestone.ID)
 | |
| 		}
 | |
| 		if issue.IsPull {
 | |
| 			assert.EqualValues(t, issue.ID, issue.PullRequest.IssueID)
 | |
| 		}
 | |
| 		for _, attachment := range issue.Attachments {
 | |
| 			assert.EqualValues(t, issue.ID, attachment.IssueID)
 | |
| 		}
 | |
| 		for _, comment := range issue.Comments {
 | |
| 			assert.EqualValues(t, issue.ID, comment.IssueID)
 | |
| 		}
 | |
| 		if issue.ID == int64(1) {
 | |
| 			assert.Equal(t, int64(400), issue.TotalTrackedTime)
 | |
| 			assert.NotNil(t, issue.Project)
 | |
| 			assert.Equal(t, int64(1), issue.Project.ID)
 | |
| 		} else {
 | |
| 			assert.Nil(t, issue.Project)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	require.NoError(t, issueList.LoadIsRead(db.DefaultContext, 1))
 | |
| 	for _, issue := range issueList {
 | |
| 		assert.Equal(t, issue.ID == 1, issue.IsRead, "unexpected is_read value for issue[%d]", issue.ID)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestIssueListLoadUser(t *testing.T) {
 | |
| 	require.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{})
 | |
| 	doer := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
 | |
| 
 | |
| 	for _, testCase := range []struct {
 | |
| 		poster int64
 | |
| 		user   *user_model.User
 | |
| 	}{
 | |
| 		{
 | |
| 			poster: user_model.ActionsUserID,
 | |
| 			user:   user_model.NewActionsUser(),
 | |
| 		},
 | |
| 		{
 | |
| 			poster: user_model.GhostUserID,
 | |
| 			user:   user_model.NewGhostUser(),
 | |
| 		},
 | |
| 		{
 | |
| 			poster: doer.ID,
 | |
| 			user:   doer,
 | |
| 		},
 | |
| 		{
 | |
| 			poster: 0,
 | |
| 			user:   user_model.NewGhostUser(),
 | |
| 		},
 | |
| 		{
 | |
| 			poster: -200,
 | |
| 			user:   user_model.NewGhostUser(),
 | |
| 		},
 | |
| 		{
 | |
| 			poster: 200,
 | |
| 			user:   user_model.NewGhostUser(),
 | |
| 		},
 | |
| 	} {
 | |
| 		t.Run(testCase.user.Name, func(t *testing.T) {
 | |
| 			list := issues_model.IssueList{issue}
 | |
| 
 | |
| 			issue.PosterID = testCase.poster
 | |
| 			issue.Poster = nil
 | |
| 			require.NoError(t, list.LoadPosters(db.DefaultContext))
 | |
| 			require.NotNil(t, issue.Poster)
 | |
| 			assert.Equal(t, testCase.user.ID, issue.Poster.ID)
 | |
| 		})
 | |
| 	}
 | |
| }
 |