123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413 |
- // Copyright 2020 The Gitea Authors. All rights reserved.
- // Use of this source code is governed by a MIT-style
- // license that can be found in the LICENSE file.
-
- package integrations
-
- import (
- "fmt"
- "net/http"
- "testing"
-
- "code.gitea.io/gitea/models"
- "code.gitea.io/gitea/models/unittest"
- user_model "code.gitea.io/gitea/models/user"
- api "code.gitea.io/gitea/modules/structs"
-
- "github.com/stretchr/testify/assert"
- )
-
- const privateActivityTestAdmin = "user1"
- const privateActivityTestUser = "user2"
-
- // user3 is an organization so it is not usable here
- const privateActivityTestOtherUser = "user4"
-
- // activity helpers
-
- func testPrivateActivityDoSomethingForActionEntries(t *testing.T) {
- repoBefore := unittest.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
- owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repoBefore.OwnerID}).(*user_model.User)
-
- session := loginUser(t, privateActivityTestUser)
- token := getTokenForLoggedInUser(t, session)
- urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues?state=all&token=%s", owner.Name, repoBefore.Name, token)
- req := NewRequestWithJSON(t, "POST", urlStr, &api.CreateIssueOption{
- Body: "test",
- Title: "test",
- })
- session.MakeRequest(t, req, http.StatusCreated)
- }
-
- // private activity helpers
-
- func testPrivateActivityHelperEnablePrivateActivity(t *testing.T) {
- session := loginUser(t, privateActivityTestUser)
- req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{
- "_csrf": GetCSRF(t, session, "/user/settings"),
- "name": privateActivityTestUser,
- "email": privateActivityTestUser + "@example.com",
- "language": "en-US",
- "keep_activity_private": "1",
- })
- session.MakeRequest(t, req, http.StatusFound)
- }
-
- func testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc *HTMLDoc) bool {
- return htmlDoc.doc.Find(".feeds").Find(".news").Length() > 0
- }
-
- func testPrivateActivityHelperHasVisibleActivitiesFromSession(t *testing.T, session *TestSession) bool {
- req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- htmlDoc := NewHTMLParser(t, resp.Body)
-
- return testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc)
- }
-
- func testPrivateActivityHelperHasVisibleActivitiesFromPublic(t *testing.T) bool {
- req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
- resp := MakeRequest(t, req, http.StatusOK)
-
- htmlDoc := NewHTMLParser(t, resp.Body)
-
- return testPrivateActivityHelperHasVisibleActivitiesInHTMLDoc(htmlDoc)
- }
-
- // heatmap UI helpers
-
- func testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc *HTMLDoc) bool {
- return htmlDoc.doc.Find("#user-heatmap").Length() > 0
- }
-
- func testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t *testing.T, session *TestSession) bool {
- req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- htmlDoc := NewHTMLParser(t, resp.Body)
-
- return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
- }
-
- func testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t *testing.T, session *TestSession) bool {
- req := NewRequest(t, "GET", "/")
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- htmlDoc := NewHTMLParser(t, resp.Body)
-
- return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
- }
-
- func testPrivateActivityHelperHasVisibleHeatmapFromPublic(t *testing.T) bool {
- req := NewRequestf(t, "GET", "/%s?tab=activity", privateActivityTestUser)
- resp := MakeRequest(t, req, http.StatusOK)
-
- htmlDoc := NewHTMLParser(t, resp.Body)
-
- return testPrivateActivityHelperHasVisibleHeatmapInHTMLDoc(htmlDoc)
- }
-
- // heatmap API helpers
-
- func testPrivateActivityHelperHasHeatmapContentFromPublic(t *testing.T) bool {
- req := NewRequestf(t, "GET", "/api/v1/users/%s/heatmap", privateActivityTestUser)
- resp := MakeRequest(t, req, http.StatusOK)
-
- var items []*models.UserHeatmapData
- DecodeJSON(t, resp, &items)
-
- return len(items) != 0
- }
-
- func testPrivateActivityHelperHasHeatmapContentFromSession(t *testing.T, session *TestSession) bool {
- token := getTokenForLoggedInUser(t, session)
-
- req := NewRequestf(t, "GET", "/api/v1/users/%s/heatmap?token=%s", privateActivityTestUser, token)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- var items []*models.UserHeatmapData
- DecodeJSON(t, resp, &items)
-
- return len(items) != 0
- }
-
- // check activity visibility if the visibility is enabled
-
- func TestPrivateActivityNoVisibleForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- func TestPrivateActivityNoVisibleForUserItself(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- func TestPrivateActivityNoVisibleForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- func TestPrivateActivityNoVisibleForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- // check activity visibility if the visibility is disabled
-
- func TestPrivateActivityYesInvisibleForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- visible := testPrivateActivityHelperHasVisibleActivitiesFromPublic(t)
-
- assert.False(t, visible, "user should have no visible activities")
- }
-
- func TestPrivateActivityYesVisibleForUserItself(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- func TestPrivateActivityYesInvisibleForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.False(t, visible, "user should have no visible activities")
- }
-
- func TestPrivateActivityYesVisibleForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- visible := testPrivateActivityHelperHasVisibleActivitiesFromSession(t, session)
-
- assert.True(t, visible, "user should have visible activities")
- }
-
- // check heatmap visibility if the visibility is enabled
-
- func TestPrivateActivityNoHeatmapVisibleForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityNoHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityNoHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityNoHeatmapVisibleForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityNoHeatmapVisibleForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- // check heatmap visibility if the visibility is disabled
-
- func TestPrivateActivityYesHeatmapInvisibleForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- visible := testPrivateActivityHelperHasVisibleHeatmapFromPublic(t)
-
- assert.False(t, visible, "user should have no visible heatmap")
- }
-
- func TestPrivateActivityYesHeatmapVisibleForUserItselfAtProfile(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityYesHeatmapVisibleForUserItselfAtDashboard(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestUser)
- visible := testPrivateActivityHelperHasVisibleDashboardHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- func TestPrivateActivityYesHeatmapInvisibleForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.False(t, visible, "user should have no visible heatmap")
- }
-
- func TestPrivateActivityYesHeatmapVisibleForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- visible := testPrivateActivityHelperHasVisibleProfileHeatmapFromSession(t, session)
-
- assert.True(t, visible, "user should have visible heatmap")
- }
-
- // check heatmap api provides content if the visibility is enabled
-
- func TestPrivateActivityNoHeatmapHasContentForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
-
- assert.True(t, hasContent, "user should have heatmap content")
- }
-
- func TestPrivateActivityNoHeatmapHasContentForUserItself(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestUser)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.True(t, hasContent, "user should have heatmap content")
- }
-
- func TestPrivateActivityNoHeatmapHasContentForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.True(t, hasContent, "user should have heatmap content")
- }
-
- func TestPrivateActivityNoHeatmapHasContentForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.True(t, hasContent, "user should have heatmap content")
- }
-
- // check heatmap api provides no content if the visibility is disabled
- // this should be equal to the hidden heatmap at the UI
-
- func TestPrivateActivityYesHeatmapHasNoContentForPublic(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- hasContent := testPrivateActivityHelperHasHeatmapContentFromPublic(t)
-
- assert.False(t, hasContent, "user should have no heatmap content")
- }
-
- func TestPrivateActivityYesHeatmapHasNoContentForUserItself(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestUser)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.True(t, hasContent, "user should see their own heatmap content")
- }
-
- func TestPrivateActivityYesHeatmapHasNoContentForOtherUser(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestOtherUser)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.False(t, hasContent, "other user should not see heatmap content")
- }
-
- func TestPrivateActivityYesHeatmapHasNoContentForAdmin(t *testing.T) {
- defer prepareTestEnv(t)()
- testPrivateActivityDoSomethingForActionEntries(t)
- testPrivateActivityHelperEnablePrivateActivity(t)
-
- session := loginUser(t, privateActivityTestAdmin)
- hasContent := testPrivateActivityHelperHasHeatmapContentFromSession(t, session)
-
- assert.True(t, hasContent, "heatmap should show content for admin")
- }
|