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 c1de540147
.
* 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)
|
|
}
|