diff options
Diffstat (limited to 'api/channel_test.go')
-rw-r--r-- | api/channel_test.go | 2007 |
1 files changed, 0 insertions, 2007 deletions
diff --git a/api/channel_test.go b/api/channel_test.go deleted file mode 100644 index 2642eb9ff..000000000 --- a/api/channel_test.go +++ /dev/null @@ -1,2007 +0,0 @@ -// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. -// See License.txt for license information. - -package api - -import ( - "net/http" - "strings" - "testing" - "time" - - "github.com/mattermost/mattermost-server/model" - "github.com/mattermost/mattermost-server/store" -) - -func TestCreateChannel(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - th.LoginBasic2() - team2 := th.CreateTeam(th.BasicClient) - th.LoginBasic() - th.BasicClient.SetTeamId(team.Id) - - channel := model.Channel{DisplayName: "Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - rchannel, err := Client.CreateChannel(&channel) - if err != nil { - t.Fatal(err) - } - - if rchannel.Data.(*model.Channel).Name != channel.Name { - t.Fatal("full name didn't match") - } - - rget := Client.Must(Client.GetChannels("")).Data.(*model.ChannelList) - nameMatch := false - for _, c := range *rget { - if c.Name == channel.Name { - nameMatch = true - } - } - - if !nameMatch { - t.Fatal("Did not create channel with correct name") - } - - if _, err := Client.CreateChannel(rchannel.Data.(*model.Channel)); err == nil { - t.Fatal("Cannot create an existing") - } - - savedId := rchannel.Data.(*model.Channel).Id - - rchannel.Data.(*model.Channel).Id = "" - if _, err := Client.CreateChannel(rchannel.Data.(*model.Channel)); err != nil { - if err.Id != "store.sql_channel.save_channel.exists.app_error" { - t.Fatal(err) - } - } - - if _, err := Client.DoApiPost(Client.GetTeamRoute()+"/channels/create", "garbage"); err == nil { - t.Fatal("should have been an error") - } - - Client.DeleteChannel(savedId) - if _, err := Client.CreateChannel(rchannel.Data.(*model.Channel)); err != nil { - if err.Message != "A channel with that URL was previously created" { - t.Fatal(err) - } - } - - channel = model.Channel{DisplayName: "Channel on Different Team", Name: "aaaa" + model.NewId() + "abbb", Type: model.CHANNEL_OPEN, TeamId: team2.Id} - - if _, err := Client.CreateChannel(&channel); err.StatusCode != http.StatusForbidden { - t.Fatal(err) - } - - channel = model.Channel{DisplayName: "Channel With No TeamId", Name: "aaaa" + model.NewId() + "abbb", Type: model.CHANNEL_OPEN, TeamId: ""} - - if _, err := Client.CreateChannel(&channel); err != nil { - t.Fatal(err) - } - - channel = model.Channel{DisplayName: "Test API Name", Name: model.NewId() + "__" + model.NewId(), Type: model.CHANNEL_OPEN, TeamId: team.Id} - - if _, err := Client.CreateChannel(&channel); err == nil { - t.Fatal("Should have errored out on invalid '__' character") - } - - channel = model.Channel{DisplayName: "Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_DIRECT, TeamId: team.Id} - - if _, err := Client.CreateChannel(&channel); err == nil { - t.Fatal("Should have errored out on direct channel type") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.AddPermissionToRole(model.PERMISSION_CREATE_PUBLIC_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_CREATE_PRIVATE_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - - channel2 := &model.Channel{DisplayName: "Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel3 := &model.Channel{DisplayName: "Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - if _, err := Client.CreateChannel(channel2); err != nil { - t.Fatal(err) - } - if _, err := Client.CreateChannel(channel3); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_CREATE_PUBLIC_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_CREATE_PRIVATE_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_CREATE_PUBLIC_CHANNEL.Id, model.TEAM_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_CREATE_PRIVATE_CHANNEL.Id, model.TEAM_ADMIN_ROLE_ID) - - th.LoginBasic2() - channel2.Name = "zz" + model.NewId() + "a" - channel3.Name = "zz" + model.NewId() + "a" - if _, err := Client.CreateChannel(channel2); err == nil { - t.Fatal("should have errored not team admin") - } - if _, err := Client.CreateChannel(channel3); err == nil { - t.Fatal("should have errored not team admin") - } - - th.UpdateUserToTeamAdmin(th.BasicUser, team) - Client.Logout() - th.LoginBasic() - Client.SetTeamId(team.Id) - - if _, err := Client.CreateChannel(channel2); err != nil { - t.Fatal(err) - } - if _, err := Client.CreateChannel(channel3); err != nil { - t.Fatal(err) - } -} - -func TestCreateDirectChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - user := th.BasicUser - user2 := th.BasicUser2 - - var channel *model.Channel - if result, err := Client.CreateDirectChannel(th.BasicUser2.Id); err != nil { - t.Fatal(err) - } else { - channel = result.Data.(*model.Channel) - } - - channelName := "" - if user2.Id > user.Id { - channelName = user.Id + "__" + user2.Id - } else { - channelName = user2.Id + "__" + user.Id - } - - if channel.Name != channelName { - t.Fatal("channel name didn't match") - } - - if channel.Type != model.CHANNEL_DIRECT { - t.Fatal("channel type was not direct") - } - - // Don't fail on direct channels already existing and return the original channel again - if result, err := Client.CreateDirectChannel(th.BasicUser2.Id); err != nil { - t.Fatal(err) - } else if result.Data.(*model.Channel).Id != channel.Id { - t.Fatal("didn't return original direct channel when saving a duplicate") - } - - if _, err := Client.CreateDirectChannel("junk"); err == nil { - t.Fatal("should have failed with bad user id") - } - - if _, err := Client.CreateDirectChannel("12345678901234567890123456"); err == nil { - t.Fatal("should have failed with non-existent user") - } -} - -func TestCreateGroupChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - user := th.BasicUser - user2 := th.BasicUser2 - user3 := th.CreateUser(Client) - - userIds := []string{user.Id, user2.Id, user3.Id} - - var channel *model.Channel - if result, err := Client.CreateGroupChannel(userIds); err != nil { - t.Fatal(err) - } else { - channel = result.Data.(*model.Channel) - } - - if channel.Type != model.CHANNEL_GROUP { - t.Fatal("channel type was not group") - } - - // Don't fail on group channels already existing and return the original channel again - if result, err := Client.CreateGroupChannel(userIds); err != nil { - t.Fatal(err) - } else if result.Data.(*model.Channel).Id != channel.Id { - t.Fatal("didn't return original group channel when saving a duplicate") - } - - if _, err := Client.CreateGroupChannel([]string{user.Id}); err == nil { - t.Fatal("should have failed with not enough users") - } - - if _, err := Client.CreateGroupChannel([]string{}); err == nil { - t.Fatal("should have failed with not enough users") - } - - if _, err := Client.CreateGroupChannel([]string{user.Id, user2.Id, user3.Id, "junk"}); err == nil { - t.Fatal("should have failed with non-existent user") - } -} - -func TestUpdateChannel(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.SystemAdminClient - team := th.SystemAdminTeam - sysAdminUser := th.SystemAdminUser - user := th.CreateUser(Client) - th.LinkUserToTeam(user, team) - user2 := th.CreateUser(Client) - th.LinkUserToTeam(user2, team) - - Client.Login(user.Email, user.Password) - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - Client.AddChannelMember(channel1.Id, user.Id) - - header := "zz" + model.NewId() + "a" - purpose := "zz" + model.NewId() + "a" - upChannel1 := &model.Channel{Id: channel1.Id, Header: header, Purpose: purpose} - upChannel1 = Client.Must(Client.UpdateChannel(upChannel1)).Data.(*model.Channel) - - if upChannel1.Header != header { - t.Fatal("Channel admin failed to update header") - } - - if upChannel1.Purpose != purpose { - t.Fatal("Channel admin failed to update purpose") - } - - if upChannel1.DisplayName != channel1.DisplayName { - t.Fatal("Channel admin failed to skip displayName") - } - - rget := Client.Must(Client.GetChannels("")) - channels := rget.Data.(*model.ChannelList) - for _, c := range *channels { - if c.Name == model.DEFAULT_CHANNEL { - c.Header = "new header" - c.Name = "pseudo-square" - if _, err := Client.UpdateChannel(c); err == nil { - t.Fatal("should have errored on updating default channel name") - } - break - } - } - - Client.Login(user2.Email, user2.Password) - - if _, err := Client.UpdateChannel(upChannel1); err == nil { - t.Fatal("Standard User should have failed to update") - } - - Client.Must(Client.JoinChannel(channel1.Id)) - th.UpdateUserToTeamAdmin(user2, team) - - Client.Logout() - Client.Login(user2.Email, user2.Password) - Client.SetTeamId(team.Id) - - if _, err := Client.UpdateChannel(upChannel1); err != nil { - t.Fatal(err) - } - - Client.Login(sysAdminUser.Email, sysAdminUser.Password) - th.LinkUserToTeam(sysAdminUser, team) - Client.Must(Client.JoinChannel(channel1.Id)) - - if _, err := Client.UpdateChannel(upChannel1); err != nil { - t.Fatal(err) - } - - Client.Must(Client.DeleteChannel(channel1.Id)) - - if _, err := Client.UpdateChannel(upChannel1); err == nil { - t.Fatal("should have failed - channel deleted") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - - channel2 := th.CreateChannel(Client, team) - channel3 := th.CreatePrivateChannel(Client, team) - - th.LinkUserToTeam(th.BasicUser, team) - - Client.Must(Client.AddChannelMember(channel2.Id, th.BasicUser.Id)) - Client.Must(Client.AddChannelMember(channel3.Id, th.BasicUser.Id)) - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.UpdateChannel(channel2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannel(channel3); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - - th.MakeUserChannelUser(th.BasicUser, channel2) - th.MakeUserChannelUser(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannel(channel2); err == nil { - t.Fatal("should have errored not channel admin") - } - if _, err := Client.UpdateChannel(channel3); err == nil { - t.Fatal("should have errored not channel admin") - } - - th.MakeUserChannelAdmin(th.BasicUser, channel2) - th.MakeUserChannelAdmin(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannel(channel2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannel(channel3); err != nil { - t.Fatal(err) - } -} - -func TestUpdateChannelDisplayName(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.SystemAdminClient - team := th.SystemAdminTeam - user := th.CreateUser(Client) - th.LinkUserToTeam(user, team) - - Client.Login(user.Email, user.Password) - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - Client.AddChannelMember(channel1.Id, user.Id) - - newDisplayName := "a" + channel1.DisplayName + "a" - channel1.DisplayName = newDisplayName - channel1 = Client.Must(Client.UpdateChannel(channel1)).Data.(*model.Channel) - - time.Sleep(100 * time.Millisecond) - - r1 := Client.Must(Client.GetPosts(channel1.Id, 0, 1, "")).Data.(*model.PostList) - if len(r1.Order) != 1 { - t.Fatal("Displayname update system message was not found") - } -} - -func TestUpdateChannelHeader(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - data := make(map[string]string) - data["channel_id"] = channel1.Id - data["channel_header"] = "new header" - - var upChannel1 *model.Channel - if result, err := Client.UpdateChannelHeader(data); err != nil { - t.Fatal(err) - } else { - upChannel1 = result.Data.(*model.Channel) - } - - time.Sleep(100 * time.Millisecond) - - r1 := Client.Must(Client.GetPosts(channel1.Id, 0, 1, "")).Data.(*model.PostList) - if len(r1.Order) != 1 { - t.Fatal("Header update system message was not found") - } else if val, ok := r1.Posts[r1.Order[0]].Props["old_header"]; !ok || val != "" { - t.Fatal("Props should contain old_header with old header value") - } else if val, ok := r1.Posts[r1.Order[0]].Props["new_header"]; !ok || val != "new header" { - t.Fatal("Props should contain new_header with new header value") - } - - if upChannel1.Header != data["channel_header"] { - t.Fatal("Failed to update header") - } - - data["channel_id"] = "junk" - if _, err := Client.UpdateChannelHeader(data); err == nil { - t.Fatal("should have errored on junk channel id") - } - - data["channel_id"] = "12345678901234567890123456" - if _, err := Client.UpdateChannelHeader(data); err == nil { - t.Fatal("should have errored on non-existent channel id") - } - - data["channel_id"] = channel1.Id - data["channel_header"] = strings.Repeat("a", 1050) - if _, err := Client.UpdateChannelHeader(data); err == nil { - t.Fatal("should have errored on bad channel header") - } - - rchannel := Client.Must(Client.CreateDirectChannel(th.BasicUser2.Id)).Data.(*model.Channel) - data["channel_id"] = rchannel.Id - data["channel_header"] = "new header" - var upChanneld *model.Channel - if result, err := Client.UpdateChannelHeader(data); err != nil { - t.Fatal(err) - } else { - upChanneld = result.Data.(*model.Channel) - } - - if upChanneld.Header != data["channel_header"] { - t.Fatal("Failed to update header") - } - - th.LoginBasic2() - - data["channel_id"] = channel1.Id - data["channel_header"] = "new header" - if _, err := Client.UpdateChannelHeader(data); err == nil { - t.Fatal("should have errored non-channel member trying to update header") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - - th.LoginBasic() - channel2 := th.CreateChannel(Client, team) - channel3 := th.CreatePrivateChannel(Client, team) - - data2 := make(map[string]string) - data2["channel_id"] = channel2.Id - data2["channel_header"] = "new header" - - data3 := make(map[string]string) - data3["channel_id"] = channel3.Id - data3["channel_header"] = "new header" - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.UpdateChannelHeader(data2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannelHeader(data3); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - - th.MakeUserChannelUser(th.BasicUser, channel2) - th.MakeUserChannelUser(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannelHeader(data2); err == nil { - t.Fatal("should have errored not channel admin") - } - if _, err := Client.UpdateChannelHeader(data3); err == nil { - t.Fatal("should have errored not channel admin") - } - - th.MakeUserChannelAdmin(th.BasicUser, channel2) - th.MakeUserChannelAdmin(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannelHeader(data2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannelHeader(data3); err != nil { - t.Fatal(err) - } -} - -func TestUpdateChannelPurpose(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - data := make(map[string]string) - data["channel_id"] = channel1.Id - data["channel_purpose"] = "new purpose" - - var upChannel1 *model.Channel - if result, err := Client.UpdateChannelPurpose(data); err != nil { - t.Fatal(err) - } else { - upChannel1 = result.Data.(*model.Channel) - } - - time.Sleep(100 * time.Millisecond) - - r1 := Client.Must(Client.GetPosts(channel1.Id, 0, 1, "")).Data.(*model.PostList) - if len(r1.Order) != 1 { - t.Fatal("Purpose update system message was not found") - } else if val, ok := r1.Posts[r1.Order[0]].Props["old_purpose"]; !ok || val != "" { - t.Fatal("Props should contain old_header with old purpose value") - } else if val, ok := r1.Posts[r1.Order[0]].Props["new_purpose"]; !ok || val != "new purpose" { - t.Fatal("Props should contain new_header with new purpose value") - } - - if upChannel1.Purpose != data["channel_purpose"] { - t.Fatal("Failed to update purpose") - } - - data["channel_id"] = "junk" - if _, err := Client.UpdateChannelPurpose(data); err == nil { - t.Fatal("should have errored on junk channel id") - } - - data["channel_id"] = "12345678901234567890123456" - if _, err := Client.UpdateChannelPurpose(data); err == nil { - t.Fatal("should have errored on non-existent channel id") - } - - data["channel_id"] = channel1.Id - data["channel_purpose"] = strings.Repeat("a", 350) - if _, err := Client.UpdateChannelPurpose(data); err == nil { - t.Fatal("should have errored on bad channel purpose") - } - - th.LoginBasic2() - - data["channel_id"] = channel1.Id - data["channel_purpose"] = "new purpose" - if _, err := Client.UpdateChannelPurpose(data); err == nil { - t.Fatal("should have errored non-channel member trying to update purpose") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.TEAM_USER_ROLE_ID) - - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - - th.LoginBasic() - channel2 := th.CreateChannel(Client, team) - channel3 := th.CreatePrivateChannel(Client, team) - - data2 := make(map[string]string) - data2["channel_id"] = channel2.Id - data2["channel_purpose"] = "new purpose" - - data3 := make(map[string]string) - data3["channel_id"] = channel3.Id - data3["channel_purpose"] = "new purpose" - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.UpdateChannelPurpose(data2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannelPurpose(data3); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_PROPERTIES.Id, model.CHANNEL_ADMIN_ROLE_ID) - - th.MakeUserChannelUser(th.BasicUser, channel2) - th.MakeUserChannelUser(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannelPurpose(data2); err == nil { - t.Fatal("should have errored not channel admin") - } - if _, err := Client.UpdateChannelPurpose(data3); err == nil { - t.Fatal("should have errored not channel admin") - } - - th.MakeUserChannelAdmin(th.BasicUser, channel2) - th.MakeUserChannelAdmin(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.UpdateChannelPurpose(data2); err != nil { - t.Fatal(err) - } - if _, err := Client.UpdateChannelPurpose(data3); err != nil { - t.Fatal(err) - } -} - -func TestGetChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - team2 := th.CreateTeam(Client) - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - rget := Client.Must(Client.GetChannels("")) - channels := rget.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - - if (*channels)[1].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - - // test etag caching - if cache_result, err := Client.GetChannels(rget.Etag); err != nil { - t.Fatal(err) - } else if cache_result.Data.(*model.ChannelList) != nil { - t.Log(cache_result.Data) - t.Fatal("cache should be empty") - } - - view := model.ChannelView{ChannelId: channel2.Id, PrevChannelId: channel1.Id} - if _, resp := Client.ViewChannel(view); resp.Error != nil { - t.Fatal(resp.Error) - } - - if resp, err := Client.GetChannel(channel1.Id, ""); err != nil { - t.Fatal(err) - } else { - data := resp.Data.(*model.ChannelData) - if data.Channel.DisplayName != channel1.DisplayName { - t.Fatal("name didn't match") - } - - // test etag caching - if cache_result, err := Client.GetChannel(channel1.Id, resp.Etag); err != nil { - t.Fatal(err) - } else if cache_result.Data.(*model.ChannelData) != nil { - t.Log(cache_result.Data) - t.Fatal("cache should be empty") - } - } - - if _, err := Client.GetChannel("junk", ""); err == nil { - t.Fatal("should have failed - bad channel id") - } - - th.BasicClient.SetTeamId(team2.Id) - if _, err := Client.GetChannel(channel2.Id, ""); err == nil { - t.Fatal("should have failed - wrong team") - } - - //Test if a wrong team id is supplied should return error - if _, err := Client.CreateDirectChannel(th.BasicUser2.Id); err != nil { - t.Fatal(err) - } - - th.BasicClient.SetTeamId("nonexitingteamid") - if _, err := Client.GetChannels(""); err == nil { - t.Fatal("should have failed - wrong team id") - } -} - -func TestGetMoreChannelsPage(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "b" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - channel3 := &model.Channel{DisplayName: "C Test API Name", Name: "c" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel3 = Client.Must(Client.CreateChannel(channel3)).Data.(*model.Channel) - - th.LoginBasic2() - - if r, err := Client.GetMoreChannelsPage(0, 100); err != nil { - t.Fatal(err) - } else { - channels := r.Data.(*model.ChannelList) - - // 1 for BasicChannel, 1 for PinnedPostChannel, 2 for open channels created above - if len(*channels) != 4 { - t.Fatal("wrong length") - } - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - - if (*channels)[1].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - } - - if r, err := Client.GetMoreChannelsPage(0, 1); err != nil { - t.Fatal(err) - } else { - channels := r.Data.(*model.ChannelList) - - if len(*channels) != 1 { - t.Fatal("wrong length") - } - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - } - - if r, err := Client.GetMoreChannelsPage(1, 1); err != nil { - t.Fatal(err) - } else { - channels := r.Data.(*model.ChannelList) - - if len(*channels) != 1 { - t.Fatal("wrong length") - } - - if (*channels)[0].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - } - - Client.SetTeamId("junk") - if _, err := Client.GetMoreChannelsPage(0, 1); err == nil { - t.Fatal("should have failed - bad team id") - } -} - -func TestGetChannelCounts(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - if result, err := Client.GetChannelCounts(""); err != nil { - t.Fatal(err) - } else { - counts := result.Data.(*model.ChannelCounts) - - if len(counts.Counts) != 6 { - t.Fatal("wrong number of channel counts") - } - - if len(counts.UpdateTimes) != 6 { - t.Fatal("wrong number of channel update times") - } - - if cache_result, err := Client.GetChannelCounts(result.Etag); err != nil { - t.Fatal(err) - } else if cache_result.Data.(*model.ChannelCounts) != nil { - t.Log(cache_result.Data) - t.Fatal("result data should be empty") - } - } - -} - -func TestGetMyChannelMembers(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - if result, err := Client.GetMyChannelMembers(); err != nil { - t.Fatal(err) - } else { - members := result.Data.(*model.ChannelMembers) - - // town-square, off-topic, basic test channel, pinned post channel, channel1, channel2 - if len(*members) != 6 { - t.Fatal("wrong number of members", len(*members)) - } - } - -} - -func TestJoinChannelById(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel3 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel3 = Client.Must(Client.CreateChannel(channel3)).Data.(*model.Channel) - - th.LoginBasic2() - - Client.Must(Client.JoinChannel(channel1.Id)) - - if _, err := Client.JoinChannel(channel3.Id); err == nil { - t.Fatal("shouldn't be able to join secret group") - } - - rchannel := Client.Must(Client.CreateDirectChannel(th.BasicUser.Id)).Data.(*model.Channel) - - user3 := th.CreateUser(th.BasicClient) - th.LinkUserToTeam(user3, team) - Client.Must(Client.Login(user3.Email, "Password1")) - - if _, err := Client.JoinChannel(rchannel.Id); err == nil { - t.Fatal("shoudn't be able to join direct channel") - } - - th.LoginBasic() - - if _, err := Client.JoinChannel(channel1.Id); err != nil { - t.Fatal("should be able to join public channel that we're a member of") - } - - if _, err := Client.JoinChannel(channel3.Id); err != nil { - t.Fatal("should be able to join private channel that we're a member of") - } - - if _, err := Client.JoinChannel(rchannel.Id); err != nil { - t.Fatal("should be able to join direct channel that we're a member of") - } -} - -func TestJoinChannelByName(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel3 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel3 = Client.Must(Client.CreateChannel(channel3)).Data.(*model.Channel) - - th.LoginBasic2() - - Client.Must(Client.JoinChannelByName(channel1.Name)) - - if _, err := Client.JoinChannelByName(channel3.Name); err == nil { - t.Fatal("shouldn't be able to join secret group") - } - - rchannel := Client.Must(Client.CreateDirectChannel(th.BasicUser.Id)).Data.(*model.Channel) - - user3 := th.CreateUser(th.BasicClient) - th.LinkUserToTeam(user3, team) - Client.Must(Client.Login(user3.Email, "Password1")) - - if _, err := Client.JoinChannelByName(rchannel.Name); err == nil { - t.Fatal("shoudn't be able to join direct channel") - } - - th.LoginBasic() - - if _, err := Client.JoinChannelByName(channel1.Name); err != nil { - t.Fatal("should be able to join public channel that we're a member of") - } - - if _, err := Client.JoinChannelByName(channel3.Name); err != nil { - t.Fatal("should be able to join private channel that we're a member of") - } - - if _, err := Client.JoinChannelByName(rchannel.Name); err != nil { - t.Fatal("should be able to join direct channel that we're a member of") - } -} - -func TestJoinChannelByNameDisabledUser(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - Client.Must(th.BasicClient.RemoveUserFromTeam(th.BasicTeam.Id, th.BasicUser.Id)) - - if _, err := th.App.AddUserToChannel(th.BasicUser, channel1); err == nil { - t.Fatal("shoudn't be able to join channel") - } else { - if err.Id != "api.channel.add_user.to.channel.failed.deleted.app_error" { - t.Fatal("wrong error") - } - } -} - -func TestLeaveChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel3 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel3 = Client.Must(Client.CreateChannel(channel3)).Data.(*model.Channel) - - th.LoginBasic2() - - Client.Must(Client.JoinChannel(channel1.Id)) - - // Cannot leave a the private group if you are the only member - if _, err := Client.LeaveChannel(channel3.Id); err == nil { - t.Fatal("should have errored, cannot leave private group if only one member") - } - - rchannel := Client.Must(Client.CreateDirectChannel(th.BasicUser.Id)).Data.(*model.Channel) - - if _, err := Client.LeaveChannel(rchannel.Id); err == nil { - t.Fatal("should have errored, cannot leave direct channel") - } - - rget := Client.Must(Client.GetChannels("")) - cdata := rget.Data.(*model.ChannelList) - for _, c := range *cdata { - if c.Name == model.DEFAULT_CHANNEL { - if _, err := Client.LeaveChannel(c.Id); err == nil { - t.Fatal("should have errored on leaving default channel") - } - break - } - } -} - -func TestDeleteChannel(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.SystemAdminClient - team := th.SystemAdminTeam - userSystemAdmin := th.SystemAdminUser - userTeamAdmin := th.CreateUser(Client) - th.LinkUserToTeam(userTeamAdmin, team) - user2 := th.CreateUser(Client) - th.LinkUserToTeam(user2, team) - - Client.Login(user2.Email, user2.Password) - - channelMadeByCA := &model.Channel{DisplayName: "C Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channelMadeByCA = Client.Must(Client.CreateChannel(channelMadeByCA)).Data.(*model.Channel) - - Client.AddChannelMember(channelMadeByCA.Id, userTeamAdmin.Id) - - Client.Login(userTeamAdmin.Email, "pwd") - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - if _, err := Client.DeleteChannel(channel1.Id); err != nil { - t.Fatal(err) - } - - if _, err := Client.DeleteChannel(channelMadeByCA.Id); err != nil { - t.Fatal("Team admin failed to delete Channel Admin's channel") - } - - post1 := &model.Post{ChannelId: channel1.Id, Message: "zz" + model.NewId() + "a"} - if _, err := Client.CreatePost(post1); err == nil { - t.Fatal("should have failed to post to deleted channel") - } - - userStd := th.CreateUser(Client) - th.LinkUserToTeam(userStd, team) - Client.Login(userStd.Email, userStd.Password) - - if _, err := Client.JoinChannel(channel1.Id); err == nil { - t.Fatal("should have failed to join deleted channel") - } - - Client.Must(Client.JoinChannel(channel2.Id)) - - if _, err := Client.DeleteChannel(channel2.Id); err != nil { - t.Fatal(err) - } - - rget := Client.Must(Client.GetChannels("")) - cdata := rget.Data.(*model.ChannelList) - for _, c := range *cdata { - if c.Name == model.DEFAULT_CHANNEL { - if _, err := Client.DeleteChannel(c.Id); err == nil { - t.Fatal("should have errored on deleting default channel") - } - break - } - } - - th.UpdateUserToTeamAdmin(userStd, team) - - Client.Logout() - Client.Login(userStd.Email, userStd.Password) - Client.SetTeamId(team.Id) - - channel2 = th.CreateChannel(Client, team) - - if _, err := Client.DeleteChannel(channel2.Id); err != nil { - t.Fatal(err) - } - - channel3 := &model.Channel{DisplayName: "B Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel3 = Client.Must(Client.CreateChannel(channel3)).Data.(*model.Channel) - - Client.Login(userSystemAdmin.Email, userSystemAdmin.Password) - Client.Must(Client.JoinChannel(channel3.Id)) - - if _, err := Client.DeleteChannel(channel3.Id); err != nil { - t.Fatal(err) - } - - if _, err := Client.DeleteChannel(channel3.Id); err == nil { - t.Fatal("should have failed - channel already deleted") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.AddPermissionToRole(model.PERMISSION_DELETE_PUBLIC_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_DELETE_PRIVATE_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - - th.LoginSystemAdmin() - th.LinkUserToTeam(th.BasicUser, team) - - channel2 = th.CreateChannel(Client, team) - channel3 = th.CreatePrivateChannel(Client, team) - channel4 := th.CreateChannel(Client, team) - Client.Must(Client.AddChannelMember(channel2.Id, th.BasicUser.Id)) - Client.Must(Client.AddChannelMember(channel3.Id, th.BasicUser.Id)) - Client.Must(Client.AddChannelMember(channel4.Id, th.BasicUser.Id)) - Client.Must(Client.LeaveChannel(channel4.Id)) - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.DeleteChannel(channel2.Id); err != nil { - t.Fatal(err) - } - if _, err := Client.DeleteChannel(channel3.Id); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_DELETE_PUBLIC_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_DELETE_PRIVATE_CHANNEL.Id, model.TEAM_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_DELETE_PUBLIC_CHANNEL.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_DELETE_PRIVATE_CHANNEL.Id, model.CHANNEL_ADMIN_ROLE_ID) - - th.LoginSystemAdmin() - - channel2 = th.CreateChannel(Client, team) - channel3 = th.CreatePrivateChannel(Client, team) - Client.Must(Client.AddChannelMember(channel2.Id, th.BasicUser.Id)) - Client.Must(Client.AddChannelMember(channel3.Id, th.BasicUser.Id)) - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.DeleteChannel(channel2.Id); err == nil { - t.Fatal("should have errored not channel admin") - } - if _, err := Client.DeleteChannel(channel3.Id); err == nil { - t.Fatal("should have errored not channel admin") - } - - th.MakeUserChannelAdmin(th.BasicUser, channel2) - th.MakeUserChannelAdmin(th.BasicUser, channel3) - th.App.Srv.Store.Channel().ClearCaches() - - if _, err := Client.DeleteChannel(channel2.Id); err != nil { - t.Fatal(err) - } - if _, err := Client.DeleteChannel(channel3.Id); err != nil { - t.Fatal(err) - } - - th.LoginSystemAdmin() - - channel2 = th.CreateChannel(Client, team) - channel3 = th.CreatePrivateChannel(Client, team) - Client.Must(Client.AddChannelMember(channel2.Id, th.BasicUser.Id)) - Client.Must(Client.AddChannelMember(channel3.Id, th.BasicUser.Id)) - - Client.Login(th.BasicUser.Email, th.BasicUser.Password) - - if _, err := Client.DeleteChannel(channel2.Id); err == nil { - t.Fatal("should have errored not system admin") - } - if _, err := Client.DeleteChannel(channel3.Id); err == nil { - t.Fatal("should have errored not system admin") - } - - if _, err := Client.DeleteChannel(channel4.Id); err == nil { - t.Fatal("Should not be able to delete channel, even though only one user is left") - } - - th.LoginSystemAdmin() - - if _, err := Client.DeleteChannel(channel2.Id); err != nil { - t.Fatal(err) - } - if _, err := Client.DeleteChannel(channel3.Id); err != nil { - t.Fatal(err) - } -} - -func TestGetChannelStats(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - rget := Client.Must(Client.GetChannelStats(channel1.Id, "")) - data := rget.Data.(*model.ChannelStats) - if data.ChannelId != channel1.Id { - t.Fatal("couldnt't get extra info") - } else if data.MemberCount != 1 { - t.Fatal("got incorrect member count") - } -} - -func TestAddChannelMember(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - user1 := th.BasicUser - user2 := th.BasicUser2 - user3 := th.CreateUser(Client) - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - if _, err := Client.AddChannelMember(channel1.Id, user2.Id); err != nil { - t.Fatal(err) - } - - if _, err := Client.AddChannelMember(channel1.Id, "dsgsdg"); err == nil { - t.Fatal("Should have errored, bad user id") - } - - if _, err := Client.AddChannelMember(channel1.Id, "12345678901234567890123456"); err == nil { - t.Fatal("Should have errored, bad user id") - } - - if _, err := Client.AddChannelMember(channel1.Id, user2.Id); err != nil { - t.Fatal(err) - } - - if _, err := Client.AddChannelMember("sgdsgsdg", user2.Id); err == nil { - t.Fatal("Should have errored, bad channel id") - } - - channel2 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - th.LoginBasic2() - - if _, err := Client.AddChannelMember(channel2.Id, user2.Id); err == nil { - t.Fatal("Should have errored, user not in channel") - } - - th.LoginBasic() - - Client.Must(Client.DeleteChannel(channel2.Id)) - - if _, err := Client.AddChannelMember(channel2.Id, user2.Id); err == nil { - t.Fatal("Should have errored, channel deleted") - } - - if _, err := Client.AddChannelMember(channel1.Id, user3.Id); err == nil { - t.Fatal("Should have errored, user not on team") - } - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - - // Check that a regular channel user can add other users. - channel4 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel4 = Client.Must(th.SystemAdminClient.CreateChannel(channel4)).Data.(*model.Channel) - Client.Must(th.SystemAdminClient.AddChannelMember(channel4.Id, user1.Id)) - if _, err := Client.AddChannelMember(channel4.Id, user2.Id); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_ADMIN_ROLE_ID) - - channel5 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel5 = Client.Must(th.SystemAdminClient.CreateChannel(channel5)).Data.(*model.Channel) - Client.Must(th.SystemAdminClient.AddChannelMember(channel5.Id, user1.Id)) - if _, err := Client.AddChannelMember(channel5.Id, user2.Id); err == nil { - t.Fatal("Should have failed due to permissions") - } - - th.MakeUserChannelAdmin(user1, channel5) - th.App.InvalidateAllCaches() - - if _, err := Client.AddChannelMember(channel5.Id, user2.Id); err != nil { - t.Fatal(err) - } -} - -func TestRemoveChannelMember(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - user1 := th.BasicUser - user2 := th.BasicUser2 - th.UpdateUserToTeamAdmin(user2, team) - - channelMadeByCA := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channelMadeByCA = Client.Must(Client.CreateChannel(channelMadeByCA)).Data.(*model.Channel) - - Client.Must(Client.AddChannelMember(channelMadeByCA.Id, user2.Id)) - - th.LoginBasic2() - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - userStd := th.CreateUser(th.BasicClient) - th.LinkUserToTeam(userStd, team) - - Client.Must(Client.AddChannelMember(channel1.Id, userStd.Id)) - - Client.Must(Client.AddChannelMember(channelMadeByCA.Id, userStd.Id)) - - if _, err := Client.RemoveChannelMember(channel1.Id, "dsgsdg"); err == nil { - t.Fatal("Should have errored, bad user id") - } - - if _, err := Client.RemoveChannelMember("sgdsgsdg", userStd.Id); err == nil { - t.Fatal("Should have errored, bad channel id") - } - - if _, err := Client.RemoveChannelMember(channel1.Id, userStd.Id); err != nil { - t.Fatal(err) - } - - if _, err := Client.RemoveChannelMember(channelMadeByCA.Id, userStd.Id); err != nil { - t.Fatal("Team Admin failed to remove member from Channel Admin's channel") - } - - channel2 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - Client.Login(userStd.Email, userStd.Password) - - if _, err := Client.RemoveChannelMember(channel2.Id, userStd.Id); err == nil { - t.Fatal("Should have errored, user not channel admin") - } - - th.LoginBasic2() - Client.Must(Client.AddChannelMember(channel2.Id, userStd.Id)) - - Client.Must(Client.DeleteChannel(channel2.Id)) - - if _, err := Client.RemoveChannelMember(channel2.Id, userStd.Id); err == nil { - t.Fatal("Should have errored, channel deleted") - } - - townSquare := Client.Must(Client.GetChannelByName("town-square")).Data.(*model.Channel) - - if _, err := Client.RemoveChannelMember(townSquare.Id, userStd.Id); err == nil { - t.Fatal("should have errored, channel is default") - } - - th.LoginBasic() - - // Check the appropriate permissions are enforced. - defaultRolePermissions := th.SaveDefaultRolePermissions() - defer func() { - th.RestoreDefaultRolePermissions(defaultRolePermissions) - }() - - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - - // Check that a regular channel user can remove other users. - channel4 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel4 = Client.Must(th.SystemAdminClient.CreateChannel(channel4)).Data.(*model.Channel) - Client.Must(th.SystemAdminClient.AddChannelMember(channel4.Id, user1.Id)) - Client.Must(th.SystemAdminClient.AddChannelMember(channel4.Id, user2.Id)) - if _, err := Client.RemoveChannelMember(channel4.Id, user2.Id); err != nil { - t.Fatal(err) - } - - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.RemovePermissionFromRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_USER_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PUBLIC_CHANNEL_MEMBERS.Id, model.CHANNEL_ADMIN_ROLE_ID) - th.AddPermissionToRole(model.PERMISSION_MANAGE_PRIVATE_CHANNEL_MEMBERS.Id, model.CHANNEL_ADMIN_ROLE_ID) - - channel5 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel5 = Client.Must(th.SystemAdminClient.CreateChannel(channel5)).Data.(*model.Channel) - Client.Must(th.SystemAdminClient.AddChannelMember(channel5.Id, user1.Id)) - Client.Must(th.SystemAdminClient.AddChannelMember(channel5.Id, user2.Id)) - if _, err := Client.RemoveChannelMember(channel5.Id, user2.Id); err == nil { - t.Fatal("Should have failed due to permissions") - } - - th.MakeUserChannelAdmin(user1, channel5) - th.App.InvalidateAllCaches() - - if _, err := Client.RemoveChannelMember(channel5.Id, user2.Id); err != nil { - t.Fatal(err) - } -} - -func TestUpdateNotifyProps(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - user := th.BasicUser - user2 := th.BasicUser2 - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - data := make(map[string]string) - data["channel_id"] = channel1.Id - data["user_id"] = user.Id - data[model.DESKTOP_NOTIFY_PROP] = model.CHANNEL_NOTIFY_MENTION - - //timeBeforeUpdate := model.GetMillis() - time.Sleep(100 * time.Millisecond) - - // test updating desktop - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.DESKTOP_NOTIFY_PROP] != model.CHANNEL_NOTIFY_MENTION { - t.Fatal("NotifyProps[\"desktop\"] did not update properly") - } else if notifyProps[model.MARK_UNREAD_NOTIFY_PROP] != model.CHANNEL_MARK_UNREAD_ALL { - t.Fatalf("NotifyProps[\"mark_unread\"] changed to %v", notifyProps[model.MARK_UNREAD_NOTIFY_PROP]) - } - - // test an empty update - delete(data, model.DESKTOP_NOTIFY_PROP) - - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.MARK_UNREAD_NOTIFY_PROP] != model.CHANNEL_MARK_UNREAD_ALL { - t.Fatalf("NotifyProps[\"mark_unread\"] changed to %v", notifyProps[model.MARK_UNREAD_NOTIFY_PROP]) - } else if notifyProps[model.DESKTOP_NOTIFY_PROP] != model.CHANNEL_NOTIFY_MENTION { - t.Fatalf("NotifyProps[\"desktop\"] changed to %v", notifyProps[model.DESKTOP_NOTIFY_PROP]) - } - - // test updating mark unread - data[model.MARK_UNREAD_NOTIFY_PROP] = model.CHANNEL_MARK_UNREAD_MENTION - - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.MARK_UNREAD_NOTIFY_PROP] != model.CHANNEL_MARK_UNREAD_MENTION { - t.Fatal("NotifyProps[\"mark_unread\"] did not update properly") - } else if notifyProps[model.DESKTOP_NOTIFY_PROP] != model.CHANNEL_NOTIFY_MENTION { - t.Fatalf("NotifyProps[\"desktop\"] changed to %v", notifyProps[model.DESKTOP_NOTIFY_PROP]) - } - - // test updating both - data[model.DESKTOP_NOTIFY_PROP] = model.CHANNEL_NOTIFY_NONE - data[model.MARK_UNREAD_NOTIFY_PROP] = model.CHANNEL_MARK_UNREAD_MENTION - - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.DESKTOP_NOTIFY_PROP] != model.CHANNEL_NOTIFY_NONE { - t.Fatal("NotifyProps[\"desktop\"] did not update properly") - } else if notifyProps[model.MARK_UNREAD_NOTIFY_PROP] != model.CHANNEL_MARK_UNREAD_MENTION { - t.Fatal("NotifyProps[\"mark_unread\"] did not update properly") - } - - // test updating push notification preferences - delete(data, model.DESKTOP_NOTIFY_PROP) - delete(data, model.MARK_UNREAD_NOTIFY_PROP) - data[model.PUSH_NOTIFY_PROP] = model.CHANNEL_NOTIFY_MENTION - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.PUSH_NOTIFY_PROP] != model.CHANNEL_NOTIFY_MENTION { - t.Fatal("NotifyProps[\"push\"] did not update properly") - } - - // test updating email preferences - delete(data, model.PUSH_NOTIFY_PROP) - data[model.EMAIL_NOTIFY_PROP] = "true" - if result, err := Client.UpdateNotifyProps(data); err != nil { - t.Fatal(err) - } else if notifyProps := result.Data.(map[string]string); notifyProps[model.EMAIL_NOTIFY_PROP] != "true" { - t.Fatal("NotifyProps[\"email\"] did not update properly") - } - - // test error cases - data["user_id"] = "junk" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad user id") - } - - data["user_id"] = "12345678901234567890123456" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad user id") - } - - data["user_id"] = user.Id - data["channel_id"] = "junk" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad channel id") - } - - data["channel_id"] = "12345678901234567890123456" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad channel id") - } - - data[model.DESKTOP_NOTIFY_PROP] = "junk" - data[model.MARK_UNREAD_NOTIFY_PROP] = model.CHANNEL_MARK_UNREAD_ALL - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad desktop notify level") - } - - data[model.DESKTOP_NOTIFY_PROP] = model.CHANNEL_NOTIFY_ALL - data[model.MARK_UNREAD_NOTIFY_PROP] = "junk" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad mark unread level") - } - - data[model.DESKTOP_NOTIFY_PROP] = model.CHANNEL_NOTIFY_ALL - data[model.MARK_UNREAD_NOTIFY_PROP] = model.CHANNEL_MARK_UNREAD_ALL - data[model.PUSH_NOTIFY_PROP] = "junk" - data[model.EMAIL_NOTIFY_PROP] = "true" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad push level") - } - - data[model.PUSH_NOTIFY_PROP] = model.CHANNEL_NOTIFY_ALL - data[model.EMAIL_NOTIFY_PROP] = "junk" - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - bad email notification option") - } - - th.LoginBasic2() - - data["channel_id"] = channel1.Id - data["user_id"] = user2.Id - data[model.DESKTOP_NOTIFY_PROP] = model.CHANNEL_NOTIFY_MENTION - data[model.MARK_UNREAD_NOTIFY_PROP] = model.CHANNEL_MARK_UNREAD_MENTION - if _, err := Client.UpdateNotifyProps(data); err == nil { - t.Fatal("Should have errored - user not in channel") - } -} - -func TestFuzzyChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - // Strings that should pass as acceptable channel names - var fuzzyStringsPass = []string{ - "*", "?", ".", "}{][)(><", "{}[]()<>", - - "qahwah ( قهوة)", - "שָׁלוֹם עֲלֵיכֶם", - "Ramen チャーシュー chāshū", - "言而无信", - "Ṫ͌ó̍ ̍͂̓̍̍̀i̊ͯ͒", - "& < &qu", - - "' or '1'='1' -- ", - "' or '1'='1' ({ ", - "' or '1'='1' /* ", - "1;DROP TABLE users", - - "<b><i><u><strong><em>", - - "sue@thatmightbe", - "sue@thatmightbe.", - "sue@thatmightbe.c", - "sue@thatmightbe.co", - "su+san@thatmightbe.com", - "a@b.中国", - "1@2.am", - "a@b.co.uk", - "a@b.cancerresearch", - "local@[127.0.0.1]", - } - - for i := 0; i < len(fuzzyStringsPass); i++ { - channel := model.Channel{DisplayName: fuzzyStringsPass[i], Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - - _, err := Client.CreateChannel(&channel) - if err != nil { - t.Fatal(err) - } - } -} - -func TestGetChannelMember(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "A Test API Name", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - if result, err := Client.GetChannelMember(channel1.Id, th.BasicUser.Id); err != nil { - t.Fatal(err) - } else { - cm := result.Data.(*model.ChannelMember) - - if cm.UserId != th.BasicUser.Id { - t.Fatal("user ids didn't match") - } - if cm.ChannelId != channel1.Id { - t.Fatal("channel ids didn't match") - } - } - - if _, err := Client.GetChannelMember(channel1.Id, th.BasicUser2.Id); err == nil { - t.Fatal("should have failed - user not in channel") - } - - if _, err := Client.GetChannelMember("junk", th.BasicUser2.Id); err == nil { - t.Fatal("should have failed - bad channel id") - } - - if _, err := Client.GetChannelMember(channel1.Id, "junk"); err == nil { - t.Fatal("should have failed - bad user id") - } - - if _, err := Client.GetChannelMember("junk", "junk"); err == nil { - t.Fatal("should have failed - bad channel and user id") - } -} - -func TestSearchMoreChannels(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "TestAPINameA", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "TestAPINameB", Name: "b" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - th.LoginBasic2() - - if result, err := Client.SearchMoreChannels(model.ChannelSearch{Term: "TestAPIName"}); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - - if (*channels)[1].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - } - - if result, err := Client.SearchMoreChannels(model.ChannelSearch{Term: "TestAPINameA"}); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - } - - if result, err := Client.SearchMoreChannels(model.ChannelSearch{Term: "TestAPINameB"}); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - } - - if result, err := Client.SearchMoreChannels(model.ChannelSearch{Term: channel1.Name}); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - } - - if _, err := Client.SearchMoreChannels(model.ChannelSearch{Term: ""}); err == nil { - t.Fatal("should have errored - empty term") - } - - if result, err := Client.SearchMoreChannels(model.ChannelSearch{Term: "blargh"}); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if len(*channels) != 0 { - t.Fatal("should have no channels") - } - } - - Client.SetTeamId("junk") - if _, err := Client.SearchMoreChannels(model.ChannelSearch{Term: "blargh"}); err == nil { - t.Fatal("should have errored - bad team id") - } -} - -func TestAutocompleteChannels(t *testing.T) { - th := Setup().InitBasic().InitSystemAdmin() - defer th.TearDown() - - Client := th.BasicClient - team := th.BasicTeam - - channel1 := &model.Channel{DisplayName: "TestAPINameA", Name: "zz" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel1 = Client.Must(Client.CreateChannel(channel1)).Data.(*model.Channel) - - channel2 := &model.Channel{DisplayName: "TestAPINameB", Name: "b" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: team.Id} - channel2 = Client.Must(Client.CreateChannel(channel2)).Data.(*model.Channel) - - channel3 := &model.Channel{DisplayName: "BadChannelC", Name: "c" + model.NewId() + "a", Type: model.CHANNEL_OPEN, TeamId: model.NewId()} - if _, err := th.SystemAdminClient.CreateChannel(channel3); err == nil { - t.Fatal("channel must have valid team id") - } - - channel4 := &model.Channel{DisplayName: "BadChannelD", Name: "d" + model.NewId() + "a", Type: model.CHANNEL_PRIVATE, TeamId: team.Id} - channel4 = Client.Must(Client.CreateChannel(channel4)).Data.(*model.Channel) - - if result, err := Client.AutocompleteChannels("TestAPIName"); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - - if (*channels)[1].DisplayName != channel2.DisplayName { - t.Fatal("full name didn't match") - } - } - - if result, err := Client.AutocompleteChannels(channel1.Name); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if (*channels)[0].DisplayName != channel1.DisplayName { - t.Fatal("full name didn't match") - } - } - - if result, err := Client.AutocompleteChannels("BadChannelC"); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if len(*channels) != 0 { - t.Fatal("should have been empty") - } - } - - if result, err := Client.AutocompleteChannels("BadChannelD"); err != nil { - t.Fatal(err) - } else { - channels := result.Data.(*model.ChannelList) - - if len(*channels) != 0 { - t.Fatal("should have been empty") - } - } - - Client.SetTeamId("junk") - - if _, err := Client.AutocompleteChannels("BadChannelD"); err == nil { - t.Fatal("should have failed - bad team id") - } -} - -func TestGetChannelByName(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - - if result, err := Client.GetChannelByName(th.BasicChannel.Name); err != nil { - t.Fatal("Failed to get channel") - } else { - channel := result.Data.(*model.Channel) - if channel.Name != th.BasicChannel.Name { - t.Fatal("channel names did not match") - } - } - - if _, err := Client.GetChannelByName("InvalidChannelName"); err == nil { - t.Fatal("Failed to get team") - } - - Client.Must(Client.Logout()) - - user2 := &model.User{Email: "success+" + model.NewId() + "@simulator.amazonses.com", Nickname: "Jabba the Hutt", Password: "passwd1"} - user2 = Client.Must(Client.CreateUser(user2, "")).Data.(*model.User) - store.Must(th.App.Srv.Store.User().VerifyEmail(user2.Id)) - - Client.SetTeamId(th.BasicTeam.Id) - - Client.Login(user2.Email, "passwd1") - - if _, err := Client.GetChannelByName(th.BasicChannel.Name); err == nil { - t.Fatal("Should fail due to not enough permissions") - } -} - -func TestViewChannel(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - - view := model.ChannelView{ - ChannelId: th.BasicChannel.Id, - } - - if _, resp := Client.ViewChannel(view); resp.Error != nil { - t.Fatal(resp.Error) - } - - view.PrevChannelId = th.BasicChannel.Id - - if _, resp := Client.ViewChannel(view); resp.Error != nil { - t.Fatal(resp.Error) - } - - view.PrevChannelId = "" - - if _, resp := Client.ViewChannel(view); resp.Error != nil { - t.Fatal(resp.Error) - } - - view.PrevChannelId = "junk" - - if _, resp := Client.ViewChannel(view); resp.Error != nil { - t.Fatal(resp.Error) - } - - rdata := Client.Must(Client.GetChannel(th.BasicChannel.Id, "")).Data.(*model.ChannelData) - - if rdata.Channel.TotalMsgCount != rdata.Member.MsgCount { - t.Log(rdata.Channel.Id) - t.Log(rdata.Member.UserId) - t.Log(rdata.Channel.TotalMsgCount) - t.Log(rdata.Member.MsgCount) - t.Fatal("message counts don't match") - } - - if _, err := Client.DoApiPost(Client.GetTeamRoute()+"/channels/view", "garbage"); err == nil { - t.Fatal("should have been an error") - } -} - -func TestGetChannelMembersByIds(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - if _, err := th.App.AddUserToChannel(th.BasicUser2, th.BasicChannel); err != nil { - t.Fatal("Could not add second user to channel") - } - - if result, err := th.BasicClient.GetChannelMembersByIds(th.BasicChannel.Id, []string{th.BasicUser.Id}); err != nil { - t.Fatal(err) - } else { - member := (*result.Data.(*model.ChannelMembers))[0] - if member.UserId != th.BasicUser.Id { - t.Fatal("user id did not match") - } - if member.ChannelId != th.BasicChannel.Id { - t.Fatal("team id did not match") - } - } - - if result, err := th.BasicClient.GetChannelMembersByIds(th.BasicChannel.Id, []string{th.BasicUser.Id, th.BasicUser2.Id, model.NewId()}); err != nil { - t.Fatal(err) - } else { - members := result.Data.(*model.ChannelMembers) - if len(*members) != 2 { - t.Fatal("length should have been 2, got ", len(*members)) - } - } - - if _, err := th.BasicClient.GetChannelMembersByIds("junk", []string{th.BasicUser.Id}); err == nil { - t.Fatal("should have errored - bad team id") - } - - if _, err := th.BasicClient.GetChannelMembersByIds(th.BasicChannel.Id, []string{}); err == nil { - t.Fatal("should have errored - empty user ids") - } -} - -func TestUpdateChannelRoles(t *testing.T) { - th := Setup().InitSystemAdmin().InitBasic() - defer th.TearDown() - - th.SystemAdminClient.SetTeamId(th.BasicTeam.Id) - th.LinkUserToTeam(th.SystemAdminUser, th.BasicTeam) - - const CHANNEL_ADMIN = "channel_admin channel_user" - const CHANNEL_MEMBER = "channel_user" - - // User 1 creates a channel, making them channel admin by default. - createChannel := model.Channel{ - DisplayName: "Test API Name", - Name: "zz" + model.NewId() + "a", - Type: model.CHANNEL_OPEN, - TeamId: th.BasicTeam.Id, - } - - rchannel, err := th.BasicClient.CreateChannel(&createChannel) - if err != nil { - t.Fatal("Failed to create channel:", err) - } - channel := rchannel.Data.(*model.Channel) - - // User 1 adds User 2 to the channel, making them a channel member by default. - if _, err := th.BasicClient.AddChannelMember(channel.Id, th.BasicUser2.Id); err != nil { - t.Fatal("Failed to add user 2 to the channel:", err) - } - - // System Admin can demote User 1 (channel admin). - if data, meta := th.SystemAdminClient.UpdateChannelRoles(channel.Id, th.BasicUser.Id, CHANNEL_MEMBER); data == nil { - t.Fatal("System Admin failed to demote channel admin to channel member:", meta) - } - - // User 1 (channel_member) cannot promote user 2 (channel_member). - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser2.Id, CHANNEL_ADMIN); data != nil { - t.Fatal("Channel member should not be able to promote another channel member to channel admin:", meta) - } - - // System Admin can promote user 1 (channel member). - if data, meta := th.SystemAdminClient.UpdateChannelRoles(channel.Id, th.BasicUser.Id, CHANNEL_ADMIN); data == nil { - t.Fatal("System Admin failed to promote channel member to channel admin:", meta) - } - - // User 1 (channel_admin) can promote User 2 (channel member). - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser2.Id, CHANNEL_ADMIN); data == nil { - t.Fatal("Channel admin failed to promote channel member to channel admin:", meta) - } - - // User 1 (channel admin) can demote User 2 (channel admin). - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser2.Id, CHANNEL_MEMBER); data == nil { - t.Fatal("Channel admin failed to demote channel admin to channel member:", meta) - } - - // User 1 (channel admin) can demote itself. - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser.Id, CHANNEL_MEMBER); data == nil { - t.Fatal("Channel admin failed to demote itself to channel member:", meta) - } - - // Promote User2 again for next test. - if data, meta := th.SystemAdminClient.UpdateChannelRoles(channel.Id, th.BasicUser2.Id, CHANNEL_ADMIN); data == nil { - t.Fatal("System Admin failed to promote channel member to channel admin:", meta) - } - - // User 1 (channel member) cannot demote user 2 (channel admin). - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser2.Id, CHANNEL_MEMBER); data != nil { - t.Fatal("Channel member should not be able to demote another channel admin to channel member:", meta) - } - - // User 1 (channel member) cannot promote itself. - if data, meta := th.BasicClient.UpdateChannelRoles(channel.Id, th.BasicUser.Id, CHANNEL_ADMIN); data != nil { - t.Fatal("Channel member should not be able to promote itself to channel admin:", meta) - } -} - -func TestGetPinnedPosts(t *testing.T) { - th := Setup().InitBasic() - defer th.TearDown() - - Client := th.BasicClient - - post1 := th.BasicPost - r1 := Client.Must(Client.GetPinnedPosts(post1.ChannelId)).Data.(*model.PostList) - if len(r1.Order) != 0 { - t.Fatal("should not have gotten a pinned post") - } - - post2 := th.PinnedPost - r2 := Client.Must(Client.GetPinnedPosts(post2.ChannelId)).Data.(*model.PostList) - if len(r2.Order) == 0 { - t.Fatal("should have gotten a pinned post") - } - - if _, ok := r2.Posts[post2.Id]; !ok { - t.Fatal("missing pinned post") - } -} |