mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
[MM-11227] Migrate "Channel.GetMembers" to Sync by default (#11228)
* Migrate 'Channel.GetMembers' to Sync by default * Add error tests to GetMembers * Change error name * Change error name
This commit is contained in:
committed by
Harrison Healey
parent
aad50f7b2c
commit
33789a3523
@@ -1274,11 +1274,7 @@ func (a *App) GetChannelMember(channelId string, userId string) (*model.ChannelM
|
||||
}
|
||||
|
||||
func (a *App) GetChannelMembersPage(channelId string, page, perPage int) (*model.ChannelMembers, *model.AppError) {
|
||||
result := <-a.Srv.Store.Channel().GetMembers(channelId, page*perPage, perPage)
|
||||
if result.Err != nil {
|
||||
return nil, result.Err
|
||||
}
|
||||
return result.Data.(*model.ChannelMembers), nil
|
||||
return a.Srv.Store.Channel().GetMembers(channelId, page*perPage, perPage)
|
||||
}
|
||||
|
||||
func (a *App) GetChannelMembersTimezones(channelId string) ([]string, *model.AppError) {
|
||||
|
||||
@@ -1388,17 +1388,14 @@ func (s SqlChannelStore) UpdateMember(member *model.ChannelMember) store.StoreCh
|
||||
})
|
||||
}
|
||||
|
||||
func (s SqlChannelStore) GetMembers(channelId string, offset, limit int) store.StoreChannel {
|
||||
return store.Do(func(result *store.StoreResult) {
|
||||
var dbMembers channelMemberWithSchemeRolesList
|
||||
_, err := s.GetReplica().Select(&dbMembers, CHANNEL_MEMBERS_WITH_SCHEME_SELECT_QUERY+"WHERE ChannelId = :ChannelId LIMIT :Limit OFFSET :Offset", map[string]interface{}{"ChannelId": channelId, "Limit": limit, "Offset": offset})
|
||||
if err != nil {
|
||||
result.Err = model.NewAppError("SqlChannelStore.GetMembers", "store.sql_channel.get_members.app_error", nil, "channel_id="+channelId+","+err.Error(), http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
func (s SqlChannelStore) GetMembers(channelId string, offset, limit int) (*model.ChannelMembers, *model.AppError) {
|
||||
var dbMembers channelMemberWithSchemeRolesList
|
||||
_, err := s.GetReplica().Select(&dbMembers, CHANNEL_MEMBERS_WITH_SCHEME_SELECT_QUERY+"WHERE ChannelId = :ChannelId LIMIT :Limit OFFSET :Offset", map[string]interface{}{"ChannelId": channelId, "Limit": limit, "Offset": offset})
|
||||
if err != nil {
|
||||
return nil, model.NewAppError("SqlChannelStore.GetMembers", "store.sql_channel.get_members.app_error", nil, "channel_id="+channelId+","+err.Error(), http.StatusInternalServerError)
|
||||
}
|
||||
|
||||
result.Data = dbMembers.ToModel()
|
||||
})
|
||||
return dbMembers.ToModel(), nil
|
||||
}
|
||||
|
||||
func (s SqlChannelStore) GetChannelMembersTimezones(channelId string) ([]model.StringMap, *model.AppError) {
|
||||
|
||||
@@ -159,7 +159,7 @@ type ChannelStore interface {
|
||||
GetForPost(postId string) (*model.Channel, *model.AppError)
|
||||
SaveMember(member *model.ChannelMember) StoreChannel
|
||||
UpdateMember(member *model.ChannelMember) StoreChannel
|
||||
GetMembers(channelId string, offset, limit int) StoreChannel
|
||||
GetMembers(channelId string, offset, limit int) (*model.ChannelMembers, *model.AppError)
|
||||
GetMember(channelId string, userId string) (*model.ChannelMember, *model.AppError)
|
||||
GetChannelMembersTimezones(channelId string) ([]model.StringMap, *model.AppError)
|
||||
GetAllChannelMembersForUser(userId string, allowFromCache bool, includeDeleted bool) StoreChannel
|
||||
|
||||
@@ -153,12 +153,13 @@ func testChannelStoreSaveDirectChannel(t *testing.T, ss store.Store, s SqlSuppli
|
||||
t.Fatal("couldn't save direct channel", err)
|
||||
}
|
||||
|
||||
members := (<-ss.Channel().GetMembers(o1.Id, 0, 100)).Data.(*model.ChannelMembers)
|
||||
members, err := ss.Channel().GetMembers(o1.Id, 0, 100)
|
||||
require.Nil(t, err)
|
||||
if len(*members) != 2 {
|
||||
t.Fatal("should have saved 2 members")
|
||||
}
|
||||
|
||||
if _, err := ss.Channel().SaveDirectChannel(&o1, &m1, &m2); err == nil {
|
||||
if _, err = ss.Channel().SaveDirectChannel(&o1, &m1, &m2); err == nil {
|
||||
t.Fatal("shouldn't be able to update from save")
|
||||
}
|
||||
|
||||
@@ -183,7 +184,7 @@ func testChannelStoreSaveDirectChannel(t *testing.T, ss store.Store, s SqlSuppli
|
||||
o1.Id = ""
|
||||
o1.Name = "zz" + model.NewId() + "b"
|
||||
o1.Type = model.CHANNEL_OPEN
|
||||
if _, err := ss.Channel().SaveDirectChannel(&o1, &m1, &m2); err == nil {
|
||||
if _, err = ss.Channel().SaveDirectChannel(&o1, &m1, &m2); err == nil {
|
||||
t.Fatal("Should not be able to save non-direct channel")
|
||||
}
|
||||
|
||||
@@ -192,11 +193,12 @@ func testChannelStoreSaveDirectChannel(t *testing.T, ss store.Store, s SqlSuppli
|
||||
o1.DisplayName = "Myself"
|
||||
o1.Name = "zz" + model.NewId() + "b"
|
||||
o1.Type = model.CHANNEL_DIRECT
|
||||
if _, err := ss.Channel().SaveDirectChannel(&o1, &m1, &m1); err != nil {
|
||||
if _, err = ss.Channel().SaveDirectChannel(&o1, &m1, &m1); err != nil {
|
||||
t.Fatal("couldn't save direct channel", err)
|
||||
}
|
||||
|
||||
members = (<-ss.Channel().GetMembers(o1.Id, 0, 100)).Data.(*model.ChannelMembers)
|
||||
members, err = ss.Channel().GetMembers(o1.Id, 0, 100)
|
||||
require.Nil(t, err)
|
||||
if len(*members) != 1 {
|
||||
t.Fatal("should have saved just 1 member")
|
||||
}
|
||||
@@ -227,7 +229,8 @@ func testChannelStoreCreateDirectChannel(t *testing.T, ss store.Store) {
|
||||
<-ss.Channel().PermanentDelete(c1.Id)
|
||||
}()
|
||||
|
||||
members := (<-ss.Channel().GetMembers(c1.Id, 0, 100)).Data.(*model.ChannelMembers)
|
||||
members, err := ss.Channel().GetMembers(c1.Id, 0, 100)
|
||||
require.Nil(t, err)
|
||||
if len(*members) != 2 {
|
||||
t.Fatal("should have saved 2 members")
|
||||
}
|
||||
@@ -3395,9 +3398,8 @@ func testChannelStoreRemoveAllDeactivatedMembers(t *testing.T, ss store.Store) {
|
||||
store.Must(ss.Channel().SaveMember(&m3))
|
||||
|
||||
// Get all the channel members. Check there are 3.
|
||||
r1 := <-ss.Channel().GetMembers(c1.Id, 0, 1000)
|
||||
assert.Nil(t, r1.Err)
|
||||
d1 := r1.Data.(*model.ChannelMembers)
|
||||
d1, err := ss.Channel().GetMembers(c1.Id, 0, 1000)
|
||||
assert.Nil(t, err)
|
||||
assert.Len(t, *d1, 3)
|
||||
|
||||
// Deactivate users 1 & 2.
|
||||
@@ -3412,9 +3414,8 @@ func testChannelStoreRemoveAllDeactivatedMembers(t *testing.T, ss store.Store) {
|
||||
assert.Nil(t, ss.Channel().RemoveAllDeactivatedMembers(c1.Id))
|
||||
|
||||
// Get all the channel members. Check there is now only 1: m3.
|
||||
r2 := <-ss.Channel().GetMembers(c1.Id, 0, 1000)
|
||||
assert.Nil(t, r1.Err)
|
||||
d2 := r2.Data.(*model.ChannelMembers)
|
||||
d2, err := ss.Channel().GetMembers(c1.Id, 0, 1000)
|
||||
assert.Nil(t, err)
|
||||
assert.Len(t, *d2, 1)
|
||||
assert.Equal(t, (*d2)[0].UserId, u3.Id)
|
||||
}
|
||||
|
||||
@@ -712,19 +712,28 @@ func (_m *ChannelStore) GetMemberForPost(postId string, userId string) store.Sto
|
||||
}
|
||||
|
||||
// GetMembers provides a mock function with given fields: channelId, offset, limit
|
||||
func (_m *ChannelStore) GetMembers(channelId string, offset int, limit int) store.StoreChannel {
|
||||
func (_m *ChannelStore) GetMembers(channelId string, offset int, limit int) (*model.ChannelMembers, *model.AppError) {
|
||||
ret := _m.Called(channelId, offset, limit)
|
||||
|
||||
var r0 store.StoreChannel
|
||||
if rf, ok := ret.Get(0).(func(string, int, int) store.StoreChannel); ok {
|
||||
var r0 *model.ChannelMembers
|
||||
if rf, ok := ret.Get(0).(func(string, int, int) *model.ChannelMembers); ok {
|
||||
r0 = rf(channelId, offset, limit)
|
||||
} else {
|
||||
if ret.Get(0) != nil {
|
||||
r0 = ret.Get(0).(store.StoreChannel)
|
||||
r0 = ret.Get(0).(*model.ChannelMembers)
|
||||
}
|
||||
}
|
||||
|
||||
return r0
|
||||
var r1 *model.AppError
|
||||
if rf, ok := ret.Get(1).(func(string, int, int) *model.AppError); ok {
|
||||
r1 = rf(channelId, offset, limit)
|
||||
} else {
|
||||
if ret.Get(1) != nil {
|
||||
r1 = ret.Get(1).(*model.AppError)
|
||||
}
|
||||
}
|
||||
|
||||
return r0, r1
|
||||
}
|
||||
|
||||
// GetMembersByIds provides a mock function with given fields: channelId, userIds
|
||||
|
||||
Reference in New Issue
Block a user