summaryrefslogtreecommitdiffstats
path: root/api/channel_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'api/channel_test.go')
-rw-r--r--api/channel_test.go40
1 files changed, 40 insertions, 0 deletions
diff --git a/api/channel_test.go b/api/channel_test.go
index 2e6484dfa..d8da3374b 100644
--- a/api/channel_test.go
+++ b/api/channel_test.go
@@ -219,6 +219,46 @@ func TestCreateDirectChannel(t *testing.T) {
}
}
+func TestCreateGroupChannel(t *testing.T) {
+ th := Setup().InitBasic()
+ 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()
Client := th.SystemAdminClient