gitea源码

privateactivity_test.go 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. // Copyright 2020 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "fmt"
  6. "net/http"
  7. "testing"
  8. activities_model "code.gitea.io/gitea/models/activities"
  9. auth_model "code.gitea.io/gitea/models/auth"
  10. repo_model "code.gitea.io/gitea/models/repo"
  11. "code.gitea.io/gitea/models/unittest"
  12. user_model "code.gitea.io/gitea/models/user"
  13. api "code.gitea.io/gitea/modules/structs"
  14. "code.gitea.io/gitea/tests"
  15. "github.com/stretchr/testify/assert"
  16. )
  17. const (
  18. privateActivityTestAdmin = "user1"
  19. privateActivityTestUser = "user2"
  20. )
  21. // org3 is an organization so it is not usable here
  22. const privateActivityTestOtherUser = "user4"
  23. // activity helpers
  24. func testPrivateActivityDoSomethingForActionEntries(t *testing.T) {
  25. repoBefore := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
  26. owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repoBefore.OwnerID})
  27. session := loginUser(t, privateActivityTestUser)
  28. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue)
  29. urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues?state=all", owner.Name, repoBefore.Name)
  30. req := NewRequestWithJSON(t, "POST", urlStr, &api.CreateIssueOption{
  31. Body: "test",
  32. Title: "test",
  33. }).AddTokenAuth(token)
  34. session.MakeRequest(t, req, http.StatusCreated)
  35. }
  36. // private activity helpers
  37. func testPrivateActivityHelperEnablePrivateActivity(t *testing.T) {
  38. session := loginUser(t, privateActivityTestUser)
  39. req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{
  40. "_csrf": GetUserCSRFToken(t, session),
  41. "name": privateActivityTestUser,
  42. "email": privateActivityTestUser + "@example.com",
  43. "language": "en-US",
  44. "keep_activity_private": "1",
  45. })
  46. session.MakeRequest(t, req, http.StatusSeeOther)
  47. }
  48. func testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc *HTMLDoc) bool {
  49. return htmlDoc.doc.Find("#activity-feed").Find(".flex-item").Length() > 0
  50. }
  51. func testPrivateActivityHelperHasVisibleActivitiesFromSession(t *testing.T, session *TestSession) bool {
  52. req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
  53. resp := session.MakeRequest(t, req, http.StatusOK)
  54. htmlDoc := NewHTMLParser(t, resp.Body)
  55. return testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc)
  56. }
  57. func testPrivateActivityHelperHasVisibleActivitiesFromPublic(t *testing.T) bool {
  58. req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
  59. resp := MakeRequest(t, req, http.StatusOK)
  60. htmlDoc := NewHTMLParser(t, resp.Body)
  61. return testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc)
  62. }
  63. // heatmap UI helpers
  64. func testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc *HTMLDoc) bool {
  65. return htmlDoc.doc.Find("#user-heatmap").Length() > 0
  66. }
  67. func testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t *testing.T, session *TestSession) bool {
  68. req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
  69. resp := session.MakeRequest(t, req, http.StatusOK)
  70. htmlDoc := NewHTMLParser(t, resp.Body)
  71. return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
  72. }
  73. func testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t *testing.T, session *TestSession) bool {
  74. req := NewRequest(t, "GET", "/")
  75. resp := session.MakeRequest(t, req, http.StatusOK)
  76. htmlDoc := NewHTMLParser(t, resp.Body)
  77. return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
  78. }
  79. func testPrivateActivityHelperHasVisibleHeatmapFromPublic(t *testing.T) bool {
  80. req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
  81. resp := MakeRequest(t, req, http.StatusOK)
  82. htmlDoc := NewHTMLParser(t, resp.Body)
  83. return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
  84. }
  85. // heatmap API helpers
  86. func testPrivateActivityHelperHasHeatmapContentFromPublic(t *testing.T) bool {
  87. req := NewRequestf(t, "GET", "/api/v1/users/%s/heatmap", privateActivityTestUser)
  88. resp := MakeRequest(t, req, http.StatusOK)
  89. var items []*activities_model.UserHeatmapData
  90. DecodeJSON(t, resp, &items)
  91. return len(items) != 0
  92. }
  93. func testPrivateActivityHelperHasHeatmapContentFromSession(t *testing.T, session *TestSession) bool {
  94. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadUser)
  95. req := NewRequestf(t, "GET", "/api/v1/users/%s/heatmap", privateActivityTestUser).
  96. AddTokenAuth(token)
  97. resp := session.MakeRequest(t, req, http.StatusOK)
  98. var items []*activities_model.UserHeatmapData
  99. DecodeJSON(t, resp, &items)
  100. return len(items) != 0
  101. }
  102. // check activity visibility if the visibility is enabled
  103. func TestPrivateActivityNoVisibleForPublic(t *testing.T) {
  104. defer tests.PrepareTestEnv(t)()
  105. testPrivateActivityDoSomethingForActionEntries(t)
  106. visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
  107. assert.True(t, visible, "user should have visible activities")
  108. }
  109. func TestPrivateActivityNoVisibleForUserItself(t *testing.T) {
  110. defer tests.PrepareTestEnv(t)()
  111. testPrivateActivityDoSomethingForActionEntries(t)
  112. session := loginUser(t, privateActivityTestUser)
  113. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  114. assert.True(t, visible, "user should have visible activities")
  115. }
  116. func TestPrivateActivityNoVisibleForOtherUser(t *testing.T) {
  117. defer tests.PrepareTestEnv(t)()
  118. testPrivateActivityDoSomethingForActionEntries(t)
  119. session := loginUser(t, privateActivityTestOtherUser)
  120. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  121. assert.True(t, visible, "user should have visible activities")
  122. }
  123. func TestPrivateActivityNoVisibleForAdmin(t *testing.T) {
  124. defer tests.PrepareTestEnv(t)()
  125. testPrivateActivityDoSomethingForActionEntries(t)
  126. session := loginUser(t, privateActivityTestAdmin)
  127. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  128. assert.True(t, visible, "user should have visible activities")
  129. }
  130. // check activity visibility if the visibility is disabled
  131. func TestPrivateActivityYesInvisibleForPublic(t *testing.T) {
  132. defer tests.PrepareTestEnv(t)()
  133. testPrivateActivityDoSomethingForActionEntries(t)
  134. testPrivateActivityHelperEnablePrivateActivity(t)
  135. visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
  136. assert.False(t, visible, "user should have no visible activities")
  137. }
  138. func TestPrivateActivityYesVisibleForUserItself(t *testing.T) {
  139. defer tests.PrepareTestEnv(t)()
  140. testPrivateActivityDoSomethingForActionEntries(t)
  141. testPrivateActivityHelperEnablePrivateActivity(t)
  142. session := loginUser(t, privateActivityTestUser)
  143. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  144. assert.True(t, visible, "user should have visible activities")
  145. }
  146. func TestPrivateActivityYesInvisibleForOtherUser(t *testing.T) {
  147. defer tests.PrepareTestEnv(t)()
  148. testPrivateActivityDoSomethingForActionEntries(t)
  149. testPrivateActivityHelperEnablePrivateActivity(t)
  150. session := loginUser(t, privateActivityTestOtherUser)
  151. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  152. assert.False(t, visible, "user should have no visible activities")
  153. }
  154. func TestPrivateActivityYesVisibleForAdmin(t *testing.T) {
  155. defer tests.PrepareTestEnv(t)()
  156. testPrivateActivityDoSomethingForActionEntries(t)
  157. testPrivateActivityHelperEnablePrivateActivity(t)
  158. session := loginUser(t, privateActivityTestAdmin)
  159. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  160. assert.True(t, visible, "user should have visible activities")
  161. }
  162. // check heatmap visibility if the visibility is enabled
  163. func TestPrivateActivityNoHeatmapVisibleForPublic(t *testing.T) {
  164. defer tests.PrepareTestEnv(t)()
  165. testPrivateActivityDoSomethingForActionEntries(t)
  166. visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
  167. assert.True(t, visible, "user should have visible heatmap")
  168. }
  169. func TestPrivateActivityNoHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
  170. defer tests.PrepareTestEnv(t)()
  171. testPrivateActivityDoSomethingForActionEntries(t)
  172. session := loginUser(t, privateActivityTestUser)
  173. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  174. assert.True(t, visible, "user should have visible heatmap")
  175. }
  176. func TestPrivateActivityNoHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
  177. defer tests.PrepareTestEnv(t)()
  178. testPrivateActivityDoSomethingForActionEntries(t)
  179. session := loginUser(t, privateActivityTestUser)
  180. visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
  181. assert.True(t, visible, "user should have visible heatmap")
  182. }
  183. func TestPrivateActivityNoHeatmapVisibleForOtherUser(t *testing.T) {
  184. defer tests.PrepareTestEnv(t)()
  185. testPrivateActivityDoSomethingForActionEntries(t)
  186. session := loginUser(t, privateActivityTestOtherUser)
  187. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  188. assert.True(t, visible, "user should have visible heatmap")
  189. }
  190. func TestPrivateActivityNoHeatmapVisibleForAdmin(t *testing.T) {
  191. defer tests.PrepareTestEnv(t)()
  192. testPrivateActivityDoSomethingForActionEntries(t)
  193. session := loginUser(t, privateActivityTestAdmin)
  194. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  195. assert.True(t, visible, "user should have visible heatmap")
  196. }
  197. // check heatmap visibility if the visibility is disabled
  198. func TestPrivateActivityYesHeatmapInvisibleForPublic(t *testing.T) {
  199. defer tests.PrepareTestEnv(t)()
  200. testPrivateActivityDoSomethingForActionEntries(t)
  201. testPrivateActivityHelperEnablePrivateActivity(t)
  202. visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
  203. assert.False(t, visible, "user should have no visible heatmap")
  204. }
  205. func TestPrivateActivityYesHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
  206. defer tests.PrepareTestEnv(t)()
  207. testPrivateActivityDoSomethingForActionEntries(t)
  208. testPrivateActivityHelperEnablePrivateActivity(t)
  209. session := loginUser(t, privateActivityTestUser)
  210. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  211. assert.True(t, visible, "user should have visible heatmap")
  212. }
  213. func TestPrivateActivityYesHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
  214. defer tests.PrepareTestEnv(t)()
  215. testPrivateActivityDoSomethingForActionEntries(t)
  216. testPrivateActivityHelperEnablePrivateActivity(t)
  217. session := loginUser(t, privateActivityTestUser)
  218. visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
  219. assert.True(t, visible, "user should have visible heatmap")
  220. }
  221. func TestPrivateActivityYesHeatmapInvisibleForOtherUser(t *testing.T) {
  222. defer tests.PrepareTestEnv(t)()
  223. testPrivateActivityDoSomethingForActionEntries(t)
  224. testPrivateActivityHelperEnablePrivateActivity(t)
  225. session := loginUser(t, privateActivityTestOtherUser)
  226. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  227. assert.False(t, visible, "user should have no visible heatmap")
  228. }
  229. func TestPrivateActivityYesHeatmapVisibleForAdmin(t *testing.T) {
  230. defer tests.PrepareTestEnv(t)()
  231. testPrivateActivityDoSomethingForActionEntries(t)
  232. testPrivateActivityHelperEnablePrivateActivity(t)
  233. session := loginUser(t, privateActivityTestAdmin)
  234. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  235. assert.True(t, visible, "user should have visible heatmap")
  236. }
  237. // check heatmap api provides content if the visibility is enabled
  238. func TestPrivateActivityNoHeatmapHasContentForPublic(t *testing.T) {
  239. defer tests.PrepareTestEnv(t)()
  240. testPrivateActivityDoSomethingForActionEntries(t)
  241. hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
  242. assert.True(t, hasContent, "user should have heatmap content")
  243. }
  244. func TestPrivateActivityNoHeatmapHasContentForUserItself(t *testing.T) {
  245. defer tests.PrepareTestEnv(t)()
  246. testPrivateActivityDoSomethingForActionEntries(t)
  247. session := loginUser(t, privateActivityTestUser)
  248. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  249. assert.True(t, hasContent, "user should have heatmap content")
  250. }
  251. func TestPrivateActivityNoHeatmapHasContentForOtherUser(t *testing.T) {
  252. defer tests.PrepareTestEnv(t)()
  253. testPrivateActivityDoSomethingForActionEntries(t)
  254. session := loginUser(t, privateActivityTestOtherUser)
  255. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  256. assert.True(t, hasContent, "user should have heatmap content")
  257. }
  258. func TestPrivateActivityNoHeatmapHasContentForAdmin(t *testing.T) {
  259. defer tests.PrepareTestEnv(t)()
  260. testPrivateActivityDoSomethingForActionEntries(t)
  261. session := loginUser(t, privateActivityTestAdmin)
  262. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  263. assert.True(t, hasContent, "user should have heatmap content")
  264. }
  265. // check heatmap api provides no content if the visibility is disabled
  266. // this should be equal to the hidden heatmap at the UI
  267. func TestPrivateActivityYesHeatmapHasNoContentForPublic(t *testing.T) {
  268. defer tests.PrepareTestEnv(t)()
  269. testPrivateActivityDoSomethingForActionEntries(t)
  270. testPrivateActivityHelperEnablePrivateActivity(t)
  271. hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
  272. assert.False(t, hasContent, "user should have no heatmap content")
  273. }
  274. func TestPrivateActivityYesHeatmapHasNoContentForUserItself(t *testing.T) {
  275. defer tests.PrepareTestEnv(t)()
  276. testPrivateActivityDoSomethingForActionEntries(t)
  277. testPrivateActivityHelperEnablePrivateActivity(t)
  278. session := loginUser(t, privateActivityTestUser)
  279. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  280. assert.True(t, hasContent, "user should see their own heatmap content")
  281. }
  282. func TestPrivateActivityYesHeatmapHasNoContentForOtherUser(t *testing.T) {
  283. defer tests.PrepareTestEnv(t)()
  284. testPrivateActivityDoSomethingForActionEntries(t)
  285. testPrivateActivityHelperEnablePrivateActivity(t)
  286. session := loginUser(t, privateActivityTestOtherUser)
  287. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  288. assert.False(t, hasContent, "other user should not see heatmap content")
  289. }
  290. func TestPrivateActivityYesHeatmapHasNoContentForAdmin(t *testing.T) {
  291. defer tests.PrepareTestEnv(t)()
  292. testPrivateActivityDoSomethingForActionEntries(t)
  293. testPrivateActivityHelperEnablePrivateActivity(t)
  294. session := loginUser(t, privateActivityTestAdmin)
  295. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  296. assert.True(t, hasContent, "heatmap should show content for admin")
  297. }