gitea源码

review_test.go 12KB

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