mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* improve performance on sendNotifications * Fix SQL queries * Remove get direct profiles, not needed anymore * Add raw data to error details if AppError fails to decode * men * Fix decode (#4052) * Fixing json decode * Adding unit test * Initial work for client scaling (#4051) * Begin adding paging to profiles API * Added more paging functionality * Finish hooking up admin console user lists * Add API for searching users and add searching to all user lists * Add lazy loading of profiles * Revert config.json * Fix unit tests and some style issues * Add GetProfilesFromList to Go driver and fix web unit test * Update etag for GetProfiles * Updating ui for filters and pagination (#4044) * Updating UI for pagination * Adjusting margins for filter row * Adjusting margin for specific modals * Adding relative padding to system console * Adjusting responsive view * Update client user tests * Minor fixes for direct messages modal (#4056) * Remove some unneeded initial load calls (#4057) * UX updates to user lists, added smart counts and bug fixes (#4059) * Improved getExplicitMentions and unit tests (#4064) * Refactor getting posts to lazy load profiles correctly (#4062) * Comment out SetActiveChannel test (#4066) * Profiler cpu, block, and memory profiler. (#4081) * Fix TestSetActiveChannel unit test (#4071) * Fixing build failure caused by dependancies updating (#4076) * Adding profiler * Fix admin_team_member_dropdown eslint errors * Bumping session cache size (#4077) * Bumping session cache size * Bumping status cache * Refactor how the client handles channel members to be large team friendly (#4106) * Refactor how the client handles channel members to be large team friendly * Change Id to ChannelId in ChannelStats model * Updated getChannelMember and getProfilesByIds routes to match proposal * Performance improvements (#4100) * Performance improvements * Fixing re-connect issue * Fixing error message * Some other minor perf tweaks * Some other minor perf tweaks * Fixing config file * Fixing buffer size * Fixing web socket send message * adding some error logging * fix getMe to be user required * Fix websocket event for new user * Fixing shutting down * Reverting web socket changes * Fixing logging lvl * Adding caching to GetMember * Adding some logging * Fixing caching * Fixing caching invalidate * Fixing direct message caching * Fixing caching * Fixing caching * Remove GetDirectProfiles from initial load * Adding logging and fixing websocket client * Adding back caching from bad merge. * Explicitly close go driver requests (#4162) * Refactored how the client handles team members to be more large team friendly (#4159) * Refactor getProfilesForDirectMessageList API into getAllProfiles API * Refactored how the client handles team members to be more large team friendly * Fix js error when receiving a notification * Fix JS error caused by current user being overwritten with sanitized version (#4165) * Adding error message to status failure (#4167) * Fix a few bugs caused by client scaling refactoring (#4170) * When there is no read replica, don't open a second set of connections to the master database (#4173) * Adding connection tacking to stats (#4174) * Reduce DB writes for statuses and other status related changes (#4175) * Fix bug preventing opening of DM channels from more modal (#4181) * Fixing socket timing error (#4183) * Fixing ping/pong handler * Fixing socket timing error * Commenting out status broadcasting * Removing user status changes * Removing user status changes * Removing user status changes * Removing user status changes * Adding DoPreComputeJson() * Performance improvements (#4194) * * Fix System Console Analytics queries * Add db.SetConnMaxLifetime to 15 minutes * Add "net/http/pprof" for profiling * Add FreeOSMemory() to manually release memory on reload config * Add flag to enable http profiler * Fix memory leak (#4197) * Fix memory leak * removed unneeded nil assignment * Fixing go routine leak (#4208) * Merge fixes * Merge fix * Refactored statuses to be queried by the client rather than broadcast by the server (#4212) * Refactored server code to reduce status broadcasts and to allow getting statuses by IDs * Refactor client code to periodically fetch statuses * Add store unit test for getting statuses by ids * Fix status unit test * Add getStatusesByIds REST API and move the client over to use that instead of the WebSocket * Adding multiple threads to websocket hub (#4230) * Adding multiple threads to websocket hub * Fixing unit tests * Fixing so websocket connections from the same user end up in the same… (#4240) * Fixing so websocket connections from the same user end up in the same list * Removing old comment * Refactor user autocomplete to query the server (#4239) * Add API for autocompleting users * Converted at mention autocomplete to query server * Converted user search autocomplete to query server * Switch autocomplete API naming to use term instead of username * Split autocomplete API into two, one for channels and for teams * Fix copy/paste error * Some final client scaling fixes (#4246) * Add lazy loading of profiles to integration pages * Add lazy loading of profiles to emoji page * Fix JS error when receiving post in select team menu and also clean up channel store
1003 lines
26 KiB
Go
1003 lines
26 KiB
Go
// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
package store
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/mattermost/platform/model"
|
|
)
|
|
|
|
func TestChannelStoreSave(t *testing.T) {
|
|
Setup()
|
|
|
|
teamId := model.NewId()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = teamId
|
|
o1.DisplayName = "Name"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
|
|
if err := (<-store.Channel().Save(&o1)).Err; err != nil {
|
|
t.Fatal("couldn't save item", err)
|
|
}
|
|
|
|
if err := (<-store.Channel().Save(&o1)).Err; err == nil {
|
|
t.Fatal("shouldn't be able to update from save")
|
|
}
|
|
|
|
o1.Id = ""
|
|
if err := (<-store.Channel().Save(&o1)).Err; err == nil {
|
|
t.Fatal("should be unique name")
|
|
}
|
|
|
|
o1.Id = ""
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_DIRECT
|
|
if err := (<-store.Channel().Save(&o1)).Err; err == nil {
|
|
t.Fatal("Should not be able to save direct channel")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreSaveDirectChannel(t *testing.T) {
|
|
Setup()
|
|
|
|
teamId := model.NewId()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = teamId
|
|
o1.DisplayName = "Name"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_DIRECT
|
|
|
|
u1 := &model.User{}
|
|
u1.Email = model.NewId()
|
|
u1.Nickname = model.NewId()
|
|
Must(store.User().Save(u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u1.Id}))
|
|
|
|
u2 := &model.User{}
|
|
u2.Email = model.NewId()
|
|
u2.Nickname = model.NewId()
|
|
Must(store.User().Save(u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u2.Id}))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = u1.Id
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o1.Id
|
|
m2.UserId = u2.Id
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
|
|
if err := (<-store.Channel().SaveDirectChannel(&o1, &m1, &m2)).Err; err != nil {
|
|
t.Fatal("couldn't save direct channel", err)
|
|
}
|
|
|
|
members := (<-store.Channel().GetMembers(o1.Id)).Data.([]model.ChannelMember)
|
|
if len(members) != 2 {
|
|
t.Fatal("should have saved 2 members")
|
|
}
|
|
|
|
if err := (<-store.Channel().SaveDirectChannel(&o1, &m1, &m2)).Err; err == nil {
|
|
t.Fatal("shouldn't be able to update from save")
|
|
}
|
|
|
|
o1.Id = ""
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
if err := (<-store.Channel().SaveDirectChannel(&o1, &m1, &m2)).Err; err == nil {
|
|
t.Fatal("Should not be able to save non-direct channel")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreCreateDirectChannel(t *testing.T) {
|
|
Setup()
|
|
|
|
u1 := &model.User{}
|
|
u1.Email = model.NewId()
|
|
u1.Nickname = model.NewId()
|
|
Must(store.User().Save(u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u1.Id}))
|
|
|
|
u2 := &model.User{}
|
|
u2.Email = model.NewId()
|
|
u2.Nickname = model.NewId()
|
|
Must(store.User().Save(u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u2.Id}))
|
|
|
|
res := <-store.Channel().CreateDirectChannel(u1.Id, u2.Id)
|
|
if res.Err != nil {
|
|
t.Fatal("couldn't create direct channel", res.Err)
|
|
}
|
|
|
|
c1 := res.Data.(*model.Channel)
|
|
|
|
members := (<-store.Channel().GetMembers(c1.Id)).Data.([]model.ChannelMember)
|
|
if len(members) != 2 {
|
|
t.Fatal("should have saved 2 members")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreUpdate(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Name"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
|
|
if err := (<-store.Channel().Save(&o1)).Err; err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
|
if err := (<-store.Channel().Update(&o1)).Err; err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
o1.Id = "missing"
|
|
if err := (<-store.Channel().Update(&o1)).Err; err == nil {
|
|
t.Fatal("Update should have failed because of missing key")
|
|
}
|
|
|
|
o1.Id = model.NewId()
|
|
if err := (<-store.Channel().Update(&o1)).Err; err == nil {
|
|
t.Fatal("Update should have faile because id change")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGet(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Name"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
if r1 := <-store.Channel().Get(o1.Id); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else {
|
|
if r1.Data.(*model.Channel).ToJson() != o1.ToJson() {
|
|
t.Fatal("invalid returned channel")
|
|
}
|
|
}
|
|
|
|
if err := (<-store.Channel().Get("")).Err; err == nil {
|
|
t.Fatal("Missing id should have failed")
|
|
}
|
|
|
|
u1 := &model.User{}
|
|
u1.Email = model.NewId()
|
|
u1.Nickname = model.NewId()
|
|
Must(store.User().Save(u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u1.Id}))
|
|
|
|
u2 := model.User{}
|
|
u2.Email = model.NewId()
|
|
u2.Nickname = model.NewId()
|
|
Must(store.User().Save(&u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u2.Id}))
|
|
|
|
o2 := model.Channel{}
|
|
o2.TeamId = model.NewId()
|
|
o2.DisplayName = "Direct Name"
|
|
o2.Name = "a" + model.NewId() + "b"
|
|
o2.Type = model.CHANNEL_DIRECT
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o2.Id
|
|
m1.UserId = u1.Id
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o2.Id
|
|
m2.UserId = u2.Id
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
|
|
Must(store.Channel().SaveDirectChannel(&o2, &m1, &m2))
|
|
|
|
if r2 := <-store.Channel().Get(o2.Id); r2.Err != nil {
|
|
t.Fatal(r2.Err)
|
|
} else {
|
|
if r2.Data.(*model.Channel).ToJson() != o2.ToJson() {
|
|
t.Fatal("invalid returned channel")
|
|
}
|
|
}
|
|
|
|
if r3 := <-store.Channel().GetAll(o1.TeamId); r3.Err != nil {
|
|
t.Fatal(r3.Err)
|
|
} else {
|
|
channels := r3.Data.([]*model.Channel)
|
|
if len(channels) == 0 {
|
|
t.Fatal("too little")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGetForPost(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := Must(store.Channel().Save(&model.Channel{
|
|
TeamId: model.NewId(),
|
|
DisplayName: "Name",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
})).(*model.Channel)
|
|
|
|
p1 := Must(store.Post().Save(&model.Post{
|
|
UserId: model.NewId(),
|
|
ChannelId: o1.Id,
|
|
Message: "test",
|
|
})).(*model.Post)
|
|
|
|
if r1 := <-store.Channel().GetForPost(p1.Id); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else if r1.Data.(*model.Channel).Id != o1.Id {
|
|
t.Fatal("incorrect channel returned")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreDelete(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
o2 := model.Channel{}
|
|
o2.TeamId = o1.TeamId
|
|
o2.DisplayName = "Channel2"
|
|
o2.Name = "a" + model.NewId() + "b"
|
|
o2.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o2))
|
|
|
|
o3 := model.Channel{}
|
|
o3.TeamId = o1.TeamId
|
|
o3.DisplayName = "Channel3"
|
|
o3.Name = "a" + model.NewId() + "b"
|
|
o3.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o3))
|
|
|
|
o4 := model.Channel{}
|
|
o4.TeamId = o1.TeamId
|
|
o4.DisplayName = "Channel4"
|
|
o4.Name = "a" + model.NewId() + "b"
|
|
o4.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o4))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o2.Id
|
|
m2.UserId = m1.UserId
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m2))
|
|
|
|
if r := <-store.Channel().Delete(o1.Id, model.GetMillis()); r.Err != nil {
|
|
t.Fatal(r.Err)
|
|
}
|
|
|
|
if r := <-store.Channel().Get(o1.Id); r.Data.(*model.Channel).DeleteAt == 0 {
|
|
t.Fatal("should have been deleted")
|
|
}
|
|
|
|
if r := <-store.Channel().Delete(o3.Id, model.GetMillis()); r.Err != nil {
|
|
t.Fatal(r.Err)
|
|
}
|
|
|
|
cresult := <-store.Channel().GetChannels(o1.TeamId, m1.UserId)
|
|
list := cresult.Data.(*model.ChannelList)
|
|
|
|
if len(list.Channels) != 1 {
|
|
t.Fatal("invalid number of channels")
|
|
}
|
|
|
|
cresult = <-store.Channel().GetMoreChannels(o1.TeamId, m1.UserId)
|
|
list = cresult.Data.(*model.ChannelList)
|
|
|
|
if len(list.Channels) != 1 {
|
|
t.Fatal("invalid number of channels")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGetByName(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Name"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
if r1 := <-store.Channel().GetByName(o1.TeamId, o1.Name); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else {
|
|
if r1.Data.(*model.Channel).ToJson() != o1.ToJson() {
|
|
t.Fatal("invalid returned channel")
|
|
}
|
|
}
|
|
|
|
if err := (<-store.Channel().GetByName(o1.TeamId, "")).Err; err == nil {
|
|
t.Fatal("Missing id should have failed")
|
|
}
|
|
}
|
|
|
|
func TestChannelMemberStore(t *testing.T) {
|
|
Setup()
|
|
|
|
c1 := model.Channel{}
|
|
c1.TeamId = model.NewId()
|
|
c1.DisplayName = "NameName"
|
|
c1.Name = "a" + model.NewId() + "b"
|
|
c1.Type = model.CHANNEL_OPEN
|
|
c1 = *Must(store.Channel().Save(&c1)).(*model.Channel)
|
|
|
|
c1t1 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t1 := c1t1.ExtraUpdateAt
|
|
|
|
u1 := model.User{}
|
|
u1.Email = model.NewId()
|
|
u1.Nickname = model.NewId()
|
|
Must(store.User().Save(&u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u1.Id}))
|
|
|
|
u2 := model.User{}
|
|
u2.Email = model.NewId()
|
|
u2.Nickname = model.NewId()
|
|
Must(store.User().Save(&u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u2.Id}))
|
|
|
|
o1 := model.ChannelMember{}
|
|
o1.ChannelId = c1.Id
|
|
o1.UserId = u1.Id
|
|
o1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&o1))
|
|
|
|
o2 := model.ChannelMember{}
|
|
o2.ChannelId = c1.Id
|
|
o2.UserId = u2.Id
|
|
o2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&o2))
|
|
|
|
c1t2 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t2 := c1t2.ExtraUpdateAt
|
|
|
|
if t2 <= t1 {
|
|
t.Fatal("Member update time incorrect")
|
|
}
|
|
|
|
count := (<-store.Channel().GetMemberCount(o1.ChannelId)).Data.(int64)
|
|
if count != 2 {
|
|
t.Fatal("should have saved 2 members")
|
|
}
|
|
|
|
Must(store.Channel().RemoveMember(o2.ChannelId, o2.UserId))
|
|
|
|
count = (<-store.Channel().GetMemberCount(o1.ChannelId)).Data.(int64)
|
|
if count != 1 {
|
|
t.Fatal("should have removed 1 member")
|
|
}
|
|
|
|
c1t3 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t3 := c1t3.ExtraUpdateAt
|
|
|
|
if t3 <= t2 || t3 <= t1 {
|
|
t.Fatal("Member update time incorrect on delete")
|
|
}
|
|
|
|
member := (<-store.Channel().GetMember(o1.ChannelId, o1.UserId)).Data.(model.ChannelMember)
|
|
if member.ChannelId != o1.ChannelId {
|
|
t.Fatal("should have go member")
|
|
}
|
|
|
|
if err := (<-store.Channel().SaveMember(&o1)).Err; err == nil {
|
|
t.Fatal("Should have been a duplicate")
|
|
}
|
|
|
|
c1t4 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t4 := c1t4.ExtraUpdateAt
|
|
if t4 != t3 {
|
|
t.Fatal("Should not update time upon failure")
|
|
}
|
|
}
|
|
|
|
func TestChannelDeleteMemberStore(t *testing.T) {
|
|
Setup()
|
|
|
|
c1 := model.Channel{}
|
|
c1.TeamId = model.NewId()
|
|
c1.DisplayName = "NameName"
|
|
c1.Name = "a" + model.NewId() + "b"
|
|
c1.Type = model.CHANNEL_OPEN
|
|
c1 = *Must(store.Channel().Save(&c1)).(*model.Channel)
|
|
|
|
c1t1 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t1 := c1t1.ExtraUpdateAt
|
|
|
|
u1 := model.User{}
|
|
u1.Email = model.NewId()
|
|
u1.Nickname = model.NewId()
|
|
Must(store.User().Save(&u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u1.Id}))
|
|
|
|
u2 := model.User{}
|
|
u2.Email = model.NewId()
|
|
u2.Nickname = model.NewId()
|
|
Must(store.User().Save(&u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: model.NewId(), UserId: u2.Id}))
|
|
|
|
o1 := model.ChannelMember{}
|
|
o1.ChannelId = c1.Id
|
|
o1.UserId = u1.Id
|
|
o1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&o1))
|
|
|
|
o2 := model.ChannelMember{}
|
|
o2.ChannelId = c1.Id
|
|
o2.UserId = u2.Id
|
|
o2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&o2))
|
|
|
|
c1t2 := (<-store.Channel().Get(c1.Id)).Data.(*model.Channel)
|
|
t2 := c1t2.ExtraUpdateAt
|
|
|
|
if t2 <= t1 {
|
|
t.Fatal("Member update time incorrect")
|
|
}
|
|
|
|
count := (<-store.Channel().GetMemberCount(o1.ChannelId)).Data.(int64)
|
|
if count != 2 {
|
|
t.Fatal("should have saved 2 members")
|
|
}
|
|
|
|
Must(store.Channel().PermanentDeleteMembersByUser(o2.UserId))
|
|
|
|
count = (<-store.Channel().GetMemberCount(o1.ChannelId)).Data.(int64)
|
|
if count != 1 {
|
|
t.Fatal("should have removed 1 member")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGetChannels(t *testing.T) {
|
|
Setup()
|
|
|
|
o2 := model.Channel{}
|
|
o2.TeamId = model.NewId()
|
|
o2.DisplayName = "Channel2"
|
|
o2.Name = "a" + model.NewId() + "b"
|
|
o2.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o2))
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o1.Id
|
|
m2.UserId = model.NewId()
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m2))
|
|
|
|
m3 := model.ChannelMember{}
|
|
m3.ChannelId = o2.Id
|
|
m3.UserId = model.NewId()
|
|
m3.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m3))
|
|
|
|
cresult := <-store.Channel().GetChannels(o1.TeamId, m1.UserId)
|
|
list := cresult.Data.(*model.ChannelList)
|
|
|
|
if list.Channels[0].Id != o1.Id {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
acresult := <-store.Channel().GetAllChannelMembersForUser(m1.UserId, false)
|
|
ids := acresult.Data.(map[string]string)
|
|
if _, ok := ids[o1.Id]; !ok {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
acresult2 := <-store.Channel().GetAllChannelMembersForUser(m1.UserId, true)
|
|
ids2 := acresult2.Data.(map[string]string)
|
|
if _, ok := ids2[o1.Id]; !ok {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
acresult3 := <-store.Channel().GetAllChannelMembersForUser(m1.UserId, true)
|
|
ids3 := acresult3.Data.(map[string]string)
|
|
if _, ok := ids3[o1.Id]; !ok {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
if !store.Channel().IsUserInChannelUseCache(m1.UserId, o1.Id) {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
if store.Channel().IsUserInChannelUseCache(m1.UserId, o2.Id) {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
if store.Channel().IsUserInChannelUseCache(m1.UserId, "blahblah") {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
if store.Channel().IsUserInChannelUseCache("blahblah", "blahblah") {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
store.Channel().InvalidateAllChannelMembersForUser(m1.UserId)
|
|
}
|
|
|
|
func TestChannelStoreGetMoreChannels(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
o2 := model.Channel{}
|
|
o2.TeamId = model.NewId()
|
|
o2.DisplayName = "Channel2"
|
|
o2.Name = "a" + model.NewId() + "b"
|
|
o2.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o2))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o1.Id
|
|
m2.UserId = model.NewId()
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m2))
|
|
|
|
m3 := model.ChannelMember{}
|
|
m3.ChannelId = o2.Id
|
|
m3.UserId = model.NewId()
|
|
m3.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m3))
|
|
|
|
o3 := model.Channel{}
|
|
o3.TeamId = o1.TeamId
|
|
o3.DisplayName = "ChannelA"
|
|
o3.Name = "a" + model.NewId() + "b"
|
|
o3.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o3))
|
|
|
|
o4 := model.Channel{}
|
|
o4.TeamId = o1.TeamId
|
|
o4.DisplayName = "ChannelB"
|
|
o4.Name = "a" + model.NewId() + "b"
|
|
o4.Type = model.CHANNEL_PRIVATE
|
|
Must(store.Channel().Save(&o4))
|
|
|
|
o5 := model.Channel{}
|
|
o5.TeamId = o1.TeamId
|
|
o5.DisplayName = "ChannelC"
|
|
o5.Name = "a" + model.NewId() + "b"
|
|
o5.Type = model.CHANNEL_PRIVATE
|
|
Must(store.Channel().Save(&o5))
|
|
|
|
cresult := <-store.Channel().GetMoreChannels(o1.TeamId, m1.UserId)
|
|
list := cresult.Data.(*model.ChannelList)
|
|
|
|
if len(list.Channels) != 1 {
|
|
t.Fatal("wrong list")
|
|
}
|
|
|
|
if list.Channels[0].Name != o3.Name {
|
|
t.Fatal("missing channel")
|
|
}
|
|
|
|
if r1 := <-store.Channel().AnalyticsTypeCount(o1.TeamId, model.CHANNEL_OPEN); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else {
|
|
if r1.Data.(int64) != 2 {
|
|
t.Log(r1.Data)
|
|
t.Fatal("wrong value")
|
|
}
|
|
}
|
|
|
|
if r1 := <-store.Channel().AnalyticsTypeCount(o1.TeamId, model.CHANNEL_PRIVATE); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else {
|
|
if r1.Data.(int64) != 2 {
|
|
t.Log(r1.Data)
|
|
t.Fatal("wrong value")
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGetChannelCounts(t *testing.T) {
|
|
Setup()
|
|
|
|
o2 := model.Channel{}
|
|
o2.TeamId = model.NewId()
|
|
o2.DisplayName = "Channel2"
|
|
o2.Name = "a" + model.NewId() + "b"
|
|
o2.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o2))
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
m2 := model.ChannelMember{}
|
|
m2.ChannelId = o1.Id
|
|
m2.UserId = model.NewId()
|
|
m2.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m2))
|
|
|
|
m3 := model.ChannelMember{}
|
|
m3.ChannelId = o2.Id
|
|
m3.UserId = model.NewId()
|
|
m3.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m3))
|
|
|
|
cresult := <-store.Channel().GetChannelCounts(o1.TeamId, m1.UserId)
|
|
counts := cresult.Data.(*model.ChannelCounts)
|
|
|
|
if len(counts.Counts) != 1 {
|
|
t.Fatal("wrong number of counts")
|
|
}
|
|
|
|
if len(counts.UpdateTimes) != 1 {
|
|
t.Fatal("wrong number of update times")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreUpdateLastViewedAt(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
o1.TotalMsgCount = 25
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
err := (<-store.Channel().UpdateLastViewedAt(m1.ChannelId, m1.UserId)).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update", err)
|
|
}
|
|
|
|
err = (<-store.Channel().UpdateLastViewedAt(m1.ChannelId, "missing id")).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreIncrementMentionCount(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := model.Channel{}
|
|
o1.TeamId = model.NewId()
|
|
o1.DisplayName = "Channel1"
|
|
o1.Name = "a" + model.NewId() + "b"
|
|
o1.Type = model.CHANNEL_OPEN
|
|
o1.TotalMsgCount = 25
|
|
Must(store.Channel().Save(&o1))
|
|
|
|
m1 := model.ChannelMember{}
|
|
m1.ChannelId = o1.Id
|
|
m1.UserId = model.NewId()
|
|
m1.NotifyProps = model.GetDefaultChannelNotifyProps()
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
err := (<-store.Channel().IncrementMentionCount(m1.ChannelId, m1.UserId)).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update")
|
|
}
|
|
|
|
err = (<-store.Channel().IncrementMentionCount(m1.ChannelId, "missing id")).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update")
|
|
}
|
|
|
|
err = (<-store.Channel().IncrementMentionCount("missing id", m1.UserId)).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update")
|
|
}
|
|
|
|
err = (<-store.Channel().IncrementMentionCount("missing id", "missing id")).Err
|
|
if err != nil {
|
|
t.Fatal("failed to update")
|
|
}
|
|
}
|
|
|
|
func TestGetMember(t *testing.T) {
|
|
Setup()
|
|
|
|
userId := model.NewId()
|
|
|
|
c1 := &model.Channel{
|
|
TeamId: model.NewId(),
|
|
DisplayName: model.NewId(),
|
|
Name: model.NewId(),
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(c1))
|
|
|
|
c2 := &model.Channel{
|
|
TeamId: c1.TeamId,
|
|
DisplayName: model.NewId(),
|
|
Name: model.NewId(),
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(c2))
|
|
|
|
m1 := &model.ChannelMember{
|
|
ChannelId: c1.Id,
|
|
UserId: userId,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(m1))
|
|
|
|
m2 := &model.ChannelMember{
|
|
ChannelId: c2.Id,
|
|
UserId: userId,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(m2))
|
|
|
|
if result := <-store.Channel().GetMember(model.NewId(), userId); result.Err == nil {
|
|
t.Fatal("should've failed to get member for non-existant channel")
|
|
}
|
|
|
|
if result := <-store.Channel().GetMember(c1.Id, model.NewId()); result.Err == nil {
|
|
t.Fatal("should've failed to get member for non-existant user")
|
|
}
|
|
|
|
if result := <-store.Channel().GetMember(c1.Id, userId); result.Err != nil {
|
|
t.Fatal("shouldn't have errored when getting member", result.Err)
|
|
} else if member := result.Data.(model.ChannelMember); member.ChannelId != c1.Id {
|
|
t.Fatal("should've gotten member of channel 1")
|
|
} else if member.UserId != userId {
|
|
t.Fatal("should've gotten member for user")
|
|
}
|
|
|
|
if result := <-store.Channel().GetMember(c2.Id, userId); result.Err != nil {
|
|
t.Fatal("shouldn't have errored when getting member", result.Err)
|
|
} else if member := result.Data.(model.ChannelMember); member.ChannelId != c2.Id {
|
|
t.Fatal("should've gotten member of channel 2")
|
|
} else if member.UserId != userId {
|
|
t.Fatal("should've gotten member for user")
|
|
}
|
|
}
|
|
|
|
func TestChannelStoreGetMemberForPost(t *testing.T) {
|
|
Setup()
|
|
|
|
o1 := Must(store.Channel().Save(&model.Channel{
|
|
TeamId: model.NewId(),
|
|
DisplayName: "Name",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
})).(*model.Channel)
|
|
|
|
m1 := Must(store.Channel().SaveMember(&model.ChannelMember{
|
|
ChannelId: o1.Id,
|
|
UserId: model.NewId(),
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
})).(*model.ChannelMember)
|
|
|
|
p1 := Must(store.Post().Save(&model.Post{
|
|
UserId: model.NewId(),
|
|
ChannelId: o1.Id,
|
|
Message: "test",
|
|
})).(*model.Post)
|
|
|
|
if r1 := <-store.Channel().GetMemberForPost(p1.Id, m1.UserId); r1.Err != nil {
|
|
t.Fatal(r1.Err)
|
|
} else if r1.Data.(*model.ChannelMember).ToJson() != m1.ToJson() {
|
|
t.Fatal("invalid returned channel member")
|
|
}
|
|
|
|
if r2 := <-store.Channel().GetMemberForPost(p1.Id, model.NewId()); r2.Err == nil {
|
|
t.Fatal("shouldn't have returned a member")
|
|
}
|
|
}
|
|
|
|
func TestGetMemberCount(t *testing.T) {
|
|
Setup()
|
|
|
|
teamId := model.NewId()
|
|
|
|
c1 := model.Channel{
|
|
TeamId: teamId,
|
|
DisplayName: "Channel1",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(&c1))
|
|
|
|
c2 := model.Channel{
|
|
TeamId: teamId,
|
|
DisplayName: "Channel2",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(&c2))
|
|
|
|
u1 := &model.User{
|
|
Email: model.NewId(),
|
|
DeleteAt: 0,
|
|
}
|
|
Must(store.User().Save(u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: teamId, UserId: u1.Id}))
|
|
|
|
m1 := model.ChannelMember{
|
|
ChannelId: c1.Id,
|
|
UserId: u1.Id,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
if result := <-store.Channel().GetMemberCount(c1.Id); result.Err != nil {
|
|
t.Fatal("failed to get member count: %v", result.Err)
|
|
} else if result.Data.(int64) != 1 {
|
|
t.Fatal("got incorrect member count %v", result.Data)
|
|
}
|
|
|
|
u2 := model.User{
|
|
Email: model.NewId(),
|
|
DeleteAt: 0,
|
|
}
|
|
Must(store.User().Save(&u2))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: teamId, UserId: u2.Id}))
|
|
|
|
m2 := model.ChannelMember{
|
|
ChannelId: c1.Id,
|
|
UserId: u2.Id,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(&m2))
|
|
|
|
if result := <-store.Channel().GetMemberCount(c1.Id); result.Err != nil {
|
|
t.Fatal("failed to get member count: %v", result.Err)
|
|
} else if result.Data.(int64) != 2 {
|
|
t.Fatal("got incorrect member count %v", result.Data)
|
|
}
|
|
|
|
// make sure members of other channels aren't counted
|
|
u3 := model.User{
|
|
Email: model.NewId(),
|
|
DeleteAt: 0,
|
|
}
|
|
Must(store.User().Save(&u3))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: teamId, UserId: u3.Id}))
|
|
|
|
m3 := model.ChannelMember{
|
|
ChannelId: c2.Id,
|
|
UserId: u3.Id,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(&m3))
|
|
|
|
if result := <-store.Channel().GetMemberCount(c1.Id); result.Err != nil {
|
|
t.Fatal("failed to get member count: %v", result.Err)
|
|
} else if result.Data.(int64) != 2 {
|
|
t.Fatal("got incorrect member count %v", result.Data)
|
|
}
|
|
|
|
// make sure inactive users aren't counted
|
|
u4 := &model.User{
|
|
Email: model.NewId(),
|
|
DeleteAt: 10000,
|
|
}
|
|
Must(store.User().Save(u4))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: teamId, UserId: u4.Id}))
|
|
|
|
m4 := model.ChannelMember{
|
|
ChannelId: c1.Id,
|
|
UserId: u4.Id,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(&m4))
|
|
|
|
if result := <-store.Channel().GetMemberCount(c1.Id); result.Err != nil {
|
|
t.Fatal("failed to get member count: %v", result.Err)
|
|
} else if result.Data.(int64) != 2 {
|
|
t.Fatal("got incorrect member count %v", result.Data)
|
|
}
|
|
}
|
|
|
|
func TestUpdateExtrasByUser(t *testing.T) {
|
|
Setup()
|
|
|
|
teamId := model.NewId()
|
|
|
|
c1 := model.Channel{
|
|
TeamId: teamId,
|
|
DisplayName: "Channel1",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(&c1))
|
|
|
|
c2 := model.Channel{
|
|
TeamId: teamId,
|
|
DisplayName: "Channel2",
|
|
Name: "a" + model.NewId() + "b",
|
|
Type: model.CHANNEL_OPEN,
|
|
}
|
|
Must(store.Channel().Save(&c2))
|
|
|
|
u1 := &model.User{
|
|
Email: model.NewId(),
|
|
DeleteAt: 0,
|
|
}
|
|
Must(store.User().Save(u1))
|
|
Must(store.Team().SaveMember(&model.TeamMember{TeamId: teamId, UserId: u1.Id}))
|
|
|
|
m1 := model.ChannelMember{
|
|
ChannelId: c1.Id,
|
|
UserId: u1.Id,
|
|
NotifyProps: model.GetDefaultChannelNotifyProps(),
|
|
}
|
|
Must(store.Channel().SaveMember(&m1))
|
|
|
|
u1.DeleteAt = model.GetMillis()
|
|
Must(store.User().Update(u1, true))
|
|
|
|
if result := <-store.Channel().ExtraUpdateByUser(u1.Id, u1.DeleteAt); result.Err != nil {
|
|
t.Fatal("failed to update extras by user: %v", result.Err)
|
|
}
|
|
|
|
u1.DeleteAt = 0
|
|
Must(store.User().Update(u1, true))
|
|
|
|
if result := <-store.Channel().ExtraUpdateByUser(u1.Id, u1.DeleteAt); result.Err != nil {
|
|
t.Fatal("failed to update extras by user: %v", result.Err)
|
|
}
|
|
}
|