sharded-gotify/database/message_test.go

205 lines
7.1 KiB
Go

package database
import (
"testing"
"time"
"github.com/gotify/server/model"
"github.com/stretchr/testify/assert"
)
func (s *DatabaseSuite) TestMessage() {
assert.Nil(s.T(), s.db.GetMessageByID(5), "not existing message")
user := &model.User{Name: "test", Pass: []byte{1}}
s.db.CreateUser(user)
assert.NotEqual(s.T(), 0, user.ID)
backupServer := &model.Application{UserID: user.ID, Token: "A0000000000", Name: "backupserver"}
s.db.CreateApplication(backupServer)
assert.NotEqual(s.T(), 0, backupServer.ID)
msgs := s.db.GetMessagesByUser(user.ID)
assert.Empty(s.T(), msgs)
msgs = s.db.GetMessagesByApplication(backupServer.ID)
assert.Empty(s.T(), msgs)
backupdone := &model.Message{ApplicationID: backupServer.ID, Message: "backup done", Title: "backup", Priority: 1, Date: time.Now()}
s.db.CreateMessage(backupdone)
assert.NotEqual(s.T(), 0, backupdone.ID)
assertEquals(s.T(), s.db.GetMessageByID(backupdone.ID), backupdone)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 1)
assertEquals(s.T(), msgs[0], backupdone)
msgs = s.db.GetMessagesByApplication(backupServer.ID)
assert.Len(s.T(), msgs, 1)
assertEquals(s.T(), msgs[0], backupdone)
loginServer := &model.Application{UserID: user.ID, Token: "A0000000001", Name: "loginserver"}
s.db.CreateApplication(loginServer)
assert.NotEqual(s.T(), 0, loginServer.ID)
logindone := &model.Message{ApplicationID: loginServer.ID, Message: "login done", Title: "login", Priority: 1, Date: time.Now()}
s.db.CreateMessage(logindone)
assert.NotEqual(s.T(), 0, logindone.ID)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 2)
assertEquals(s.T(), msgs[0], logindone)
assertEquals(s.T(), msgs[1], backupdone)
msgs = s.db.GetMessagesByApplication(backupServer.ID)
assert.Len(s.T(), msgs, 1)
assertEquals(s.T(), msgs[0], backupdone)
loginfailed := &model.Message{ApplicationID: loginServer.ID, Message: "login failed", Title: "login", Priority: 1, Date: time.Now()}
s.db.CreateMessage(loginfailed)
assert.NotEqual(s.T(), 0, loginfailed.ID)
msgs = s.db.GetMessagesByApplication(backupServer.ID)
assert.Len(s.T(), msgs, 1)
assertEquals(s.T(), msgs[0], backupdone)
msgs = s.db.GetMessagesByApplication(loginServer.ID)
assert.Len(s.T(), msgs, 2)
assertEquals(s.T(), msgs[0], loginfailed)
assertEquals(s.T(), msgs[1], logindone)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 3)
assertEquals(s.T(), msgs[0], loginfailed)
assertEquals(s.T(), msgs[1], logindone)
assertEquals(s.T(), msgs[2], backupdone)
backupfailed := &model.Message{ApplicationID: backupServer.ID, Message: "backup failed", Title: "backup", Priority: 1, Date: time.Now()}
s.db.CreateMessage(backupfailed)
assert.NotEqual(s.T(), 0, backupfailed.ID)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 4)
assertEquals(s.T(), msgs[0], backupfailed)
assertEquals(s.T(), msgs[1], loginfailed)
assertEquals(s.T(), msgs[2], logindone)
assertEquals(s.T(), msgs[3], backupdone)
msgs = s.db.GetMessagesByApplication(loginServer.ID)
assert.Len(s.T(), msgs, 2)
assertEquals(s.T(), msgs[0], loginfailed)
assertEquals(s.T(), msgs[1], logindone)
s.db.DeleteMessagesByApplication(loginServer.ID)
assert.Empty(s.T(), s.db.GetMessagesByApplication(loginServer.ID))
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 2)
assertEquals(s.T(), msgs[0], backupfailed)
assertEquals(s.T(), msgs[1], backupdone)
logindone = &model.Message{ApplicationID: loginServer.ID, Message: "login done", Title: "login", Priority: 1, Date: time.Now()}
s.db.CreateMessage(logindone)
assert.NotEqual(s.T(), 0, logindone.ID)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 3)
assertEquals(s.T(), msgs[0], logindone)
assertEquals(s.T(), msgs[1], backupfailed)
assertEquals(s.T(), msgs[2], backupdone)
s.db.DeleteMessagesByUser(user.ID)
assert.Empty(s.T(), s.db.GetMessagesByUser(user.ID))
logout := &model.Message{ApplicationID: loginServer.ID, Message: "logout success", Title: "logout", Priority: 1, Date: time.Now()}
s.db.CreateMessage(logout)
msgs = s.db.GetMessagesByUser(user.ID)
assert.Len(s.T(), msgs, 1)
assertEquals(s.T(), msgs[0], logout)
s.db.DeleteMessageByID(logout.ID)
assert.Empty(s.T(), s.db.GetMessagesByUser(user.ID))
}
func (s *DatabaseSuite) TestGetMessagesSince() {
user := &model.User{Name: "test", Pass: []byte{1}}
s.db.CreateUser(user)
app := &model.Application{UserID: user.ID, Token: "A0000000000"}
app2 := &model.Application{UserID: user.ID, Token: "A0000000001"}
s.db.CreateApplication(app)
s.db.CreateApplication(app2)
curDate := time.Now()
for i := 1; i <= 500; i++ {
s.db.CreateMessage(&model.Message{ApplicationID: app.ID, Message: "abc", Date: curDate.Add(time.Duration(i) * time.Second)})
s.db.CreateMessage(&model.Message{ApplicationID: app2.ID, Message: "abc", Date: curDate.Add(time.Duration(i) * time.Second)})
}
actual := s.db.GetMessagesByUserSince(user.ID, 50, 0)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 1000, 951, 1)
actual = s.db.GetMessagesByUserSince(user.ID, 50, 951)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 950, 901, 1)
actual = s.db.GetMessagesByUserSince(user.ID, 100, 951)
assert.Len(s.T(), actual, 100)
hasIDInclusiveBetween(s.T(), actual, 950, 851, 1)
actual = s.db.GetMessagesByUserSince(user.ID, 100, 51)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 50, 1, 1)
actual = s.db.GetMessagesByApplicationSince(app.ID, 50, 0)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 999, 901, 2)
actual = s.db.GetMessagesByApplicationSince(app.ID, 50, 901)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 899, 801, 2)
actual = s.db.GetMessagesByApplicationSince(app.ID, 100, 666)
assert.Len(s.T(), actual, 100)
hasIDInclusiveBetween(s.T(), actual, 665, 467, 2)
actual = s.db.GetMessagesByApplicationSince(app.ID, 100, 101)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 99, 1, 2)
actual = s.db.GetMessagesByApplicationSince(app2.ID, 50, 0)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 1000, 902, 2)
actual = s.db.GetMessagesByApplicationSince(app2.ID, 50, 902)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 900, 802, 2)
actual = s.db.GetMessagesByApplicationSince(app2.ID, 100, 667)
assert.Len(s.T(), actual, 100)
hasIDInclusiveBetween(s.T(), actual, 666, 468, 2)
actual = s.db.GetMessagesByApplicationSince(app2.ID, 100, 102)
assert.Len(s.T(), actual, 50)
hasIDInclusiveBetween(s.T(), actual, 100, 2, 2)
}
func hasIDInclusiveBetween(t *testing.T, msgs []*model.Message, from, to, decrement int) {
index := 0
for expectedID := from; expectedID >= to; expectedID -= decrement {
if !assert.Equal(t, uint(expectedID), msgs[index].ID) {
break
}
index++
}
assert.Equal(t, index, len(msgs), "not all entries inside msgs were checked")
}
// assertEquals compares messages and correctly check dates
func assertEquals(t *testing.T, left *model.Message, right *model.Message) {
assert.Equal(t, left.Date.Unix(), right.Date.Unix())
left.Date = right.Date
assert.Equal(t, left, right)
}