diff options
author | raeno <just.raeno@gmail.com> | 2018-12-18 14:59:32 +0100 |
---|---|---|
committer | raeno <just.raeno@gmail.com> | 2018-12-18 14:59:32 +0100 |
commit | a3003364598b42849e384a216948dad810481f51 (patch) | |
tree | 2ed2b04efab457220a60fb7630906b1b26f24df3 /test/support/websocket_client.ex | |
parent | 30812f84518f1b2fcc70a416d1a6b9f81264f3a5 (diff) | |
parent | b6ae412fcd7c67d64dd1467e8e35d17140e992df (diff) | |
download | pleroma-a3003364598b42849e384a216948dad810481f51.tar.gz |
Merge branch 'develop' into oembed_provider
Diffstat (limited to 'test/support/websocket_client.ex')
-rw-r--r-- | test/support/websocket_client.ex | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/test/support/websocket_client.ex b/test/support/websocket_client.ex new file mode 100644 index 000000000..57e9bb17f --- /dev/null +++ b/test/support/websocket_client.ex @@ -0,0 +1,58 @@ +defmodule Pleroma.Integration.WebsocketClient do + # https://github.com/phoenixframework/phoenix/blob/master/test/support/websocket_client.exs + + @doc """ + Starts the WebSocket server for given ws URL. Received Socket.Message's + are forwarded to the sender pid + """ + def start_link(sender, url, headers \\ []) do + :crypto.start() + :ssl.start() + + :websocket_client.start_link( + String.to_charlist(url), + __MODULE__, + [sender], + extra_headers: headers + ) + end + + @doc """ + Closes the socket + """ + def close(socket) do + send(socket, :close) + end + + @doc """ + Sends a low-level text message to the client. + """ + def send_text(server_pid, msg) do + send(server_pid, {:text, msg}) + end + + @doc false + def init([sender], _conn_state) do + {:ok, %{sender: sender}} + end + + @doc false + def websocket_handle(frame, _conn_state, state) do + send(state.sender, frame) + {:ok, state} + end + + @doc false + def websocket_info({:text, msg}, _conn_state, state) do + {:reply, {:text, msg}, state} + end + + def websocket_info(:close, _conn_state, _state) do + {:close, <<>>, "done"} + end + + @doc false + def websocket_terminate(_reason, _conn_state, _state) do + :ok + end +end |