Files
mattermost/store/sql_preference_store_test.go

210 lines
5.8 KiB
Go

// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
// See License.txt for license information.
package store
import (
"github.com/mattermost/platform/model"
"testing"
)
func TestPreferenceStoreSave(t *testing.T) {
Setup()
p1 := model.Preference{
UserId: model.NewId(),
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
AltId: model.NewId(),
}
if err := (<-store.Preference().Save(&p1)).Err; err != nil {
t.Fatal("couldn't save preference", err)
}
if err := (<-store.Preference().Save(&p1)).Err; err == nil {
t.Fatal("shouldn't be able to save duplicate preference")
}
p2 := model.Preference{
UserId: model.NewId(),
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
AltId: p1.AltId,
}
if err := (<-store.Preference().Save(&p2)).Err; err != nil {
t.Fatal("couldn't save preference with duplicate category, name, alternate id", err)
}
p3 := model.Preference{
UserId: p1.UserId,
Category: model.PREFERENCE_CATEGORY_TEST,
Name: model.PREFERENCE_NAME_SHOW,
AltId: p1.AltId,
}
if err := (<-store.Preference().Save(&p3)).Err; err != nil {
t.Fatal("couldn't save preference with duplicate user id, name, alternate id", err)
}
p4 := model.Preference{
UserId: p1.UserId,
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_TEST,
AltId: p1.AltId,
}
if err := (<-store.Preference().Save(&p4)).Err; err != nil {
t.Fatal("couldn't save preference with duplicate user id, category, alternate id", err)
}
p5 := model.Preference{
UserId: p1.UserId,
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
AltId: model.NewId(),
}
if err := (<-store.Preference().Save(&p5)).Err; err != nil {
t.Fatal("couldn't save preference with duplicate user id, category, name", err)
}
}
func TestPreferenceStoreUpdate(t *testing.T) {
Setup()
id := model.NewId()
p1 := model.Preference{
UserId: id,
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
}
Must(store.Preference().Save(&p1))
p1.Value = "1234garbage"
if result := (<-store.Preference().Update(&p1)); result.Err != nil {
t.Fatal(result.Err)
} else if result.Data.(int64) != 1 {
t.Fatal("update should have changed only 1 row")
}
p1.UserId = model.NewId()
if result := (<-store.Preference().Update(&p1)); result.Err != nil {
t.Fatal(result.Err)
} else if result.Data.(int64) != 0 {
t.Fatal("update shouldn't have made changes because of changed user id")
}
p1.UserId = id
p1.Category = model.PREFERENCE_CATEGORY_TEST
if result := (<-store.Preference().Update(&p1)); result.Err != nil {
t.Fatal(result.Err)
} else if result.Data.(int64) != 0 {
t.Fatal("update shouldn't have made changes because of changed category")
}
p1.Category = model.PREFERENCE_CATEGORY_DIRECT_CHANNELS
p1.Name = model.PREFERENCE_NAME_TEST
if result := (<-store.Preference().Update(&p1)); result.Err != nil {
t.Fatal(result.Err)
} else if result.Data.(int64) != 0 {
t.Fatal("update shouldn't have made changes because of changed name")
}
p1.Name = model.PREFERENCE_NAME_SHOW
p1.AltId = model.NewId()
if result := (<-store.Preference().Update(&p1)); result.Err != nil {
t.Fatal(result.Err)
} else if result.Data.(int64) != 0 {
t.Fatal("update shouldn't have made changes because of changed alt id")
}
}
func TestPreferenceSaveOrUpdate(t *testing.T) {
Setup()
id := model.NewId()
p1 := model.Preference{
UserId: id,
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
Value: "value1",
}
Must(store.Preference().SaveOrUpdate(&p1))
if preferences := Must(store.Preference().GetByName(p1.UserId, p1.Category, p1.Name)).([]*model.Preference); len(preferences) != 1 {
t.Fatal("got incorrect number of preferences after SaveOrUpdate")
} else if preferences[0].Value != "value1" {
t.Fatal("should have received value1 after SaveOrUpdate")
}
p1.Value = "value2"
Must(store.Preference().SaveOrUpdate(&p1))
if preferences := Must(store.Preference().GetByName(p1.UserId, p1.Category, p1.Name)).([]*model.Preference); len(preferences) != 1 {
t.Fatal("got incorrect number of preferences after second SaveOrUpdate")
} else if preferences[0].Value != "value2" {
t.Fatal("should have received value2 after SaveOrUpdate")
}
}
func TestPreferenceGetByName(t *testing.T) {
Setup()
p1 := model.Preference{
UserId: model.NewId(),
Category: model.PREFERENCE_CATEGORY_DIRECT_CHANNELS,
Name: model.PREFERENCE_NAME_SHOW,
AltId: model.NewId(),
}
// same user/category/name, different alt id
p2 := model.Preference{
UserId: p1.UserId,
Category: p1.Category,
Name: p1.Name,
AltId: model.NewId(),
}
// same user/category/alt id, different name
p3 := model.Preference{
UserId: p1.UserId,
Category: p1.Category,
Name: model.PREFERENCE_NAME_TEST,
AltId: p1.AltId,
}
// same user/name/alt id, different category
p4 := model.Preference{
UserId: p1.UserId,
Category: model.PREFERENCE_CATEGORY_TEST,
Name: p1.Name,
AltId: p1.AltId,
}
// same name/category/alt id, different user
p5 := model.Preference{
UserId: model.NewId(),
Category: p1.Category,
Name: p1.Name,
AltId: p1.AltId,
}
Must(store.Preference().Save(&p1))
Must(store.Preference().Save(&p2))
Must(store.Preference().Save(&p3))
Must(store.Preference().Save(&p4))
Must(store.Preference().Save(&p5))
if result := <-store.Preference().GetByName(p1.UserId, p1.Category, p1.Name); result.Err != nil {
t.Fatal(result.Err)
} else if data := result.Data.([]*model.Preference); len(data) != 2 {
t.Fatal("got the wrong number of preferences")
} else if !((*data[0] == p1 && *data[1] == p2) || (*data[0] == p2 && *data[1] == p1)) {
t.Fatal("got incorrect preferences")
}
}