2020-02-07 17:27:45 +01:00
|
|
|
// Vikunja is a to-do list application to facilitate your life.
|
2020-01-09 18:33:22 +01:00
|
|
|
// Copyright 2018-2020 Vikunja and contributors. All rights reserved.
|
2018-11-26 21:17:33 +01:00
|
|
|
//
|
2019-12-04 20:39:56 +01:00
|
|
|
// 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.
|
2018-11-26 21:17:33 +01:00
|
|
|
//
|
2019-12-04 20:39:56 +01:00
|
|
|
// 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.
|
2018-11-26 21:17:33 +01:00
|
|
|
//
|
2019-12-04 20:39:56 +01:00
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2018-11-26 21:17:33 +01:00
|
|
|
|
2018-07-27 16:28:09 +02:00
|
|
|
package models
|
|
|
|
|
|
|
|
import (
|
2020-02-16 22:42:04 +01:00
|
|
|
"code.vikunja.io/api/pkg/db"
|
2020-01-26 18:08:06 +01:00
|
|
|
"code.vikunja.io/api/pkg/user"
|
2018-07-27 16:28:09 +02:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"reflect"
|
2018-07-27 16:28:28 +02:00
|
|
|
"testing"
|
2018-07-27 16:28:09 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestTeam_Create(t *testing.T) {
|
2020-02-16 22:42:04 +01:00
|
|
|
doer := &user.User{
|
|
|
|
ID: 1,
|
|
|
|
Username: "user1",
|
2018-07-27 16:28:09 +02:00
|
|
|
}
|
2020-02-16 22:42:04 +01:00
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{
|
|
|
|
Name: "Testteam293",
|
|
|
|
Description: "Lorem Ispum",
|
|
|
|
}
|
|
|
|
err := team.Create(doer)
|
|
|
|
assert.NoError(t, err)
|
2020-09-27 17:45:17 +02:00
|
|
|
db.AssertExists(t, "teams", map[string]interface{}{
|
|
|
|
"id": team.ID,
|
|
|
|
"name": "Testteam293",
|
|
|
|
"description": "Lorem Ispum",
|
|
|
|
}, false)
|
2020-02-16 22:42:04 +01:00
|
|
|
})
|
|
|
|
t.Run("empty name", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{}
|
|
|
|
err := team.Create(doer)
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrTeamNameCannotBeEmpty(err))
|
|
|
|
})
|
|
|
|
}
|
2018-07-27 16:28:09 +02:00
|
|
|
|
2020-02-16 22:42:04 +01:00
|
|
|
func TestTeam_ReadOne(t *testing.T) {
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{ID: 1}
|
|
|
|
err := team.ReadOne()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, "testteam1", team.Name)
|
|
|
|
assert.Equal(t, "Lorem Ipsum", team.Description)
|
|
|
|
assert.Equal(t, int64(1), team.CreatedBy.ID)
|
|
|
|
assert.Equal(t, int64(1), team.CreatedByID)
|
|
|
|
})
|
|
|
|
t.Run("invalid id", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{ID: -1}
|
|
|
|
err := team.ReadOne()
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrTeamDoesNotExist(err))
|
|
|
|
})
|
|
|
|
t.Run("nonexisting", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{ID: 99999}
|
|
|
|
err := team.ReadOne()
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrTeamDoesNotExist(err))
|
|
|
|
})
|
|
|
|
}
|
2018-07-27 16:28:09 +02:00
|
|
|
|
2020-02-16 22:42:04 +01:00
|
|
|
func TestTeam_ReadAll(t *testing.T) {
|
|
|
|
doer := &user.User{ID: 1}
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
team := &Team{}
|
|
|
|
ts, _, _, err := team.ReadAll(doer, "", 1, 50)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, reflect.TypeOf(ts).Kind(), reflect.Slice)
|
|
|
|
s := reflect.ValueOf(ts)
|
|
|
|
assert.Equal(t, 8, s.Len())
|
|
|
|
})
|
|
|
|
}
|
2018-07-27 16:28:09 +02:00
|
|
|
|
2020-02-16 22:42:04 +01:00
|
|
|
func TestTeam_Update(t *testing.T) {
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{
|
|
|
|
ID: 1,
|
|
|
|
Name: "SomethingNew",
|
|
|
|
}
|
|
|
|
err := team.Update()
|
|
|
|
assert.NoError(t, err)
|
2020-09-27 17:45:17 +02:00
|
|
|
db.AssertExists(t, "teams", map[string]interface{}{
|
|
|
|
"id": team.ID,
|
|
|
|
"name": "SomethingNew",
|
|
|
|
}, false)
|
2020-02-16 22:42:04 +01:00
|
|
|
})
|
|
|
|
t.Run("empty name", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{
|
|
|
|
ID: 1,
|
|
|
|
Name: "",
|
|
|
|
}
|
|
|
|
err := team.Update()
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrTeamNameCannotBeEmpty(err))
|
|
|
|
})
|
|
|
|
t.Run("nonexisting", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{
|
|
|
|
ID: 9999,
|
|
|
|
Name: "SomethingNew",
|
|
|
|
}
|
|
|
|
err := team.Update()
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrTeamDoesNotExist(err))
|
|
|
|
})
|
|
|
|
}
|
2018-07-27 16:28:09 +02:00
|
|
|
|
2020-02-16 22:42:04 +01:00
|
|
|
func TestTeam_Delete(t *testing.T) {
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
db.LoadAndAssertFixtures(t)
|
|
|
|
team := &Team{
|
|
|
|
ID: 1,
|
|
|
|
}
|
|
|
|
err := team.Delete()
|
|
|
|
assert.NoError(t, err)
|
2020-09-27 17:45:17 +02:00
|
|
|
db.AssertMissing(t, "teams", map[string]interface{}{
|
|
|
|
"id": 1,
|
|
|
|
})
|
2020-02-16 22:42:04 +01:00
|
|
|
})
|
2018-07-27 16:28:09 +02:00
|
|
|
}
|
|
|
|
|
2019-01-21 23:08:04 +01:00
|
|
|
func TestIsErrInvalidRight(t *testing.T) {
|
|
|
|
assert.NoError(t, RightAdmin.isValid())
|
|
|
|
assert.NoError(t, RightRead.isValid())
|
|
|
|
assert.NoError(t, RightWrite.isValid())
|
2018-07-27 16:28:09 +02:00
|
|
|
|
|
|
|
// Check invalid
|
2019-02-18 20:32:41 +01:00
|
|
|
var tr Right = 938
|
2018-07-27 16:28:09 +02:00
|
|
|
err := tr.isValid()
|
|
|
|
assert.Error(t, err)
|
2019-01-21 23:08:04 +01:00
|
|
|
assert.True(t, IsErrInvalidRight(err))
|
2018-07-27 16:28:09 +02:00
|
|
|
}
|