12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- // Copyright 2018 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 models
-
- package models
-
- import (
- "fmt"
- "testing"
-
- jsoniter "github.com/json-iterator/go"
- "github.com/stretchr/testify/assert"
- )
-
- func TestGetUserHeatmapDataByUser(t *testing.T) {
- testCases := []struct {
- userID int64
- doerID int64
- CountResult int
- JSONResult string
- }{
- // self looks at action in private repo
- {2, 2, 1, `[{"timestamp":1603227600,"contributions":1}]`},
- // admin looks at action in private repo
- {2, 1, 1, `[{"timestamp":1603227600,"contributions":1}]`},
- // other user looks at action in private repo
- {2, 3, 0, `[]`},
- // nobody looks at action in private repo
- {2, 0, 0, `[]`},
- // collaborator looks at action in private repo
- {16, 15, 1, `[{"timestamp":1603267200,"contributions":1}]`},
- // no action action not performed by target user
- {3, 3, 0, `[]`},
- // multiple actions performed with two grouped together
- {10, 10, 3, `[{"timestamp":1603009800,"contributions":1},{"timestamp":1603010700,"contributions":2}]`},
- }
- // Prepare
- assert.NoError(t, PrepareTestDatabase())
-
- for i, tc := range testCases {
- user := AssertExistsAndLoadBean(t, &User{ID: tc.userID}).(*User)
-
- doer := &User{ID: tc.doerID}
- _, err := loadBeanIfExists(doer)
- assert.NoError(t, err)
- if tc.doerID == 0 {
- doer = nil
- }
-
- // get the action for comparison
- actions, err := GetFeeds(GetFeedsOptions{
- RequestedUser: user,
- Actor: doer,
- IncludePrivate: true,
- OnlyPerformedBy: true,
- IncludeDeleted: true,
- })
- assert.NoError(t, err)
-
- // Get the heatmap and compare
- heatmap, err := GetUserHeatmapDataByUser(user, doer)
- var contributions int
- for _, hm := range heatmap {
- contributions += int(hm.Contributions)
- }
- assert.NoError(t, err)
- assert.Len(t, actions, contributions, "invalid action count: did the test data became too old?")
- assert.Equal(t, tc.CountResult, contributions, fmt.Sprintf("testcase %d", i))
-
- // Test JSON rendering
- json := jsoniter.ConfigCompatibleWithStandardLibrary
- jsonData, err := json.Marshal(heatmap)
- assert.NoError(t, err)
- assert.Equal(t, tc.JSONResult, string(jsonData))
- }
- }
|