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.

review_test.go 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. // Copyright 2020 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package issues_test
  4. import (
  5. "testing"
  6. "code.gitea.io/gitea/models/db"
  7. issues_model "code.gitea.io/gitea/models/issues"
  8. repo_model "code.gitea.io/gitea/models/repo"
  9. "code.gitea.io/gitea/models/unittest"
  10. user_model "code.gitea.io/gitea/models/user"
  11. "github.com/stretchr/testify/assert"
  12. )
  13. func TestGetReviewByID(t *testing.T) {
  14. assert.NoError(t, unittest.PrepareTestDatabase())
  15. review, err := issues_model.GetReviewByID(db.DefaultContext, 1)
  16. assert.NoError(t, err)
  17. assert.Equal(t, "Demo Review", review.Content)
  18. assert.Equal(t, issues_model.ReviewTypeApprove, review.Type)
  19. _, err = issues_model.GetReviewByID(db.DefaultContext, 23892)
  20. assert.Error(t, err)
  21. assert.True(t, issues_model.IsErrReviewNotExist(err), "IsErrReviewNotExist")
  22. }
  23. func TestReview_LoadAttributes(t *testing.T) {
  24. assert.NoError(t, unittest.PrepareTestDatabase())
  25. review := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 1})
  26. assert.NoError(t, review.LoadAttributes(db.DefaultContext))
  27. assert.NotNil(t, review.Issue)
  28. assert.NotNil(t, review.Reviewer)
  29. invalidReview1 := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 2})
  30. assert.Error(t, invalidReview1.LoadAttributes(db.DefaultContext))
  31. invalidReview2 := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 3})
  32. assert.Error(t, invalidReview2.LoadAttributes(db.DefaultContext))
  33. }
  34. func TestReview_LoadCodeComments(t *testing.T) {
  35. assert.NoError(t, unittest.PrepareTestDatabase())
  36. review := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 4})
  37. assert.NoError(t, review.LoadAttributes(db.DefaultContext))
  38. assert.NoError(t, review.LoadCodeComments(db.DefaultContext))
  39. assert.Len(t, review.CodeComments, 1)
  40. assert.Equal(t, int64(4), review.CodeComments["README.md"][int64(4)][0].Line)
  41. }
  42. func TestReviewType_Icon(t *testing.T) {
  43. assert.Equal(t, "check", issues_model.ReviewTypeApprove.Icon())
  44. assert.Equal(t, "diff", issues_model.ReviewTypeReject.Icon())
  45. assert.Equal(t, "comment", issues_model.ReviewTypeComment.Icon())
  46. assert.Equal(t, "comment", issues_model.ReviewTypeUnknown.Icon())
  47. assert.Equal(t, "dot-fill", issues_model.ReviewTypeRequest.Icon())
  48. assert.Equal(t, "comment", issues_model.ReviewType(6).Icon())
  49. }
  50. func TestFindReviews(t *testing.T) {
  51. assert.NoError(t, unittest.PrepareTestDatabase())
  52. reviews, err := issues_model.FindReviews(db.DefaultContext, issues_model.FindReviewOptions{
  53. Type: issues_model.ReviewTypeApprove,
  54. IssueID: 2,
  55. ReviewerID: 1,
  56. })
  57. assert.NoError(t, err)
  58. assert.Len(t, reviews, 1)
  59. assert.Equal(t, "Demo Review", reviews[0].Content)
  60. }
  61. func TestFindLatestReviews(t *testing.T) {
  62. assert.NoError(t, unittest.PrepareTestDatabase())
  63. reviews, err := issues_model.FindLatestReviews(db.DefaultContext, issues_model.FindReviewOptions{
  64. Type: issues_model.ReviewTypeApprove,
  65. IssueID: 11,
  66. })
  67. assert.NoError(t, err)
  68. assert.Len(t, reviews, 2)
  69. assert.Equal(t, "duplicate review from user5 (latest)", reviews[0].Content)
  70. assert.Equal(t, "singular review from org6 and final review for this pr", reviews[1].Content)
  71. }
  72. func TestGetCurrentReview(t *testing.T) {
  73. assert.NoError(t, unittest.PrepareTestDatabase())
  74. issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  75. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  76. review, err := issues_model.GetCurrentReview(db.DefaultContext, user, issue)
  77. assert.NoError(t, err)
  78. assert.NotNil(t, review)
  79. assert.Equal(t, issues_model.ReviewTypePending, review.Type)
  80. assert.Equal(t, "Pending Review", review.Content)
  81. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 7})
  82. review2, err := issues_model.GetCurrentReview(db.DefaultContext, user2, issue)
  83. assert.Error(t, err)
  84. assert.True(t, issues_model.IsErrReviewNotExist(err))
  85. assert.Nil(t, review2)
  86. }
  87. func TestCreateReview(t *testing.T) {
  88. assert.NoError(t, unittest.PrepareTestDatabase())
  89. issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  90. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  91. review, err := issues_model.CreateReview(db.DefaultContext, issues_model.CreateReviewOptions{
  92. Content: "New Review",
  93. Type: issues_model.ReviewTypePending,
  94. Issue: issue,
  95. Reviewer: user,
  96. })
  97. assert.NoError(t, err)
  98. assert.Equal(t, "New Review", review.Content)
  99. unittest.AssertExistsAndLoadBean(t, &issues_model.Review{Content: "New Review"})
  100. }
  101. func TestGetReviewersByIssueID(t *testing.T) {
  102. assert.NoError(t, unittest.PrepareTestDatabase())
  103. issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 3})
  104. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  105. org3 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 3})
  106. user4 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 4})
  107. expectedReviews := []*issues_model.Review{}
  108. expectedReviews = append(expectedReviews,
  109. &issues_model.Review{
  110. Reviewer: org3,
  111. Type: issues_model.ReviewTypeReject,
  112. UpdatedUnix: 946684812,
  113. },
  114. &issues_model.Review{
  115. Reviewer: user4,
  116. Type: issues_model.ReviewTypeApprove,
  117. UpdatedUnix: 946684813,
  118. },
  119. &issues_model.Review{
  120. Reviewer: user2,
  121. Type: issues_model.ReviewTypeReject,
  122. UpdatedUnix: 946684814,
  123. })
  124. allReviews, err := issues_model.GetReviewsByIssueID(db.DefaultContext, issue.ID)
  125. assert.NoError(t, err)
  126. for _, review := range allReviews {
  127. assert.NoError(t, review.LoadReviewer(db.DefaultContext))
  128. }
  129. if assert.Len(t, allReviews, 3) {
  130. for i, review := range allReviews {
  131. assert.Equal(t, expectedReviews[i].Reviewer, review.Reviewer)
  132. assert.Equal(t, expectedReviews[i].Type, review.Type)
  133. assert.Equal(t, expectedReviews[i].UpdatedUnix, review.UpdatedUnix)
  134. }
  135. }
  136. allReviews, err = issues_model.GetReviewsByIssueID(db.DefaultContext, issue.ID)
  137. assert.NoError(t, err)
  138. assert.NoError(t, allReviews.LoadReviewers(db.DefaultContext))
  139. if assert.Len(t, allReviews, 3) {
  140. for i, review := range allReviews {
  141. assert.Equal(t, expectedReviews[i].Reviewer, review.Reviewer)
  142. assert.Equal(t, expectedReviews[i].Type, review.Type)
  143. assert.Equal(t, expectedReviews[i].UpdatedUnix, review.UpdatedUnix)
  144. }
  145. }
  146. }
  147. func TestDismissReview(t *testing.T) {
  148. assert.NoError(t, unittest.PrepareTestDatabase())
  149. rejectReviewExample := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  150. requestReviewExample := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  151. approveReviewExample := unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 8})
  152. assert.False(t, rejectReviewExample.Dismissed)
  153. assert.False(t, requestReviewExample.Dismissed)
  154. assert.False(t, approveReviewExample.Dismissed)
  155. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, rejectReviewExample, true))
  156. rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  157. requestReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  158. assert.True(t, rejectReviewExample.Dismissed)
  159. assert.False(t, requestReviewExample.Dismissed)
  160. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, requestReviewExample, true))
  161. rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  162. requestReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  163. assert.True(t, rejectReviewExample.Dismissed)
  164. assert.False(t, requestReviewExample.Dismissed)
  165. assert.False(t, approveReviewExample.Dismissed)
  166. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, requestReviewExample, true))
  167. rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  168. requestReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  169. assert.True(t, rejectReviewExample.Dismissed)
  170. assert.False(t, requestReviewExample.Dismissed)
  171. assert.False(t, approveReviewExample.Dismissed)
  172. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, requestReviewExample, false))
  173. rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  174. requestReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  175. assert.True(t, rejectReviewExample.Dismissed)
  176. assert.False(t, requestReviewExample.Dismissed)
  177. assert.False(t, approveReviewExample.Dismissed)
  178. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, requestReviewExample, false))
  179. rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 9})
  180. requestReviewExample = unittest.AssertExistsAndLoadBean(t, &issues_model.Review{ID: 11})
  181. assert.True(t, rejectReviewExample.Dismissed)
  182. assert.False(t, requestReviewExample.Dismissed)
  183. assert.False(t, approveReviewExample.Dismissed)
  184. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, rejectReviewExample, false))
  185. assert.False(t, rejectReviewExample.Dismissed)
  186. assert.False(t, requestReviewExample.Dismissed)
  187. assert.False(t, approveReviewExample.Dismissed)
  188. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, approveReviewExample, true))
  189. assert.False(t, rejectReviewExample.Dismissed)
  190. assert.False(t, requestReviewExample.Dismissed)
  191. assert.True(t, approveReviewExample.Dismissed)
  192. }
  193. func TestDeleteReview(t *testing.T) {
  194. assert.NoError(t, unittest.PrepareTestDatabase())
  195. issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  196. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  197. review1, err := issues_model.CreateReview(db.DefaultContext, issues_model.CreateReviewOptions{
  198. Content: "Official rejection",
  199. Type: issues_model.ReviewTypeReject,
  200. Official: false,
  201. Issue: issue,
  202. Reviewer: user,
  203. })
  204. assert.NoError(t, err)
  205. review2, err := issues_model.CreateReview(db.DefaultContext, issues_model.CreateReviewOptions{
  206. Content: "Official approval",
  207. Type: issues_model.ReviewTypeApprove,
  208. Official: true,
  209. Issue: issue,
  210. Reviewer: user,
  211. })
  212. assert.NoError(t, err)
  213. assert.NoError(t, issues_model.DeleteReview(db.DefaultContext, review2))
  214. _, err = issues_model.GetReviewByID(db.DefaultContext, review2.ID)
  215. assert.Error(t, err)
  216. assert.True(t, issues_model.IsErrReviewNotExist(err), "IsErrReviewNotExist")
  217. review1, err = issues_model.GetReviewByID(db.DefaultContext, review1.ID)
  218. assert.NoError(t, err)
  219. assert.True(t, review1.Official)
  220. }
  221. func TestDeleteDismissedReview(t *testing.T) {
  222. assert.NoError(t, unittest.PrepareTestDatabase())
  223. issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 2})
  224. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  225. repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: issue.RepoID})
  226. review, err := issues_model.CreateReview(db.DefaultContext, issues_model.CreateReviewOptions{
  227. Content: "reject",
  228. Type: issues_model.ReviewTypeReject,
  229. Official: false,
  230. Issue: issue,
  231. Reviewer: user,
  232. })
  233. assert.NoError(t, err)
  234. assert.NoError(t, issues_model.DismissReview(db.DefaultContext, review, true))
  235. comment, err := issues_model.CreateComment(db.DefaultContext, &issues_model.CreateCommentOptions{
  236. Type: issues_model.CommentTypeDismissReview,
  237. Doer: user,
  238. Repo: repo,
  239. Issue: issue,
  240. ReviewID: review.ID,
  241. Content: "dismiss",
  242. })
  243. assert.NoError(t, err)
  244. unittest.AssertExistsAndLoadBean(t, &issues_model.Comment{ID: comment.ID})
  245. assert.NoError(t, issues_model.DeleteReview(db.DefaultContext, review))
  246. unittest.AssertNotExistsBean(t, &issues_model.Comment{ID: comment.ID})
  247. }
  248. func TestAddReviewRequest(t *testing.T) {
  249. assert.NoError(t, unittest.PrepareTestDatabase())
  250. pull := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1})
  251. assert.NoError(t, pull.LoadIssue(db.DefaultContext))
  252. issue := pull.Issue
  253. assert.NoError(t, issue.LoadRepo(db.DefaultContext))
  254. reviewer := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  255. _, err := issues_model.CreateReview(db.DefaultContext, issues_model.CreateReviewOptions{
  256. Issue: issue,
  257. Reviewer: reviewer,
  258. Type: issues_model.ReviewTypeReject,
  259. })
  260. assert.NoError(t, err)
  261. pull.HasMerged = false
  262. assert.NoError(t, pull.UpdateCols(db.DefaultContext, "has_merged"))
  263. issue.IsClosed = true
  264. _, err = issues_model.AddReviewRequest(db.DefaultContext, issue, reviewer, &user_model.User{})
  265. assert.Error(t, err)
  266. assert.True(t, issues_model.IsErrReviewRequestOnClosedPR(err))
  267. pull.HasMerged = true
  268. assert.NoError(t, pull.UpdateCols(db.DefaultContext, "has_merged"))
  269. issue.IsClosed = false
  270. _, err = issues_model.AddReviewRequest(db.DefaultContext, issue, reviewer, &user_model.User{})
  271. assert.Error(t, err)
  272. assert.True(t, issues_model.IsErrReviewRequestOnClosedPR(err))
  273. }