diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/integration/mastodon_websocket_test.exs | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/test/integration/mastodon_websocket_test.exs b/test/integration/mastodon_websocket_test.exs index c04262808..d02a3cc4d 100644 --- a/test/integration/mastodon_websocket_test.exs +++ b/test/integration/mastodon_websocket_test.exs @@ -18,6 +18,11 @@ defmodule Pleroma.Integration.MastodonWebsocketTest do          |> Map.put(:path, "/api/v1/streaming")          |> URI.to_string() +  setup_all do +    start_supervised(Pleroma.Web.Streamer.supervisor()) +    :ok +  end +    def start_socket(qs \\ nil, headers \\ []) do      path =        case qs do @@ -32,6 +37,7 @@ defmodule Pleroma.Integration.MastodonWebsocketTest do      capture_log(fn ->        assert {:error, {400, _}} = start_socket()        assert {:error, {404, _}} = start_socket("?stream=ncjdk") +      Process.sleep(30)      end)    end @@ -39,17 +45,16 @@ defmodule Pleroma.Integration.MastodonWebsocketTest do      capture_log(fn ->        assert {:error, {403, _}} = start_socket("?stream=user&access_token=aaaaaaaaaaaa")        assert {:error, {403, _}} = start_socket("?stream=user") +      Process.sleep(30)      end)    end -  @tag needs_streamer: true    test "allows public streams without authentication" do      assert {:ok, _} = start_socket("?stream=public")      assert {:ok, _} = start_socket("?stream=public:local")      assert {:ok, _} = start_socket("?stream=hashtag&tag=lain")    end -  @tag needs_streamer: true    test "receives well formatted events" do      user = insert(:user)      {:ok, _} = start_socket("?stream=public") @@ -94,31 +99,32 @@ defmodule Pleroma.Integration.MastodonWebsocketTest do        assert {:ok, _} = start_socket("?stream=user&access_token=#{state.token.token}")      end -    @tag needs_streamer: true      test "accepts the 'user' stream", %{token: token} = _state do        assert {:ok, _} = start_socket("?stream=user&access_token=#{token.token}")        assert capture_log(fn ->                 assert {:error, {403, "Forbidden"}} = start_socket("?stream=user") +               Process.sleep(30)               end) =~ ":badarg"      end -    @tag needs_streamer: true      test "accepts the 'user:notification' stream", %{token: token} = _state do        assert {:ok, _} = start_socket("?stream=user:notification&access_token=#{token.token}")        assert capture_log(fn ->                 assert {:error, {403, "Forbidden"}} = start_socket("?stream=user:notification") +               Process.sleep(30)               end) =~ ":badarg"      end -    @tag needs_streamer: true      test "accepts valid token on Sec-WebSocket-Protocol header", %{token: token} do        assert {:ok, _} = start_socket("?stream=user", [{"Sec-WebSocket-Protocol", token.token}])        assert capture_log(fn ->                 assert {:error, {403, "Forbidden"}} =                          start_socket("?stream=user", [{"Sec-WebSocket-Protocol", "I am a friend"}]) + +               Process.sleep(30)               end) =~ ":badarg"      end    end | 
