123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- // Copyright 2017 The Gitea Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package repo_test
-
- import (
- "testing"
-
- "code.gitea.io/gitea/models/db"
- repo_model "code.gitea.io/gitea/models/repo"
- "code.gitea.io/gitea/models/unittest"
- "code.gitea.io/gitea/modules/setting"
-
- "github.com/stretchr/testify/assert"
- )
-
- func TestIsWatching(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- assert.True(t, repo_model.IsWatching(db.DefaultContext, 1, 1))
- assert.True(t, repo_model.IsWatching(db.DefaultContext, 4, 1))
- assert.True(t, repo_model.IsWatching(db.DefaultContext, 11, 1))
-
- assert.False(t, repo_model.IsWatching(db.DefaultContext, 1, 5))
- assert.False(t, repo_model.IsWatching(db.DefaultContext, 8, 1))
- assert.False(t, repo_model.IsWatching(db.DefaultContext, unittest.NonexistentID, unittest.NonexistentID))
- }
-
- func TestGetWatchers(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
- watches, err := repo_model.GetWatchers(db.DefaultContext, repo.ID)
- assert.NoError(t, err)
- // One watchers are inactive, thus minus 1
- assert.Len(t, watches, repo.NumWatches-1)
- for _, watch := range watches {
- assert.EqualValues(t, repo.ID, watch.RepoID)
- }
-
- watches, err = repo_model.GetWatchers(db.DefaultContext, unittest.NonexistentID)
- assert.NoError(t, err)
- assert.Len(t, watches, 0)
- }
-
- func TestRepository_GetWatchers(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
- watchers, err := repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, repo.NumWatches)
- for _, watcher := range watchers {
- unittest.AssertExistsAndLoadBean(t, &repo_model.Watch{UserID: watcher.ID, RepoID: repo.ID})
- }
-
- repo = unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 9})
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, 0)
- }
-
- func TestWatchIfAuto(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
- watchers, err := repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, repo.NumWatches)
-
- setting.Service.AutoWatchOnChanges = false
-
- prevCount := repo.NumWatches
-
- // Must not add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 8, 1, true))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
-
- // Should not add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 10, 1, true))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
-
- setting.Service.AutoWatchOnChanges = true
-
- // Must not add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 8, 1, true))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
-
- // Should not add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 12, 1, false))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
-
- // Should add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 12, 1, true))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount+1)
-
- // Should remove watch, inhibit from adding auto
- assert.NoError(t, repo_model.WatchRepo(db.DefaultContext, 12, 1, false))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
-
- // Must not add watch
- assert.NoError(t, repo_model.WatchIfAuto(db.DefaultContext, 12, 1, true))
- watchers, err = repo_model.GetRepoWatchers(db.DefaultContext, repo.ID, db.ListOptions{Page: 1})
- assert.NoError(t, err)
- assert.Len(t, watchers, prevCount)
- }
-
- func TestWatchRepoMode(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1}, 0)
-
- assert.NoError(t, repo_model.WatchRepoMode(12, 1, repo_model.WatchModeAuto))
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1}, 1)
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1, Mode: repo_model.WatchModeAuto}, 1)
-
- assert.NoError(t, repo_model.WatchRepoMode(12, 1, repo_model.WatchModeNormal))
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1}, 1)
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1, Mode: repo_model.WatchModeNormal}, 1)
-
- assert.NoError(t, repo_model.WatchRepoMode(12, 1, repo_model.WatchModeDont))
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1}, 1)
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1, Mode: repo_model.WatchModeDont}, 1)
-
- assert.NoError(t, repo_model.WatchRepoMode(12, 1, repo_model.WatchModeNone))
- unittest.AssertCount(t, &repo_model.Watch{UserID: 12, RepoID: 1}, 0)
- }
|