mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-20 23:49:23 +00:00
2c3da59e27
By clicking the currently active "Open" or "Closed" filter button in the issue list, the user can toggle that filter off in order to see all issues regardless of state. The URL "state" parameter will be set to "all" and the "Open"/"Closed" button will not show as active.
135 lines
4.6 KiB
Go
135 lines
4.6 KiB
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package issues_test
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"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/util"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestAddTime(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
org3, err := user_model.GetUserByID(db.DefaultContext, 3)
|
|
assert.NoError(t, err)
|
|
|
|
issue1, err := issues_model.GetIssueByID(db.DefaultContext, 1)
|
|
assert.NoError(t, err)
|
|
|
|
// 3661 = 1h 1min 1s
|
|
trackedTime, err := issues_model.AddTime(db.DefaultContext, org3, issue1, 3661, time.Now())
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, int64(3), trackedTime.UserID)
|
|
assert.Equal(t, int64(1), trackedTime.IssueID)
|
|
assert.Equal(t, int64(3661), trackedTime.Time)
|
|
|
|
tt := unittest.AssertExistsAndLoadBean(t, &issues_model.TrackedTime{UserID: 3, IssueID: 1})
|
|
assert.Equal(t, int64(3661), tt.Time)
|
|
|
|
comment := unittest.AssertExistsAndLoadBean(t, &issues_model.Comment{Type: issues_model.CommentTypeAddTimeManual, PosterID: 3, IssueID: 1})
|
|
assert.Equal(t, "|3661", comment.Content)
|
|
}
|
|
|
|
func TestGetTrackedTimes(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
// by Issue
|
|
times, err := issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: 1})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 1)
|
|
assert.Equal(t, int64(400), times[0].Time)
|
|
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: -1})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 0)
|
|
|
|
// by User
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{UserID: 1})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 3)
|
|
assert.Equal(t, int64(400), times[0].Time)
|
|
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{UserID: 3})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 0)
|
|
|
|
// by Repo
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{RepositoryID: 2})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 3)
|
|
assert.Equal(t, int64(1), times[0].Time)
|
|
issue, err := issues_model.GetIssueByID(db.DefaultContext, times[0].IssueID)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, issue.RepoID, int64(2))
|
|
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{RepositoryID: 1})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 5)
|
|
|
|
times, err = issues_model.GetTrackedTimes(db.DefaultContext, &issues_model.FindTrackedTimesOptions{RepositoryID: 10})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, times, 0)
|
|
}
|
|
|
|
func TestTotalTimesForEachUser(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
total, err := issues_model.TotalTimesForEachUser(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: 1})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, total, 1)
|
|
for user, time := range total {
|
|
assert.EqualValues(t, 1, user.ID)
|
|
assert.EqualValues(t, 400, time)
|
|
}
|
|
|
|
total, err = issues_model.TotalTimesForEachUser(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: 2})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, total, 2)
|
|
for user, time := range total {
|
|
if user.ID == 2 {
|
|
assert.EqualValues(t, 3662, time)
|
|
} else if user.ID == 1 {
|
|
assert.EqualValues(t, 20, time)
|
|
} else {
|
|
assert.Error(t, assert.AnError)
|
|
}
|
|
}
|
|
|
|
total, err = issues_model.TotalTimesForEachUser(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: 5})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, total, 1)
|
|
for user, time := range total {
|
|
assert.EqualValues(t, 2, user.ID)
|
|
assert.EqualValues(t, 1, time)
|
|
}
|
|
|
|
total, err = issues_model.TotalTimesForEachUser(db.DefaultContext, &issues_model.FindTrackedTimesOptions{IssueID: 4})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, total, 2)
|
|
}
|
|
|
|
func TestGetIssueTotalTrackedTime(t *testing.T) {
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
ttt, err := issues_model.GetIssueTotalTrackedTime(db.DefaultContext, &issues_model.IssuesOptions{MilestoneIDs: []int64{1}}, util.OptionalBoolFalse)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 3682, ttt)
|
|
|
|
ttt, err = issues_model.GetIssueTotalTrackedTime(db.DefaultContext, &issues_model.IssuesOptions{MilestoneIDs: []int64{1}}, util.OptionalBoolTrue)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 0, ttt)
|
|
|
|
ttt, err = issues_model.GetIssueTotalTrackedTime(db.DefaultContext, &issues_model.IssuesOptions{MilestoneIDs: []int64{1}}, util.OptionalBoolNone)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 3682, ttt)
|
|
}
|