Switch to HTTP
This commit is contained in:
parent
984ac15084
commit
45f55083fc
9 changed files with 221 additions and 30 deletions
82
test/birdy_chat_web/api/internal/messages_test.exs
Normal file
82
test/birdy_chat_web/api/internal/messages_test.exs
Normal file
|
|
@ -0,0 +1,82 @@
|
|||
defmodule BirdyChatWeb.Api.Internal.MessagesTest do
|
||||
use BirdyChatWeb.ConnCase, async: true
|
||||
|
||||
setup do
|
||||
url = ~p"/api/internal"
|
||||
%{url: url}
|
||||
end
|
||||
|
||||
describe "authorisation" do
|
||||
setup %{conn: conn} do
|
||||
conn =
|
||||
conn
|
||||
|> put_req_header("content-type", "application/json")
|
||||
|
||||
%{conn: conn}
|
||||
end
|
||||
|
||||
test "returns 403 when authorisation token is missing", %{url: url, conn: conn} do
|
||||
message = %{"from" => "test2-user", "to" => "test2-someone", "message" => "123"}
|
||||
body = Jason.encode!(message)
|
||||
conn = post(conn, url, body)
|
||||
assert result = json_response(conn, :forbidden)
|
||||
assert result == %{"errors" => %{"general" => "Unauthorised"}}
|
||||
end
|
||||
|
||||
test "returns 403 when authorisation token is invalid", %{url: url, conn: conn} do
|
||||
server_id = "test2-user"
|
||||
token = Phoenix.Token.sign(BirdyChatWeb.Endpoint, "FakeAuth", server_id)
|
||||
|
||||
conn =
|
||||
conn
|
||||
|> put_req_header("content-type", "application/json")
|
||||
|> put_req_header("authorization", token)
|
||||
|
||||
message = %{"from" => "test2-user", "to" => "test2-someone", "message" => "123"}
|
||||
body = Jason.encode!(message)
|
||||
conn = post(conn, url, body)
|
||||
assert result = json_response(conn, :forbidden)
|
||||
assert result == %{"errors" => %{"general" => "Unauthorised"}}
|
||||
end
|
||||
end
|
||||
|
||||
describe "POST /api/server/messages" do
|
||||
setup %{conn: conn} do
|
||||
unique_user_id = System.unique_integer([:positive])
|
||||
username = "test1-user#{unique_user_id}"
|
||||
|
||||
path = Application.app_dir(:birdy_chat, ["priv", "messages", "#{username}.txt"])
|
||||
on_exit(fn -> File.rm(path) end)
|
||||
|
||||
server_id = "test2-user"
|
||||
token = Phoenix.Token.sign(BirdyChatWeb.Endpoint, "serverAuth", server_id)
|
||||
|
||||
conn =
|
||||
conn
|
||||
|> put_req_header("content-type", "application/json")
|
||||
|> put_req_header("authorization", token)
|
||||
|
||||
%{conn: conn, username: username, path: path}
|
||||
end
|
||||
|
||||
test "saves message locally", %{conn: conn, username: username, url: url, path: path} do
|
||||
message = %{"from" => "test2-user", "to" => username, "message" => "123"}
|
||||
body = Jason.encode!(message)
|
||||
conn = post(conn, url, body)
|
||||
assert result = json_response(conn, :created)
|
||||
|
||||
expected_result = %{
|
||||
"from" => "test2-user",
|
||||
"message" => "123",
|
||||
"to" => username,
|
||||
"routing" => "local",
|
||||
"server" => "test1"
|
||||
}
|
||||
|
||||
assert result == expected_result
|
||||
|
||||
contents = File.read!(path)
|
||||
assert contents == "test2-user: 123\n"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
@ -36,22 +36,26 @@ defmodule BirdyChatWeb.Api.MessagesTest do
|
|||
conn = post(conn, url, payload)
|
||||
assert result = json_response(conn, :unprocessable_entity)
|
||||
|
||||
expected_result = %{"errors" => %{"to" => ["Unknown 'to' server"]}}
|
||||
expected_result = %{"errors" => %{"server" => ["unknown 'to' server"]}}
|
||||
|
||||
assert result == expected_result
|
||||
end
|
||||
|
||||
test "broadcasts message to websocket", %{conn: conn, url: url} do
|
||||
message = %{from: "test1-user", to: "test2-user", message: "123"}
|
||||
string_message = %{"from" => "test1-user", "message" => "123", "to" => "test2-user"}
|
||||
|
||||
string_message = %{
|
||||
"from" => "test1-user",
|
||||
"message" => "123",
|
||||
"to" => "test2-user",
|
||||
"routing" => "remote",
|
||||
"server" => "test2"
|
||||
}
|
||||
|
||||
payload = Jason.encode!(message)
|
||||
conn = post(conn, url, payload)
|
||||
assert result = json_response(conn, :created)
|
||||
assert result == string_message
|
||||
|
||||
assert_broadcast "new_message", {:binary, encoded_message}
|
||||
assert :erlang.binary_to_term(encoded_message, [:safe]) == message
|
||||
end
|
||||
end
|
||||
|
||||
|
|
@ -74,10 +78,20 @@ defmodule BirdyChatWeb.Api.MessagesTest do
|
|||
|
||||
test "returns message and 201 when successful", %{conn: conn, url: url} do
|
||||
message = %{"from" => "test2-user", "to" => "test1-user", "message" => "123"}
|
||||
|
||||
payload = Jason.encode!(message)
|
||||
conn = post(conn, url, payload)
|
||||
assert result = json_response(conn, :created)
|
||||
assert result == message
|
||||
|
||||
expected_result = %{
|
||||
"from" => "test2-user",
|
||||
"to" => "test1-user",
|
||||
"message" => "123",
|
||||
"routing" => "local",
|
||||
"server" => "test1"
|
||||
}
|
||||
|
||||
assert result == expected_result
|
||||
end
|
||||
|
||||
test "writes message to file", %{conn: conn, url: url} do
|
||||
|
|
@ -85,7 +99,16 @@ defmodule BirdyChatWeb.Api.MessagesTest do
|
|||
payload = Jason.encode!(message)
|
||||
conn = post(conn, url, payload)
|
||||
assert result = json_response(conn, :created)
|
||||
assert result == message
|
||||
|
||||
expected_result = %{
|
||||
"from" => "test2-user",
|
||||
"to" => "test1-user",
|
||||
"message" => "123",
|
||||
"routing" => "local",
|
||||
"server" => "test1"
|
||||
}
|
||||
|
||||
assert result == expected_result
|
||||
|
||||
path = Application.app_dir(:birdy_chat, ["priv", "messages", "test1-user.txt"])
|
||||
contents = File.read!(path)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue