You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

issue_tracked_time_test.go 3.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package models
  5. import (
  6. "testing"
  7. "time"
  8. "code.gitea.io/gitea/models/unittest"
  9. user_model "code.gitea.io/gitea/models/user"
  10. "github.com/stretchr/testify/assert"
  11. )
  12. func TestAddTime(t *testing.T) {
  13. assert.NoError(t, unittest.PrepareTestDatabase())
  14. user3, err := user_model.GetUserByID(3)
  15. assert.NoError(t, err)
  16. issue1, err := GetIssueByID(1)
  17. assert.NoError(t, err)
  18. // 3661 = 1h 1min 1s
  19. trackedTime, err := AddTime(user3, issue1, 3661, time.Now())
  20. assert.NoError(t, err)
  21. assert.Equal(t, int64(3), trackedTime.UserID)
  22. assert.Equal(t, int64(1), trackedTime.IssueID)
  23. assert.Equal(t, int64(3661), trackedTime.Time)
  24. tt := unittest.AssertExistsAndLoadBean(t, &TrackedTime{UserID: 3, IssueID: 1}).(*TrackedTime)
  25. assert.Equal(t, int64(3661), tt.Time)
  26. comment := unittest.AssertExistsAndLoadBean(t, &Comment{Type: CommentTypeAddTimeManual, PosterID: 3, IssueID: 1}).(*Comment)
  27. assert.Equal(t, comment.Content, "1h 1min 1s")
  28. }
  29. func TestGetTrackedTimes(t *testing.T) {
  30. assert.NoError(t, unittest.PrepareTestDatabase())
  31. // by Issue
  32. times, err := GetTrackedTimes(&FindTrackedTimesOptions{IssueID: 1})
  33. assert.NoError(t, err)
  34. assert.Len(t, times, 1)
  35. assert.Equal(t, int64(400), times[0].Time)
  36. times, err = GetTrackedTimes(&FindTrackedTimesOptions{IssueID: -1})
  37. assert.NoError(t, err)
  38. assert.Len(t, times, 0)
  39. // by User
  40. times, err = GetTrackedTimes(&FindTrackedTimesOptions{UserID: 1})
  41. assert.NoError(t, err)
  42. assert.Len(t, times, 3)
  43. assert.Equal(t, int64(400), times[0].Time)
  44. times, err = GetTrackedTimes(&FindTrackedTimesOptions{UserID: 3})
  45. assert.NoError(t, err)
  46. assert.Len(t, times, 0)
  47. // by Repo
  48. times, err = GetTrackedTimes(&FindTrackedTimesOptions{RepositoryID: 2})
  49. assert.NoError(t, err)
  50. assert.Len(t, times, 3)
  51. assert.Equal(t, int64(1), times[0].Time)
  52. issue, err := GetIssueByID(times[0].IssueID)
  53. assert.NoError(t, err)
  54. assert.Equal(t, issue.RepoID, int64(2))
  55. times, err = GetTrackedTimes(&FindTrackedTimesOptions{RepositoryID: 1})
  56. assert.NoError(t, err)
  57. assert.Len(t, times, 5)
  58. times, err = GetTrackedTimes(&FindTrackedTimesOptions{RepositoryID: 10})
  59. assert.NoError(t, err)
  60. assert.Len(t, times, 0)
  61. }
  62. func TestTotalTimes(t *testing.T) {
  63. assert.NoError(t, unittest.PrepareTestDatabase())
  64. total, err := TotalTimes(&FindTrackedTimesOptions{IssueID: 1})
  65. assert.NoError(t, err)
  66. assert.Len(t, total, 1)
  67. for user, time := range total {
  68. assert.Equal(t, int64(1), user.ID)
  69. assert.Equal(t, "6min 40s", time)
  70. }
  71. total, err = TotalTimes(&FindTrackedTimesOptions{IssueID: 2})
  72. assert.NoError(t, err)
  73. assert.Len(t, total, 2)
  74. for user, time := range total {
  75. if user.ID == 2 {
  76. assert.Equal(t, "1h 1min 2s", time)
  77. } else if user.ID == 1 {
  78. assert.Equal(t, "20s", time)
  79. } else {
  80. assert.Error(t, assert.AnError)
  81. }
  82. }
  83. total, err = TotalTimes(&FindTrackedTimesOptions{IssueID: 5})
  84. assert.NoError(t, err)
  85. assert.Len(t, total, 1)
  86. for user, time := range total {
  87. assert.Equal(t, int64(2), user.ID)
  88. assert.Equal(t, "1s", time)
  89. }
  90. total, err = TotalTimes(&FindTrackedTimesOptions{IssueID: 4})
  91. assert.NoError(t, err)
  92. assert.Len(t, total, 2)
  93. }