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

issue_label_test.go 7.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. // Copyright 2017 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. "html/template"
  7. "testing"
  8. api "code.gitea.io/sdk/gitea"
  9. "github.com/stretchr/testify/assert"
  10. )
  11. // TODO TestGetLabelTemplateFile
  12. func TestLabel_APIFormat(t *testing.T) {
  13. assert.NoError(t, PrepareTestDatabase())
  14. label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  15. assert.Equal(t, api.Label{
  16. ID: label.ID,
  17. Name: label.Name,
  18. Color: "abcdef",
  19. }, *label.APIFormat())
  20. }
  21. func TestLabel_CalOpenIssues(t *testing.T) {
  22. assert.NoError(t, PrepareTestDatabase())
  23. label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  24. label.CalOpenIssues()
  25. assert.EqualValues(t, 2, label.NumOpenIssues)
  26. }
  27. func TestLabel_ForegroundColor(t *testing.T) {
  28. assert.NoError(t, PrepareTestDatabase())
  29. label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  30. assert.Equal(t, template.CSS("#000"), label.ForegroundColor())
  31. label = AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
  32. assert.Equal(t, template.CSS("#fff"), label.ForegroundColor())
  33. }
  34. func TestNewLabels(t *testing.T) {
  35. assert.NoError(t, PrepareTestDatabase())
  36. labels := []*Label{
  37. {RepoID: 2, Name: "labelName2", Color: "#123456"},
  38. {RepoID: 3, Name: "labelName3", Color: "#234567"},
  39. }
  40. for _, label := range labels {
  41. AssertNotExistsBean(t, label)
  42. }
  43. assert.NoError(t, NewLabels(labels...))
  44. for _, label := range labels {
  45. AssertExistsAndLoadBean(t, label)
  46. }
  47. }
  48. func TestGetLabelByID(t *testing.T) {
  49. assert.NoError(t, PrepareTestDatabase())
  50. label, err := GetLabelByID(1)
  51. assert.NoError(t, err)
  52. assert.EqualValues(t, 1, label.ID)
  53. _, err = GetLabelByID(NonexistentID)
  54. assert.True(t, IsErrLabelNotExist(err))
  55. }
  56. func TestGetLabelInRepoByName(t *testing.T) {
  57. assert.NoError(t, PrepareTestDatabase())
  58. label, err := GetLabelInRepoByName(1, "label1")
  59. assert.NoError(t, err)
  60. assert.EqualValues(t, 1, label.ID)
  61. assert.Equal(t, "label1", label.Name)
  62. _, err = GetLabelInRepoByName(1, "")
  63. assert.True(t, IsErrLabelNotExist(err))
  64. _, err = GetLabelInRepoByName(NonexistentID, "nonexistent")
  65. assert.True(t, IsErrLabelNotExist(err))
  66. }
  67. func TestGetLabelInRepoByID(t *testing.T) {
  68. assert.NoError(t, PrepareTestDatabase())
  69. label, err := GetLabelInRepoByID(1, 1)
  70. assert.NoError(t, err)
  71. assert.EqualValues(t, 1, label.ID)
  72. _, err = GetLabelInRepoByID(1, -1)
  73. assert.True(t, IsErrLabelNotExist(err))
  74. _, err = GetLabelInRepoByID(NonexistentID, NonexistentID)
  75. assert.True(t, IsErrLabelNotExist(err))
  76. }
  77. func TestGetLabelsInRepoByIDs(t *testing.T) {
  78. assert.NoError(t, PrepareTestDatabase())
  79. labels, err := GetLabelsInRepoByIDs(1, []int64{1, 2, NonexistentID})
  80. assert.NoError(t, err)
  81. assert.Len(t, labels, 2)
  82. assert.EqualValues(t, 1, labels[0].ID)
  83. assert.EqualValues(t, 2, labels[1].ID)
  84. }
  85. func TestGetLabelsByRepoID(t *testing.T) {
  86. assert.NoError(t, PrepareTestDatabase())
  87. testSuccess := func(repoID int64, sortType string, expectedIssueIDs []int64) {
  88. labels, err := GetLabelsByRepoID(repoID, sortType)
  89. assert.NoError(t, err)
  90. assert.Len(t, labels, len(expectedIssueIDs))
  91. for i, label := range labels {
  92. assert.EqualValues(t, expectedIssueIDs[i], label.ID)
  93. }
  94. }
  95. testSuccess(1, "leastissues", []int64{2, 1})
  96. testSuccess(1, "mostissues", []int64{1, 2})
  97. testSuccess(1, "reversealphabetically", []int64{2, 1})
  98. testSuccess(1, "default", []int64{1, 2})
  99. }
  100. func TestGetLabelsByIssueID(t *testing.T) {
  101. assert.NoError(t, PrepareTestDatabase())
  102. labels, err := GetLabelsByIssueID(1)
  103. assert.NoError(t, err)
  104. assert.Len(t, labels, 1)
  105. assert.EqualValues(t, 1, labels[0].ID)
  106. labels, err = GetLabelsByIssueID(NonexistentID)
  107. assert.NoError(t, err)
  108. assert.Len(t, labels, 0)
  109. }
  110. func TestUpdateLabel(t *testing.T) {
  111. assert.NoError(t, PrepareTestDatabase())
  112. label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  113. label.Color = "#ffff00"
  114. label.Name = "newLabelName"
  115. assert.NoError(t, UpdateLabel(label))
  116. newLabel := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  117. assert.Equal(t, *label, *newLabel)
  118. }
  119. func TestDeleteLabel(t *testing.T) {
  120. assert.NoError(t, PrepareTestDatabase())
  121. label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  122. assert.NoError(t, DeleteLabel(label.RepoID, label.ID))
  123. AssertNotExistsBean(t, &Label{ID: label.ID, RepoID: label.RepoID})
  124. assert.NoError(t, DeleteLabel(label.RepoID, label.ID))
  125. AssertNotExistsBean(t, &Label{ID: label.ID, RepoID: label.RepoID})
  126. assert.NoError(t, DeleteLabel(NonexistentID, NonexistentID))
  127. }
  128. func TestHasIssueLabel(t *testing.T) {
  129. assert.NoError(t, PrepareTestDatabase())
  130. assert.True(t, HasIssueLabel(1, 1))
  131. assert.False(t, HasIssueLabel(1, 2))
  132. assert.False(t, HasIssueLabel(NonexistentID, NonexistentID))
  133. }
  134. func TestNewIssueLabel(t *testing.T) {
  135. assert.NoError(t, PrepareTestDatabase())
  136. label := AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
  137. issue := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
  138. doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
  139. // add new IssueLabel
  140. prevNumIssues := label.NumIssues
  141. assert.NoError(t, NewIssueLabel(issue, label, doer))
  142. AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label.ID})
  143. AssertExistsAndLoadBean(t, &Comment{
  144. Type: CommentTypeLabel,
  145. PosterID: doer.ID,
  146. IssueID: issue.ID,
  147. LabelID: label.ID,
  148. Content: "1",
  149. })
  150. assert.EqualValues(t, prevNumIssues+1, label.NumIssues)
  151. // re-add existing IssueLabel
  152. assert.NoError(t, NewIssueLabel(issue, label, doer))
  153. }
  154. func TestNewIssueLabels(t *testing.T) {
  155. assert.NoError(t, PrepareTestDatabase())
  156. label1 := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  157. label2 := AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
  158. issue := AssertExistsAndLoadBean(t, &Issue{ID: 5}).(*Issue)
  159. doer := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
  160. assert.NoError(t, NewIssueLabels(issue, []*Label{label1, label2}, doer))
  161. AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label1.ID})
  162. AssertExistsAndLoadBean(t, &Comment{
  163. Type: CommentTypeLabel,
  164. PosterID: doer.ID,
  165. IssueID: issue.ID,
  166. LabelID: label1.ID,
  167. Content: "1",
  168. })
  169. AssertExistsAndLoadBean(t, &IssueLabel{IssueID: issue.ID, LabelID: label1.ID})
  170. label1 = AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
  171. assert.EqualValues(t, 3, label1.NumIssues)
  172. assert.EqualValues(t, 1, label1.NumClosedIssues)
  173. label2 = AssertExistsAndLoadBean(t, &Label{ID: 2}).(*Label)
  174. assert.EqualValues(t, 1, label2.NumIssues)
  175. assert.EqualValues(t, 1, label2.NumClosedIssues)
  176. // corner case: test empty slice
  177. assert.NoError(t, NewIssueLabels(issue, []*Label{}, doer))
  178. }
  179. func TestDeleteIssueLabel(t *testing.T) {
  180. assert.NoError(t, PrepareTestDatabase())
  181. testSuccess := func(labelID, issueID, doerID int64) {
  182. label := AssertExistsAndLoadBean(t, &Label{ID: labelID}).(*Label)
  183. issue := AssertExistsAndLoadBean(t, &Issue{ID: issueID}).(*Issue)
  184. doer := AssertExistsAndLoadBean(t, &User{ID: doerID}).(*User)
  185. expectedNumIssues := label.NumIssues
  186. expectedNumClosedIssues := label.NumClosedIssues
  187. if BeanExists(t, &IssueLabel{IssueID: issueID, LabelID: labelID}) {
  188. expectedNumIssues--
  189. if issue.IsClosed {
  190. expectedNumClosedIssues--
  191. }
  192. }
  193. assert.NoError(t, DeleteIssueLabel(issue, label, doer))
  194. AssertNotExistsBean(t, &IssueLabel{IssueID: issueID, LabelID: labelID})
  195. AssertExistsAndLoadBean(t, &Comment{
  196. Type: CommentTypeLabel,
  197. PosterID: doerID,
  198. IssueID: issueID,
  199. LabelID: labelID,
  200. }, `content=""`)
  201. label = AssertExistsAndLoadBean(t, &Label{ID: labelID}).(*Label)
  202. assert.EqualValues(t, expectedNumIssues, label.NumIssues)
  203. assert.EqualValues(t, expectedNumClosedIssues, label.NumClosedIssues)
  204. }
  205. testSuccess(1, 1, 2)
  206. testSuccess(2, 5, 2)
  207. testSuccess(1, 1, 2) // delete non-existent IssueLabel
  208. }