1f01f53c53
* paginate results * fixed deadlock * prevented breaking change * updated swagger * go fmt * fixed find topic * go mod tidy * go mod vendor with go1.13.5 * fixed repo find topics * fixed unit test * added Limit method to Engine struct; use engine variable when provided; fixed gitignore * use ItemsPerPage for default pagesize; fix GetWatchers, getOrgUsersByOrgID and GetStargazers; fix GetAllCommits headers; reverted some changed behaviors * set Page value on Home route * improved memory allocations * fixed response headers * removed logfiles * fixed import order * import order * improved swagger * added function to get models.ListOptions from context * removed pagesize diff on unit test * fixed imports * removed unnecessary struct field * fixed go fmt * scoped PR * code improvements * code improvements * go mod tidy * fixed import order * fixed commit statuses session * fixed files headers * fixed headers; added pagination for notifications * go mod tidy * go fmt * removed Private from user search options; added setting.UI.IssuePagingNum as default valeu on repo's issues list * Apply suggestions from code review Co-Authored-By: 6543 <6543@obermui.de> Co-Authored-By: zeripath <art27@cantab.net> * fixed build error * CI.restart() * fixed merge conflicts resolve * fixed conflicts resolve * improved FindTrackedTimesOptions.ToOptions() method * added backwards compatibility on ListReleases request; fixed issue tracked time ToSession * fixed build error; fixed swagger template * fixed swagger template * fixed ListReleases backwards compatibility * added page to user search route Co-authored-by: techknowlogick <matti@mdranta.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: zeripath <art27@cantab.net>
280 lines
8.7 KiB
Go
280 lines
8.7 KiB
Go
// Copyright 2017 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 (
|
|
"html/template"
|
|
"testing"
|
|
|
|
api "code.gitea.io/gitea/modules/structs"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
// TODO TestGetLabelTemplateFile
|
|
|
|
func TestLabel_APIFormat(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
assert.Equal(t, api.Label{
|
|
ID: label.ID,
|
|
Name: label.Name,
|
|
Color: "abcdef",
|
|
}, *label.APIFormat())
|
|
}
|
|
|
|
func TestLabel_CalOpenIssues(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
label.CalOpenIssues()
|
|
assert.EqualValues(t, 2, label.NumOpenIssues)
|
|
}
|
|
|
|
func TestLabel_ForegroundColor(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
assert.Equal(t, template.CSS("#000"), label.ForegroundColor())
|
|
|
|
label = AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
|
|
assert.Equal(t, template.CSS("#fff"), label.ForegroundColor())
|
|
}
|
|
|
|
func TestNewLabels(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
labels := []*Label{
|
|
{RepoID: 2, Name: "labelName2", Color: "#123456"},
|
|
{RepoID: 3, Name: "labelName3", Color: "#234567"},
|
|
}
|
|
for _, label := range labels {
|
|
AssertNotExistsBean(t, label)
|
|
}
|
|
assert.NoError(t, NewLabels(labels...))
|
|
for _, label := range labels {
|
|
AssertExistsAndLoadBean(t, label, Cond("id = ?", label.ID))
|
|
}
|
|
CheckConsistencyFor(t, &Label{}, &Repository{})
|
|
}
|
|
|
|
func TestGetLabelByID(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label, err := GetLabelByID(1)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, label.ID)
|
|
|
|
_, err = GetLabelByID(NonexistentID)
|
|
assert.True(t, IsErrLabelNotExist(err))
|
|
}
|
|
|
|
func TestGetLabelInRepoByName(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label, err := GetLabelInRepoByName(1, "label1")
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, label.ID)
|
|
assert.Equal(t, "label1", label.Name)
|
|
|
|
_, err = GetLabelInRepoByName(1, "")
|
|
assert.True(t, IsErrLabelNotExist(err))
|
|
|
|
_, err = GetLabelInRepoByName(NonexistentID, "nonexistent")
|
|
assert.True(t, IsErrLabelNotExist(err))
|
|
}
|
|
|
|
func TestGetLabelInRepoByNames(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
labelIDs, err := GetLabelIDsInRepoByNames(1, []string{"label1", "label2"})
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, labelIDs, 2)
|
|
|
|
assert.Equal(t, int64(1), labelIDs[0])
|
|
assert.Equal(t, int64(2), labelIDs[1])
|
|
}
|
|
|
|
func TestGetLabelInRepoByNamesDiscardsNonExistentLabels(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
// label3 doesn't exists.. See labels.yml
|
|
labelIDs, err := GetLabelIDsInRepoByNames(1, []string{"label1", "label2", "label3"})
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, labelIDs, 2)
|
|
|
|
assert.Equal(t, int64(1), labelIDs[0])
|
|
assert.Equal(t, int64(2), labelIDs[1])
|
|
assert.NoError(t, err)
|
|
}
|
|
|
|
func TestGetLabelInRepoByID(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label, err := GetLabelInRepoByID(1, 1)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, label.ID)
|
|
|
|
_, err = GetLabelInRepoByID(1, -1)
|
|
assert.True(t, IsErrLabelNotExist(err))
|
|
|
|
_, err = GetLabelInRepoByID(NonexistentID, NonexistentID)
|
|
assert.True(t, IsErrLabelNotExist(err))
|
|
}
|
|
|
|
func TestGetLabelsInRepoByIDs(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
labels, err := GetLabelsInRepoByIDs(1, []int64{1, 2, NonexistentID})
|
|
assert.NoError(t, err)
|
|
if assert.Len(t, labels, 2) {
|
|
assert.EqualValues(t, 1, labels[0].ID)
|
|
assert.EqualValues(t, 2, labels[1].ID)
|
|
}
|
|
}
|
|
|
|
func TestGetLabelsByRepoID(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
testSuccess := func(repoID int64, sortType string, expectedIssueIDs []int64) {
|
|
labels, err := GetLabelsByRepoID(repoID, sortType, ListOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, labels, len(expectedIssueIDs))
|
|
for i, label := range labels {
|
|
assert.EqualValues(t, expectedIssueIDs[i], label.ID)
|
|
}
|
|
}
|
|
testSuccess(1, "leastissues", []int64{2, 1})
|
|
testSuccess(1, "mostissues", []int64{1, 2})
|
|
testSuccess(1, "reversealphabetically", []int64{2, 1})
|
|
testSuccess(1, "default", []int64{1, 2})
|
|
}
|
|
|
|
func TestGetLabelsByIssueID(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
labels, err := GetLabelsByIssueID(1)
|
|
assert.NoError(t, err)
|
|
if assert.Len(t, labels, 1) {
|
|
assert.EqualValues(t, 1, labels[0].ID)
|
|
}
|
|
|
|
labels, err = GetLabelsByIssueID(NonexistentID)
|
|
assert.NoError(t, err)
|
|
assert.Len(t, labels, 0)
|
|
}
|
|
|
|
func TestUpdateLabel(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
label.Color = "#ffff00"
|
|
label.Name = "newLabelName"
|
|
assert.NoError(t, UpdateLabel(label))
|
|
newLabel := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
assert.Equal(t, *label, *newLabel)
|
|
CheckConsistencyFor(t, &Label{}, &Repository{})
|
|
}
|
|
|
|
func TestDeleteLabel(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
assert.NoError(t, DeleteLabel(label.RepoID, label.ID))
|
|
AssertNotExistsBean(t, &Label{ID: label.ID, RepoID: label.RepoID})
|
|
|
|
assert.NoError(t, DeleteLabel(label.RepoID, label.ID))
|
|
AssertNotExistsBean(t, &Label{ID: label.ID, RepoID: label.RepoID})
|
|
|
|
assert.NoError(t, DeleteLabel(NonexistentID, NonexistentID))
|
|
CheckConsistencyFor(t, &Label{}, &Repository{})
|
|
}
|
|
|
|
func TestHasIssueLabel(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
assert.True(t, HasIssueLabel(1, 1))
|
|
assert.False(t, HasIssueLabel(1, 2))
|
|
assert.False(t, HasIssueLabel(NonexistentID, NonexistentID))
|
|
}
|
|
|
|
func TestNewIssueLabel(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
|
|
issue := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
|
|
doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
|
|
// add new IssueLabel
|
|
prevNumIssues := label.NumIssues
|
|
assert.NoError(t, NewIssueLabel(issue, label, doer))
|
|
AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label.ID})
|
|
AssertExistsAndLoadBean(t, &Comment{
|
|
Type: CommentTypeLabel,
|
|
PosterID: doer.ID,
|
|
IssueID: issue.ID,
|
|
LabelID: label.ID,
|
|
Content: "1",
|
|
})
|
|
label = AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
|
|
assert.EqualValues(t, prevNumIssues+1, label.NumIssues)
|
|
|
|
// re-add existing IssueLabel
|
|
assert.NoError(t, NewIssueLabel(issue, label, doer))
|
|
CheckConsistencyFor(t, &Issue{}, &Label{})
|
|
}
|
|
|
|
func TestNewIssueLabels(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
label1 := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
label2 := AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
|
|
issue := AssertExistsAndLoadBean(t, &Issue{ID: 5}).(*Issue)
|
|
doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
|
|
assert.NoError(t, NewIssueLabels(issue, []*Label{label1, label2}, doer))
|
|
AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label1.ID})
|
|
AssertExistsAndLoadBean(t, &Comment{
|
|
Type: CommentTypeLabel,
|
|
PosterID: doer.ID,
|
|
IssueID: issue.ID,
|
|
LabelID: label1.ID,
|
|
Content: "1",
|
|
})
|
|
AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label1.ID})
|
|
label1 = AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
assert.EqualValues(t, 3, label1.NumIssues)
|
|
assert.EqualValues(t, 1, label1.NumClosedIssues)
|
|
label2 = AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
|
|
assert.EqualValues(t, 1, label2.NumIssues)
|
|
assert.EqualValues(t, 1, label2.NumClosedIssues)
|
|
|
|
// corner case: test empty slice
|
|
assert.NoError(t, NewIssueLabels(issue, []*Label{}, doer))
|
|
|
|
CheckConsistencyFor(t, &Issue{}, &Label{})
|
|
}
|
|
|
|
func TestDeleteIssueLabel(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
testSuccess := func(labelID, issueID, doerID int64) {
|
|
label := AssertExistsAndLoadBean(t, &Label{ID: labelID}).(*Label)
|
|
issue := AssertExistsAndLoadBean(t, &Issue{ID: issueID}).(*Issue)
|
|
doer := AssertExistsAndLoadBean(t, &User{ID: doerID}).(*User)
|
|
|
|
expectedNumIssues := label.NumIssues
|
|
expectedNumClosedIssues := label.NumClosedIssues
|
|
if BeanExists(t, &IssueLabel{IssueID: issueID, LabelID: labelID}) {
|
|
expectedNumIssues--
|
|
if issue.IsClosed {
|
|
expectedNumClosedIssues--
|
|
}
|
|
}
|
|
|
|
assert.NoError(t, DeleteIssueLabel(issue, label, doer))
|
|
AssertNotExistsBean(t, &IssueLabel{IssueID: issueID, LabelID: labelID})
|
|
AssertExistsAndLoadBean(t, &Comment{
|
|
Type: CommentTypeLabel,
|
|
PosterID: doerID,
|
|
IssueID: issueID,
|
|
LabelID: labelID,
|
|
}, `content=""`)
|
|
label = AssertExistsAndLoadBean(t, &Label{ID: labelID}).(*Label)
|
|
assert.EqualValues(t, expectedNumIssues, label.NumIssues)
|
|
assert.EqualValues(t, expectedNumClosedIssues, label.NumClosedIssues)
|
|
}
|
|
testSuccess(1, 1, 2)
|
|
testSuccess(2, 5, 2)
|
|
testSuccess(1, 1, 2) // delete non-existent IssueLabel
|
|
|
|
CheckConsistencyFor(t, &Issue{}, &Label{})
|
|
}
|