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.

privateactivity_test.go 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  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&token=%s", owner.Name, repoBefore.Name, token)
  30. req := NewRequestWithJSON(t, "POST", urlStr, &api.CreateIssueOption{
  31. Body: "test",
  32. Title: "test",
  33. })
  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": GetCSRF(t, session, "/user/settings"),
  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?token=%s", privateActivityTestUser, token)
  96. resp := session.MakeRequest(t, req, http.StatusOK)
  97. var items []*activities_model.UserHeatmapData
  98. DecodeJSON(t, resp, &items)
  99. return len(items) != 0
  100. }
  101. // check activity visibility if the visibility is enabled
  102. func TestPrivateActivityNoVisibleForPublic(t *testing.T) {
  103. defer tests.PrepareTestEnv(t)()
  104. testPrivateActivityDoSomethingForActionEntries(t)
  105. visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
  106. assert.True(t, visible, "user should have visible activities")
  107. }
  108. func TestPrivateActivityNoVisibleForUserItself(t *testing.T) {
  109. defer tests.PrepareTestEnv(t)()
  110. testPrivateActivityDoSomethingForActionEntries(t)
  111. session := loginUser(t, privateActivityTestUser)
  112. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  113. assert.True(t, visible, "user should have visible activities")
  114. }
  115. func TestPrivateActivityNoVisibleForOtherUser(t *testing.T) {
  116. defer tests.PrepareTestEnv(t)()
  117. testPrivateActivityDoSomethingForActionEntries(t)
  118. session := loginUser(t, privateActivityTestOtherUser)
  119. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  120. assert.True(t, visible, "user should have visible activities")
  121. }
  122. func TestPrivateActivityNoVisibleForAdmin(t *testing.T) {
  123. defer tests.PrepareTestEnv(t)()
  124. testPrivateActivityDoSomethingForActionEntries(t)
  125. session := loginUser(t, privateActivityTestAdmin)
  126. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  127. assert.True(t, visible, "user should have visible activities")
  128. }
  129. // check activity visibility if the visibility is disabled
  130. func TestPrivateActivityYesInvisibleForPublic(t *testing.T) {
  131. defer tests.PrepareTestEnv(t)()
  132. testPrivateActivityDoSomethingForActionEntries(t)
  133. testPrivateActivityHelperEnablePrivateActivity(t)
  134. visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
  135. assert.False(t, visible, "user should have no visible activities")
  136. }
  137. func TestPrivateActivityYesVisibleForUserItself(t *testing.T) {
  138. defer tests.PrepareTestEnv(t)()
  139. testPrivateActivityDoSomethingForActionEntries(t)
  140. testPrivateActivityHelperEnablePrivateActivity(t)
  141. session := loginUser(t, privateActivityTestUser)
  142. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  143. assert.True(t, visible, "user should have visible activities")
  144. }
  145. func TestPrivateActivityYesInvisibleForOtherUser(t *testing.T) {
  146. defer tests.PrepareTestEnv(t)()
  147. testPrivateActivityDoSomethingForActionEntries(t)
  148. testPrivateActivityHelperEnablePrivateActivity(t)
  149. session := loginUser(t, privateActivityTestOtherUser)
  150. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  151. assert.False(t, visible, "user should have no visible activities")
  152. }
  153. func TestPrivateActivityYesVisibleForAdmin(t *testing.T) {
  154. defer tests.PrepareTestEnv(t)()
  155. testPrivateActivityDoSomethingForActionEntries(t)
  156. testPrivateActivityHelperEnablePrivateActivity(t)
  157. session := loginUser(t, privateActivityTestAdmin)
  158. visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
  159. assert.True(t, visible, "user should have visible activities")
  160. }
  161. // check heatmap visibility if the visibility is enabled
  162. func TestPrivateActivityNoHeatmapVisibleForPublic(t *testing.T) {
  163. defer tests.PrepareTestEnv(t)()
  164. testPrivateActivityDoSomethingForActionEntries(t)
  165. visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
  166. assert.True(t, visible, "user should have visible heatmap")
  167. }
  168. func TestPrivateActivityNoHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
  169. defer tests.PrepareTestEnv(t)()
  170. testPrivateActivityDoSomethingForActionEntries(t)
  171. session := loginUser(t, privateActivityTestUser)
  172. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  173. assert.True(t, visible, "user should have visible heatmap")
  174. }
  175. func TestPrivateActivityNoHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
  176. defer tests.PrepareTestEnv(t)()
  177. testPrivateActivityDoSomethingForActionEntries(t)
  178. session := loginUser(t, privateActivityTestUser)
  179. visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
  180. assert.True(t, visible, "user should have visible heatmap")
  181. }
  182. func TestPrivateActivityNoHeatmapVisibleForOtherUser(t *testing.T) {
  183. defer tests.PrepareTestEnv(t)()
  184. testPrivateActivityDoSomethingForActionEntries(t)
  185. session := loginUser(t, privateActivityTestOtherUser)
  186. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  187. assert.True(t, visible, "user should have visible heatmap")
  188. }
  189. func TestPrivateActivityNoHeatmapVisibleForAdmin(t *testing.T) {
  190. defer tests.PrepareTestEnv(t)()
  191. testPrivateActivityDoSomethingForActionEntries(t)
  192. session := loginUser(t, privateActivityTestAdmin)
  193. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  194. assert.True(t, visible, "user should have visible heatmap")
  195. }
  196. // check heatmap visibility if the visibility is disabled
  197. func TestPrivateActivityYesHeatmapInvisibleForPublic(t *testing.T) {
  198. defer tests.PrepareTestEnv(t)()
  199. testPrivateActivityDoSomethingForActionEntries(t)
  200. testPrivateActivityHelperEnablePrivateActivity(t)
  201. visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
  202. assert.False(t, visible, "user should have no visible heatmap")
  203. }
  204. func TestPrivateActivityYesHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
  205. defer tests.PrepareTestEnv(t)()
  206. testPrivateActivityDoSomethingForActionEntries(t)
  207. testPrivateActivityHelperEnablePrivateActivity(t)
  208. session := loginUser(t, privateActivityTestUser)
  209. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  210. assert.True(t, visible, "user should have visible heatmap")
  211. }
  212. func TestPrivateActivityYesHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
  213. defer tests.PrepareTestEnv(t)()
  214. testPrivateActivityDoSomethingForActionEntries(t)
  215. testPrivateActivityHelperEnablePrivateActivity(t)
  216. session := loginUser(t, privateActivityTestUser)
  217. visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
  218. assert.True(t, visible, "user should have visible heatmap")
  219. }
  220. func TestPrivateActivityYesHeatmapInvisibleForOtherUser(t *testing.T) {
  221. defer tests.PrepareTestEnv(t)()
  222. testPrivateActivityDoSomethingForActionEntries(t)
  223. testPrivateActivityHelperEnablePrivateActivity(t)
  224. session := loginUser(t, privateActivityTestOtherUser)
  225. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  226. assert.False(t, visible, "user should have no visible heatmap")
  227. }
  228. func TestPrivateActivityYesHeatmapVisibleForAdmin(t *testing.T) {
  229. defer tests.PrepareTestEnv(t)()
  230. testPrivateActivityDoSomethingForActionEntries(t)
  231. testPrivateActivityHelperEnablePrivateActivity(t)
  232. session := loginUser(t, privateActivityTestAdmin)
  233. visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
  234. assert.True(t, visible, "user should have visible heatmap")
  235. }
  236. // check heatmap api provides content if the visibility is enabled
  237. func TestPrivateActivityNoHeatmapHasContentForPublic(t *testing.T) {
  238. defer tests.PrepareTestEnv(t)()
  239. testPrivateActivityDoSomethingForActionEntries(t)
  240. hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
  241. assert.True(t, hasContent, "user should have heatmap content")
  242. }
  243. func TestPrivateActivityNoHeatmapHasContentForUserItself(t *testing.T) {
  244. defer tests.PrepareTestEnv(t)()
  245. testPrivateActivityDoSomethingForActionEntries(t)
  246. session := loginUser(t, privateActivityTestUser)
  247. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  248. assert.True(t, hasContent, "user should have heatmap content")
  249. }
  250. func TestPrivateActivityNoHeatmapHasContentForOtherUser(t *testing.T) {
  251. defer tests.PrepareTestEnv(t)()
  252. testPrivateActivityDoSomethingForActionEntries(t)
  253. session := loginUser(t, privateActivityTestOtherUser)
  254. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  255. assert.True(t, hasContent, "user should have heatmap content")
  256. }
  257. func TestPrivateActivityNoHeatmapHasContentForAdmin(t *testing.T) {
  258. defer tests.PrepareTestEnv(t)()
  259. testPrivateActivityDoSomethingForActionEntries(t)
  260. session := loginUser(t, privateActivityTestAdmin)
  261. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  262. assert.True(t, hasContent, "user should have heatmap content")
  263. }
  264. // check heatmap api provides no content if the visibility is disabled
  265. // this should be equal to the hidden heatmap at the UI
  266. func TestPrivateActivityYesHeatmapHasNoContentForPublic(t *testing.T) {
  267. defer tests.PrepareTestEnv(t)()
  268. testPrivateActivityDoSomethingForActionEntries(t)
  269. testPrivateActivityHelperEnablePrivateActivity(t)
  270. hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
  271. assert.False(t, hasContent, "user should have no heatmap content")
  272. }
  273. func TestPrivateActivityYesHeatmapHasNoContentForUserItself(t *testing.T) {
  274. defer tests.PrepareTestEnv(t)()
  275. testPrivateActivityDoSomethingForActionEntries(t)
  276. testPrivateActivityHelperEnablePrivateActivity(t)
  277. session := loginUser(t, privateActivityTestUser)
  278. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  279. assert.True(t, hasContent, "user should see their own heatmap content")
  280. }
  281. func TestPrivateActivityYesHeatmapHasNoContentForOtherUser(t *testing.T) {
  282. defer tests.PrepareTestEnv(t)()
  283. testPrivateActivityDoSomethingForActionEntries(t)
  284. testPrivateActivityHelperEnablePrivateActivity(t)
  285. session := loginUser(t, privateActivityTestOtherUser)
  286. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  287. assert.False(t, hasContent, "other user should not see heatmap content")
  288. }
  289. func TestPrivateActivityYesHeatmapHasNoContentForAdmin(t *testing.T) {
  290. defer tests.PrepareTestEnv(t)()
  291. testPrivateActivityDoSomethingForActionEntries(t)
  292. testPrivateActivityHelperEnablePrivateActivity(t)
  293. session := loginUser(t, privateActivityTestAdmin)
  294. hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
  295. assert.True(t, hasContent, "heatmap should show content for admin")
  296. }