summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorLain Iwakura <lain@soykaf.club>2017-12-07 17:41:34 +0100
committerLain Iwakura <lain@soykaf.club>2017-12-07 17:41:34 +0100
commit0ec5aeb8a76653935caefa0de92861269f98f343 (patch)
tree10db8190e376c9a7d857ea1b5d345aa1765502aa /test
parente31a5ff4af04156b9db8f032cf184e1da540f025 (diff)
downloadpleroma-0ec5aeb8a76653935caefa0de92861269f98f343.tar.gz
pleroma-0ec5aeb8a76653935caefa0de92861269f98f343.zip
Don't log in deactivated users.
Diffstat (limited to 'test')
-rw-r--r--test/plugs/authentication_plug_test.exs27
1 files changed, 27 insertions, 0 deletions
diff --git a/test/plugs/authentication_plug_test.exs b/test/plugs/authentication_plug_test.exs
index 9d6c2cd70..5480dab43 100644
--- a/test/plugs/authentication_plug_test.exs
+++ b/test/plugs/authentication_plug_test.exs
@@ -14,6 +14,13 @@ defmodule Pleroma.Plugs.AuthenticationPlugTest do
password_hash: Comeonin.Pbkdf2.hashpwsalt("guy")
}
+ @deactivated %User{
+ id: 1,
+ name: "dude",
+ password_hash: Comeonin.Pbkdf2.hashpwsalt("guy"),
+ info: %{"deactivated" => true}
+ }
+
@session_opts [
store: :cookie,
key: "_test",
@@ -131,6 +138,26 @@ defmodule Pleroma.Plugs.AuthenticationPlugTest do
end
end
+ describe "with a correct authorization header for an deactiviated user" do
+ test "it halts the appication", %{conn: conn} do
+ opts = %{
+ optional: false,
+ fetcher: fn _ -> @deactivated end
+ }
+
+ header = basic_auth_enc("dude", "guy")
+
+ conn = conn
+ |> Plug.Session.call(Plug.Session.init(@session_opts))
+ |> fetch_session
+ |> put_req_header("authorization", header)
+ |> AuthenticationPlug.call(opts)
+
+ assert conn.status == 403
+ assert conn.halted == true
+ end
+ end
+
describe "with a user_id in the session for an existing user" do
test "it assigns the user", %{conn: conn} do
opts = %{