summaryrefslogtreecommitdiffstats
path: root/store/storetest
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2018-06-01 12:49:02 +0100
committerGitHub <noreply@github.com>2018-06-01 12:49:02 +0100
commit516a097e1ad588d860b374ef1d0eff202adb286b (patch)
treec6ca77b0ddee05c5fd2b794f09580a65e672ccaf /store/storetest
parent27e7841a734e9c3ed71f988a653f5865d2ef6f91 (diff)
downloadchat-516a097e1ad588d860b374ef1d0eff202adb286b.tar.gz
chat-516a097e1ad588d860b374ef1d0eff202adb286b.tar.bz2
chat-516a097e1ad588d860b374ef1d0eff202adb286b.zip
MM-10757: Default roles from scheme should be keyed by name not ID. (#8894)
* MM-10757: Default roles from scheme should be keyed by name not ID. * Update permissions import/export.
Diffstat (limited to 'store/storetest')
-rw-r--r--store/storetest/scheme_store.go24
-rw-r--r--store/storetest/team_store.go32
2 files changed, 44 insertions, 12 deletions
diff --git a/store/storetest/scheme_store.go b/store/storetest/scheme_store.go
index 39920c109..eb4e8efa0 100644
--- a/store/storetest/scheme_store.go
+++ b/store/storetest/scheme_store.go
@@ -87,25 +87,25 @@ func testSchemeStoreSave(t *testing.T, ss store.Store) {
assert.Len(t, d1.DefaultChannelUserRole, 26)
// Check the default roles were created correctly.
- roleRes1 := <-ss.Role().Get(d1.DefaultTeamAdminRole)
+ roleRes1 := <-ss.Role().GetByName(d1.DefaultTeamAdminRole)
assert.Nil(t, roleRes1.Err)
role1 := roleRes1.Data.(*model.Role)
assert.Equal(t, role1.Permissions, []string{"edit_others_posts", "delete_others_posts"})
assert.True(t, role1.SchemeManaged)
- roleRes2 := <-ss.Role().Get(d1.DefaultTeamUserRole)
+ roleRes2 := <-ss.Role().GetByName(d1.DefaultTeamUserRole)
assert.Nil(t, roleRes2.Err)
role2 := roleRes2.Data.(*model.Role)
assert.Equal(t, role2.Permissions, []string{"view_team", "add_user_to_team"})
assert.True(t, role2.SchemeManaged)
- roleRes3 := <-ss.Role().Get(d1.DefaultChannelAdminRole)
+ roleRes3 := <-ss.Role().GetByName(d1.DefaultChannelAdminRole)
assert.Nil(t, roleRes3.Err)
role3 := roleRes3.Data.(*model.Role)
assert.Equal(t, role3.Permissions, []string{"manage_public_channel_members", "manage_private_channel_members"})
assert.True(t, role3.SchemeManaged)
- roleRes4 := <-ss.Role().Get(d1.DefaultChannelUserRole)
+ roleRes4 := <-ss.Role().GetByName(d1.DefaultChannelUserRole)
assert.Nil(t, roleRes4.Err)
role4 := roleRes4.Data.(*model.Role)
assert.Equal(t, role4.Permissions, []string{"read_channel", "create_post"})
@@ -274,25 +274,25 @@ func testSchemeStoreDelete(t *testing.T, ss store.Store) {
assert.Len(t, d1.DefaultChannelUserRole, 26)
// Check the default roles were created correctly.
- roleRes1 := <-ss.Role().Get(d1.DefaultTeamAdminRole)
+ roleRes1 := <-ss.Role().GetByName(d1.DefaultTeamAdminRole)
assert.Nil(t, roleRes1.Err)
role1 := roleRes1.Data.(*model.Role)
assert.Equal(t, role1.Permissions, []string{"edit_others_posts", "delete_others_posts"})
assert.True(t, role1.SchemeManaged)
- roleRes2 := <-ss.Role().Get(d1.DefaultTeamUserRole)
+ roleRes2 := <-ss.Role().GetByName(d1.DefaultTeamUserRole)
assert.Nil(t, roleRes2.Err)
role2 := roleRes2.Data.(*model.Role)
assert.Equal(t, role2.Permissions, []string{"view_team", "add_user_to_team"})
assert.True(t, role2.SchemeManaged)
- roleRes3 := <-ss.Role().Get(d1.DefaultChannelAdminRole)
+ roleRes3 := <-ss.Role().GetByName(d1.DefaultChannelAdminRole)
assert.Nil(t, roleRes3.Err)
role3 := roleRes3.Data.(*model.Role)
assert.Equal(t, role3.Permissions, []string{"manage_public_channel_members", "manage_private_channel_members"})
assert.True(t, role3.SchemeManaged)
- roleRes4 := <-ss.Role().Get(d1.DefaultChannelUserRole)
+ roleRes4 := <-ss.Role().GetByName(d1.DefaultChannelUserRole)
assert.Nil(t, roleRes4.Err)
role4 := roleRes4.Data.(*model.Role)
assert.Equal(t, role4.Permissions, []string{"read_channel", "create_post"})
@@ -307,22 +307,22 @@ func testSchemeStoreDelete(t *testing.T, ss store.Store) {
assert.NotZero(t, d2.DeleteAt)
// Check that the roles are deleted too.
- roleRes5 := <-ss.Role().Get(d1.DefaultTeamAdminRole)
+ roleRes5 := <-ss.Role().GetByName(d1.DefaultTeamAdminRole)
assert.Nil(t, roleRes5.Err)
role5 := roleRes5.Data.(*model.Role)
assert.NotZero(t, role5.DeleteAt)
- roleRes6 := <-ss.Role().Get(d1.DefaultTeamUserRole)
+ roleRes6 := <-ss.Role().GetByName(d1.DefaultTeamUserRole)
assert.Nil(t, roleRes6.Err)
role6 := roleRes6.Data.(*model.Role)
assert.NotZero(t, role6.DeleteAt)
- roleRes7 := <-ss.Role().Get(d1.DefaultChannelAdminRole)
+ roleRes7 := <-ss.Role().GetByName(d1.DefaultChannelAdminRole)
assert.Nil(t, roleRes7.Err)
role7 := roleRes7.Data.(*model.Role)
assert.NotZero(t, role7.DeleteAt)
- roleRes8 := <-ss.Role().Get(d1.DefaultChannelUserRole)
+ roleRes8 := <-ss.Role().GetByName(d1.DefaultChannelUserRole)
assert.Nil(t, roleRes8.Err)
role8 := roleRes8.Data.(*model.Role)
assert.NotZero(t, role8.DeleteAt)
diff --git a/store/storetest/team_store.go b/store/storetest/team_store.go
index b209b48c4..346b55c18 100644
--- a/store/storetest/team_store.go
+++ b/store/storetest/team_store.go
@@ -12,6 +12,7 @@ import (
"github.com/mattermost/mattermost-server/model"
"github.com/mattermost/mattermost-server/store"
+ "github.com/stretchr/testify/require"
)
func TestTeamStore(t *testing.T, ss store.Store) {
@@ -823,6 +824,37 @@ func testGetTeamMember(t *testing.T, ss store.Store) {
if r := <-ss.Team().GetMember("", m1.UserId); r.Err == nil {
t.Fatal("empty team id - should have failed")
}
+
+ // Test with a custom team scheme.
+ s2 := &model.Scheme{
+ Name: model.NewId(),
+ DisplayName: model.NewId(),
+ Description: model.NewId(),
+ Scope: model.SCHEME_SCOPE_TEAM,
+ }
+ s2 = (<-ss.Scheme().Save(s2)).Data.(*model.Scheme)
+ t.Log(s2)
+
+ t2 := store.Must(ss.Team().Save(&model.Team{
+ DisplayName: "DisplayName",
+ Name: "z-z-z" + model.NewId() + "b",
+ Type: model.TEAM_OPEN,
+ SchemeId: &s2.Id,
+ })).(*model.Team)
+
+ defer func() {
+ <-ss.Team().PermanentDelete(t2.Id)
+ }()
+
+ m2 := &model.TeamMember{TeamId: t2.Id, UserId: model.NewId(), SchemeUser: true}
+ store.Must(ss.Team().SaveMember(m2, -1))
+
+ r2 := <-ss.Team().GetMember(m2.TeamId, m2.UserId)
+ require.Nil(t, r2.Err)
+ m3 := r2.Data.(*model.TeamMember)
+ t.Log(m3)
+
+ assert.Equal(t, s2.DefaultTeamUserRole, m3.Roles)
}
func testGetTeamMembersByIds(t *testing.T, ss store.Store) {