2ab8c78c30
* FIX: getIssueWatchers() get only aktive suscriber * save query to work later with it or not ... * fix test + add new case * corect tests + GetIssueWatch * API issue_subscripton: Put/Delete require tocken * remove redundant code * swagger specify return value * remove unused binding * remove note because I'll implement this in a different way and in another PR * ID should be unique! * use xorm session * Revert "use xorm session" This reverts commit c1de540147199f2f1a8dd0d008f54af3603e2229. * better test code * more acurate comments * use assert.False/True instead of Equal * use more assert methodes
63 lines
1.5 KiB
Go
63 lines
1.5 KiB
Go
// Copyright 2017 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
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCreateOrUpdateIssueWatch(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
|
|
assert.NoError(t, CreateOrUpdateIssueWatch(3, 1, true))
|
|
iw := AssertExistsAndLoadBean(t, &IssueWatch{UserID: 3, IssueID: 1}).(*IssueWatch)
|
|
assert.True(t, iw.IsWatching)
|
|
|
|
assert.NoError(t, CreateOrUpdateIssueWatch(1, 1, false))
|
|
iw = AssertExistsAndLoadBean(t, &IssueWatch{UserID: 1, IssueID: 1}).(*IssueWatch)
|
|
assert.False(t, iw.IsWatching)
|
|
}
|
|
|
|
func TestGetIssueWatch(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
|
|
_, exists, err := GetIssueWatch(9, 1)
|
|
assert.True(t, exists)
|
|
assert.NoError(t, err)
|
|
|
|
_, exists, err = GetIssueWatch(2, 2)
|
|
assert.False(t, exists)
|
|
assert.NoError(t, err)
|
|
|
|
_, exists, err = GetIssueWatch(3, 1)
|
|
assert.False(t, exists)
|
|
assert.NoError(t, err)
|
|
}
|
|
|
|
func TestGetIssueWatchers(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
|
|
iws, err := GetIssueWatchers(1)
|
|
assert.NoError(t, err)
|
|
// Watcher is inactive, thus 0
|
|
assert.Len(t, iws, 0)
|
|
|
|
iws, err = GetIssueWatchers(2)
|
|
assert.NoError(t, err)
|
|
// Watcher is explicit not watching
|
|
assert.Len(t, iws, 0)
|
|
|
|
iws, err = GetIssueWatchers(5)
|
|
assert.NoError(t, err)
|
|
// Issue has no Watchers
|
|
assert.Len(t, iws, 0)
|
|
|
|
iws, err = GetIssueWatchers(7)
|
|
assert.NoError(t, err)
|
|
// Issue has one watcher
|
|
assert.Len(t, iws, 1)
|
|
}
|