sharded-gotify/test/database_test.go

143 lines
3.8 KiB
Go

package test_test
import (
"testing"
"github.com/gotify/server/mode"
"github.com/gotify/server/model"
"github.com/gotify/server/test"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/suite"
)
func Test_WithDefault(t *testing.T) {
db := test.NewDBWithDefaultUser(t)
assert.NotNil(t, db.GetUserByName("admin"))
db.Close()
}
func TestDatabaseSuite(t *testing.T) {
suite.Run(t, new(DatabaseSuite))
}
type DatabaseSuite struct {
suite.Suite
db *test.Database
}
func (s *DatabaseSuite) BeforeTest(suiteName, testName string) {
mode.Set(mode.TestDev)
s.db = test.NewDB(s.T())
}
func (s *DatabaseSuite) AfterTest(suiteName, testName string) {
s.db.Close()
}
func (s *DatabaseSuite) Test_Users() {
s.db.User(1)
newUserActual := s.db.NewUser(2)
s.db.NewUserWithName(3, "tom")
newUserExpected := &model.User{ID: 2, Name: "user2"}
assert.Equal(s.T(), newUserExpected, newUserActual)
users := []*model.User{{ID: 1, Name: "user1"}, {ID: 2, Name: "user2"}, {ID: 3, Name: "tom"}}
assert.Equal(s.T(), users, s.db.GetUsers())
s.db.AssertUserExist(1)
s.db.AssertUserExist(2)
s.db.AssertUserExist(3)
s.db.AssertUserNotExist(4)
s.db.DeleteUserByID(2)
s.db.AssertUserNotExist(2)
}
func (s *DatabaseSuite) Test_Clients() {
userBuilder := s.db.User(1)
userBuilder.Client(1)
newClientActual := userBuilder.NewClientWithToken(2, "asdf")
s.db.User(2).Client(5)
newClientExpected := &model.Client{ID: 2, Token: "asdf", UserID: 1}
assert.Equal(s.T(), newClientExpected, newClientActual)
userOneExpected := []*model.Client{{ID: 1, Token: "client1", UserID: 1}, {ID: 2, Token: "asdf", UserID: 1}}
assert.Equal(s.T(), userOneExpected, s.db.GetClientsByUser(1))
userTwoExpected := []*model.Client{{ID: 5, Token: "client5", UserID: 2}}
assert.Equal(s.T(), userTwoExpected, s.db.GetClientsByUser(2))
s.db.AssertClientExist(1)
s.db.AssertClientExist(2)
s.db.AssertClientNotExist(3)
s.db.AssertClientNotExist(4)
s.db.AssertClientExist(5)
s.db.AssertClientNotExist(6)
s.db.DeleteClientByID(2)
s.db.AssertClientNotExist(2)
}
func (s *DatabaseSuite) Test_Apps() {
userBuilder := s.db.User(1)
userBuilder.App(1)
newAppActual := userBuilder.NewAppWithToken(2, "asdf")
s.db.User(2).App(5)
newAppExpected := &model.Application{ID: 2, Token: "asdf", UserID: 1}
assert.Equal(s.T(), newAppExpected, newAppActual)
userOneExpected := []*model.Application{{ID: 1, Token: "app1", UserID: 1}, {ID: 2, Token: "asdf", UserID: 1}}
assert.Equal(s.T(), userOneExpected, s.db.GetApplicationsByUser(1))
userTwoExpected := []*model.Application{{ID: 5, Token: "app5", UserID: 2}}
assert.Equal(s.T(), userTwoExpected, s.db.GetApplicationsByUser(2))
newAppWithName := userBuilder.NewAppWithTokenAndName(7, "test-token", "app name")
newAppWithNameExpected := &model.Application{ID: 7, Token: "test-token", UserID: 1, Name: "app name"}
assert.Equal(s.T(), newAppWithNameExpected, newAppWithName)
userBuilder.AppWithTokenAndName(8, "test-token-2", "app name")
s.db.AssertAppExist(1)
s.db.AssertAppExist(2)
s.db.AssertAppNotExist(3)
s.db.AssertAppNotExist(4)
s.db.AssertAppExist(5)
s.db.AssertAppNotExist(6)
s.db.AssertAppExist(7)
s.db.AssertAppExist(8)
s.db.DeleteApplicationByID(2)
s.db.AssertAppNotExist(2)
}
func (s *DatabaseSuite) Test_Messages() {
s.db.User(1).App(1).Message(1).Message(2)
s.db.User(2).App(2).Message(4).Message(5)
userOneExpected := []*model.Message{{ID: 2, ApplicationID: 1}, {ID: 1, ApplicationID: 1}}
assert.Equal(s.T(), userOneExpected, s.db.GetMessagesByUser(1))
userTwoExpected := []*model.Message{{ID: 5, ApplicationID: 2}, {ID: 4, ApplicationID: 2}}
assert.Equal(s.T(), userTwoExpected, s.db.GetMessagesByUser(2))
s.db.AssertMessageExist(1)
s.db.AssertMessageExist(2)
s.db.AssertMessageExist(4)
s.db.AssertMessageExist(5)
s.db.AssertMessageNotExist(3, 6, 7, 8)
s.db.DeleteMessageByID(2)
s.db.AssertMessageNotExist(2)
}