699d3d6060
Increase golangci timeout Fix installing golangci-lint in ci Remove mage targets replaced by golangci Run golint in ci Add goheader linter Enable & fix more linters Fix lint issues Add mage target to automagically fix issues found by golangci golangci-lint run --fix Add golangci config Add golangci mage target Co-authored-by: kolaente <k@knt.li> Reviewed-on: https://kolaente.dev/vikunja/api/pulls/676 Co-Authored-By: konrad <konrad@kola-entertainments.de> Co-Committed-By: konrad <konrad@kola-entertainments.de>
210 lines
6.3 KiB
Go
210 lines
6.3 KiB
Go
// Vikunja is a to-do list application to facilitate your life.
|
|
// Copyright 2018-2020 Vikunja and contributors. All rights reserved.
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package models
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.vikunja.io/api/pkg/db"
|
|
"code.vikunja.io/api/pkg/user"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestNamespace_Create(t *testing.T) {
|
|
|
|
// Dummy namespace
|
|
dummynamespace := Namespace{
|
|
Title: "Test",
|
|
Description: "Lorem Ipsum",
|
|
}
|
|
|
|
user1 := &user.User{ID: 1}
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
err := dummynamespace.Create(user1)
|
|
assert.NoError(t, err)
|
|
db.AssertExists(t, "namespaces", map[string]interface{}{
|
|
"title": "Test",
|
|
"description": "Lorem Ipsum",
|
|
}, false)
|
|
})
|
|
t.Run("no title", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n2 := Namespace{}
|
|
err := n2.Create(user1)
|
|
assert.Error(t, err)
|
|
assert.True(t, IsErrNamespaceNameCannotBeEmpty(err))
|
|
})
|
|
t.Run("nonexistant user", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
nUser := &user.User{ID: 9482385}
|
|
dnsp2 := dummynamespace
|
|
err := dnsp2.Create(nUser)
|
|
assert.Error(t, err)
|
|
assert.True(t, user.IsErrUserDoesNotExist(err))
|
|
})
|
|
}
|
|
|
|
func TestNamespace_ReadOne(t *testing.T) {
|
|
t.Run("normal", func(t *testing.T) {
|
|
n := &Namespace{ID: 1}
|
|
db.LoadAndAssertFixtures(t)
|
|
err := n.ReadOne()
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, n.Title, "testnamespace")
|
|
})
|
|
t.Run("nonexistant", func(t *testing.T) {
|
|
n := &Namespace{ID: 99999}
|
|
db.LoadAndAssertFixtures(t)
|
|
err := n.ReadOne()
|
|
assert.Error(t, err)
|
|
assert.True(t, IsErrNamespaceDoesNotExist(err))
|
|
})
|
|
}
|
|
|
|
func TestNamespace_Update(t *testing.T) {
|
|
t.Run("normal", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 1,
|
|
Title: "Lorem Ipsum",
|
|
}
|
|
err := n.Update()
|
|
assert.NoError(t, err)
|
|
db.AssertExists(t, "namespaces", map[string]interface{}{
|
|
"id": 1,
|
|
"title": "Lorem Ipsum",
|
|
}, false)
|
|
})
|
|
t.Run("nonexisting", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 99999,
|
|
Title: "Lorem Ipsum",
|
|
}
|
|
err := n.Update()
|
|
assert.Error(t, err)
|
|
assert.True(t, IsErrNamespaceDoesNotExist(err))
|
|
})
|
|
t.Run("nonexisting owner", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 1,
|
|
Title: "Lorem Ipsum",
|
|
Owner: &user.User{ID: 99999},
|
|
}
|
|
err := n.Update()
|
|
assert.Error(t, err)
|
|
assert.True(t, user.IsErrUserDoesNotExist(err))
|
|
})
|
|
t.Run("no title", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 1,
|
|
}
|
|
err := n.Update()
|
|
assert.Error(t, err)
|
|
assert.True(t, IsErrNamespaceNameCannotBeEmpty(err))
|
|
})
|
|
}
|
|
|
|
func TestNamespace_Delete(t *testing.T) {
|
|
t.Run("normal", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 1,
|
|
}
|
|
err := n.Delete()
|
|
assert.NoError(t, err)
|
|
db.AssertMissing(t, "namespaces", map[string]interface{}{
|
|
"id": 1,
|
|
})
|
|
})
|
|
t.Run("nonexisting", func(t *testing.T) {
|
|
db.LoadAndAssertFixtures(t)
|
|
n := &Namespace{
|
|
ID: 9999,
|
|
}
|
|
err := n.Delete()
|
|
assert.Error(t, err)
|
|
assert.True(t, IsErrNamespaceDoesNotExist(err))
|
|
})
|
|
}
|
|
|
|
func TestNamespace_ReadAll(t *testing.T) {
|
|
user1 := &user.User{ID: 1}
|
|
user11 := &user.User{ID: 11}
|
|
user12 := &user.User{ID: 12}
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
n := &Namespace{}
|
|
nn, _, _, err := n.ReadAll(user1, "", 1, -1)
|
|
assert.NoError(t, err)
|
|
namespaces := nn.([]*NamespaceWithLists)
|
|
assert.NotNil(t, namespaces)
|
|
assert.Len(t, namespaces, 11) // Total of 10 including shared, favorites and saved filters
|
|
assert.Equal(t, int64(-3), namespaces[0].ID) // The first one should be the one with shared filters
|
|
assert.Equal(t, int64(-2), namespaces[1].ID) // The second one should be the one with favorites
|
|
assert.Equal(t, int64(-1), namespaces[2].ID) // The third one should be the one with the shared namespaces
|
|
// Ensure every list and namespace are not archived
|
|
for _, namespace := range namespaces {
|
|
assert.False(t, namespace.IsArchived)
|
|
for _, list := range namespace.Lists {
|
|
assert.False(t, list.IsArchived)
|
|
}
|
|
}
|
|
})
|
|
t.Run("archived", func(t *testing.T) {
|
|
n := &Namespace{
|
|
IsArchived: true,
|
|
}
|
|
nn, _, _, err := n.ReadAll(user1, "", 1, -1)
|
|
namespaces := nn.([]*NamespaceWithLists)
|
|
assert.NoError(t, err)
|
|
assert.NotNil(t, namespaces)
|
|
assert.Len(t, namespaces, 12) // Total of 12 including shared & favorites, one is archived
|
|
assert.Equal(t, int64(-3), namespaces[0].ID) // The first one should be the one with shared filters
|
|
assert.Equal(t, int64(-2), namespaces[1].ID) // The second one should be the one with favorites
|
|
assert.Equal(t, int64(-1), namespaces[2].ID) // The third one should be the one with the shared namespaces
|
|
})
|
|
t.Run("no favorites", func(t *testing.T) {
|
|
n := &Namespace{}
|
|
nn, _, _, err := n.ReadAll(user11, "", 1, -1)
|
|
namespaces := nn.([]*NamespaceWithLists)
|
|
assert.NoError(t, err)
|
|
// Assert the first namespace is not the favorites namespace
|
|
assert.NotEqual(t, FavoritesPseudoNamespace.ID, namespaces[0].ID)
|
|
})
|
|
t.Run("no favorite tasks but namespace", func(t *testing.T) {
|
|
n := &Namespace{}
|
|
nn, _, _, err := n.ReadAll(user12, "", 1, -1)
|
|
namespaces := nn.([]*NamespaceWithLists)
|
|
assert.NoError(t, err)
|
|
// Assert the first namespace is the favorites namespace and contains lists
|
|
assert.Equal(t, FavoritesPseudoNamespace.ID, namespaces[0].ID)
|
|
assert.NotEqual(t, 0, namespaces[0].Lists)
|
|
})
|
|
t.Run("no saved filters", func(t *testing.T) {
|
|
n := &Namespace{}
|
|
nn, _, _, err := n.ReadAll(user11, "", 1, -1)
|
|
namespaces := nn.([]*NamespaceWithLists)
|
|
assert.NoError(t, err)
|
|
// Assert the first namespace is not the favorites namespace
|
|
assert.NotEqual(t, SavedFiltersPseudoNamespace.ID, namespaces[0].ID)
|
|
})
|
|
}
|