summaryrefslogtreecommitdiffstats
path: root/api4/channel_test.go
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2017-02-03 10:27:12 -0500
committerChristopher Speller <crspeller@gmail.com>2017-02-03 10:27:12 -0500
commit9312469ad54cf2ff268a44e478b584549f62e2c4 (patch)
tree6b29783b9341b54a16aca581c4878f3cdd7474d7 /api4/channel_test.go
parentccb034382850b7e8ea924a4559e47ef44203155c (diff)
downloadchat-9312469ad54cf2ff268a44e478b584549f62e2c4.tar.gz
chat-9312469ad54cf2ff268a44e478b584549f62e2c4.tar.bz2
chat-9312469ad54cf2ff268a44e478b584549f62e2c4.zip
Implement POST /channels/direct endpoint for APIv4 (#5283)
Diffstat (limited to 'api4/channel_test.go')
-rw-r--r--api4/channel_test.go52
1 files changed, 52 insertions, 0 deletions
diff --git a/api4/channel_test.go b/api4/channel_test.go
index e3d0a85bd..5123d7730 100644
--- a/api4/channel_test.go
+++ b/api4/channel_test.go
@@ -167,3 +167,55 @@ func TestCreateChannel(t *testing.T) {
}
}
}
+
+func TestCreateDirectChannel(t *testing.T) {
+ th := Setup().InitBasic().InitSystemAdmin()
+ defer TearDown()
+ Client := th.Client
+ user1 := th.BasicUser
+ user2 := th.BasicUser2
+ user3 := th.CreateUser()
+
+ dm, resp := Client.CreateDirectChannel(user1.Id, user2.Id)
+ CheckNoError(t, resp)
+
+ channelName := ""
+ if user2.Id > user1.Id {
+ channelName = user1.Id + "__" + user2.Id
+ } else {
+ channelName = user2.Id + "__" + user1.Id
+ }
+
+ if dm.Name != channelName {
+ t.Fatal("dm name didn't match")
+ }
+
+ _, resp = Client.CreateDirectChannel("junk", user2.Id)
+ CheckBadRequestStatus(t, resp)
+
+ _, resp = Client.CreateDirectChannel(user1.Id, model.NewId())
+ CheckBadRequestStatus(t, resp)
+
+ _, resp = Client.CreateDirectChannel(model.NewId(), user1.Id)
+ CheckBadRequestStatus(t, resp)
+
+ _, resp = Client.CreateDirectChannel(model.NewId(), user2.Id)
+ CheckForbiddenStatus(t, resp)
+
+ if r, err := Client.DoApiPost("/channels/direct", "garbage"); err == nil {
+ t.Fatal("should have errored")
+ } else {
+ if r.StatusCode != http.StatusBadRequest {
+ t.Log("actual: " + strconv.Itoa(r.StatusCode))
+ t.Log("expected: " + strconv.Itoa(http.StatusBadRequest))
+ t.Fatal("wrong status code")
+ }
+ }
+
+ Client.Logout()
+ _, resp = Client.CreateDirectChannel(model.NewId(), user2.Id)
+ CheckUnauthorizedStatus(t, resp)
+
+ _, resp = th.SystemAdminClient.CreateDirectChannel(user3.Id, user2.Id)
+ CheckNoError(t, resp)
+}