mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
210 lines
5.8 KiB
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")
|
|
}
|
|
}
|