mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-12-05 02:54:46 +01:00
052e65e63f
Backport #25806 by @yp05327 sort type `oldest` should be `Asc`. Added a test for this. I see we have `SearchOrderBy` in db model, but we are using many different ways to define the sort type. ~Maybe we can improve this later.~ ↑ Improved in this PR Co-authored-by: yp05327 <576951401@qq.com>
123 lines
2.7 KiB
Go
123 lines
2.7 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package project
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
"code.gitea.io/gitea/modules/timeutil"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestIsProjectTypeValid(t *testing.T) {
|
|
const UnknownType Type = 15
|
|
|
|
cases := []struct {
|
|
typ Type
|
|
valid bool
|
|
}{
|
|
{TypeIndividual, true},
|
|
{TypeRepository, true},
|
|
{TypeOrganization, true},
|
|
{UnknownType, false},
|
|
}
|
|
|
|
for _, v := range cases {
|
|
assert.Equal(t, v.valid, IsTypeValid(v.typ))
|
|
}
|
|
}
|
|
|
|
func TestGetProjects(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
projects, _, err := FindProjects(db.DefaultContext, SearchOptions{RepoID: 1})
|
|
assert.NoError(t, err)
|
|
|
|
// 1 value for this repo exists in the fixtures
|
|
assert.Len(t, projects, 1)
|
|
|
|
projects, _, err = FindProjects(db.DefaultContext, SearchOptions{RepoID: 3})
|
|
assert.NoError(t, err)
|
|
|
|
// 1 value for this repo exists in the fixtures
|
|
assert.Len(t, projects, 1)
|
|
}
|
|
|
|
func TestProject(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
project := &Project{
|
|
Type: TypeRepository,
|
|
BoardType: BoardTypeBasicKanban,
|
|
CardType: CardTypeTextOnly,
|
|
Title: "New Project",
|
|
RepoID: 1,
|
|
CreatedUnix: timeutil.TimeStampNow(),
|
|
CreatorID: 2,
|
|
}
|
|
|
|
assert.NoError(t, NewProject(project))
|
|
|
|
_, err := GetProjectByID(db.DefaultContext, project.ID)
|
|
assert.NoError(t, err)
|
|
|
|
// Update project
|
|
project.Title = "Updated title"
|
|
assert.NoError(t, UpdateProject(db.DefaultContext, project))
|
|
|
|
projectFromDB, err := GetProjectByID(db.DefaultContext, project.ID)
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, project.Title, projectFromDB.Title)
|
|
|
|
assert.NoError(t, ChangeProjectStatus(project, true))
|
|
|
|
// Retrieve from DB afresh to check if it is truly closed
|
|
projectFromDB, err = GetProjectByID(db.DefaultContext, project.ID)
|
|
assert.NoError(t, err)
|
|
|
|
assert.True(t, projectFromDB.IsClosed)
|
|
}
|
|
|
|
func TestProjectsSort(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
tests := []struct {
|
|
sortType string
|
|
wants []int64
|
|
}{
|
|
{
|
|
sortType: "default",
|
|
wants: []int64{1, 3, 2, 4},
|
|
},
|
|
{
|
|
sortType: "oldest",
|
|
wants: []int64{4, 2, 3, 1},
|
|
},
|
|
{
|
|
sortType: "recentupdate",
|
|
wants: []int64{1, 3, 2, 4},
|
|
},
|
|
{
|
|
sortType: "leastupdate",
|
|
wants: []int64{4, 2, 3, 1},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
projects, count, err := FindProjects(db.DefaultContext, SearchOptions{
|
|
OrderBy: GetSearchOrderByBySortType(tt.sortType),
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, int64(4), count)
|
|
if assert.Len(t, projects, 4) {
|
|
for i := range projects {
|
|
assert.EqualValues(t, tt.wants[i], projects[i].ID)
|
|
}
|
|
}
|
|
}
|
|
}
|