summaryrefslogtreecommitdiff
path: root/test/web/mongooseim/mongoose_im_controller_test.exs
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2019-05-22 04:06:54 +0000
committerkaniini <nenolod@gmail.com>2019-05-22 04:06:54 +0000
commit79c2cef2fbcbac99cce001376b8231e0e0a9adf4 (patch)
treed3e994e4930638103d8a8fea5e6ac14ad61dfb7c /test/web/mongooseim/mongoose_im_controller_test.exs
parentab6e15622b0977a50408f4afb874e0b5b1704d2f (diff)
parentd378b342ba0d7f54be3b47f031c602a578191dfd (diff)
downloadpleroma-79c2cef2fbcbac99cce001376b8231e0e0a9adf4.tar.gz
pleroma-79c2cef2fbcbac99cce001376b8231e0e0a9adf4.zip
Merge branch 'mongooseim-support' into 'develop'
MongooseIM: Add basic integration endpoints. See merge request pleroma/pleroma!1172
Diffstat (limited to 'test/web/mongooseim/mongoose_im_controller_test.exs')
-rw-r--r--test/web/mongooseim/mongoose_im_controller_test.exs59
1 files changed, 59 insertions, 0 deletions
diff --git a/test/web/mongooseim/mongoose_im_controller_test.exs b/test/web/mongooseim/mongoose_im_controller_test.exs
new file mode 100644
index 000000000..eb83999bb
--- /dev/null
+++ b/test/web/mongooseim/mongoose_im_controller_test.exs
@@ -0,0 +1,59 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.Web.MongooseIMController do
+ use Pleroma.Web.ConnCase
+ import Pleroma.Factory
+
+ test "/user_exists", %{conn: conn} do
+ _user = insert(:user, nickname: "lain")
+ _remote_user = insert(:user, nickname: "alice", local: false)
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :user_exists), user: "lain")
+ |> json_response(200)
+
+ assert res == true
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :user_exists), user: "alice")
+ |> json_response(404)
+
+ assert res == false
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :user_exists), user: "bob")
+ |> json_response(404)
+
+ assert res == false
+ end
+
+ test "/check_password", %{conn: conn} do
+ user = insert(:user, password_hash: Comeonin.Pbkdf2.hashpwsalt("cool"))
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :check_password), user: user.nickname, pass: "cool")
+ |> json_response(200)
+
+ assert res == true
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :check_password), user: user.nickname, pass: "uncool")
+ |> json_response(403)
+
+ assert res == false
+
+ res =
+ conn
+ |> get(mongoose_im_path(conn, :check_password), user: "nobody", pass: "cool")
+ |> json_response(404)
+
+ assert res == false
+ end
+end