diff options
Diffstat (limited to 'test/web/websub')
| -rw-r--r-- | test/web/websub/websub_controller_test.exs | 53 | ||||
| -rw-r--r-- | test/web/websub/websub_test.exs | 7 | 
2 files changed, 33 insertions, 27 deletions
| diff --git a/test/web/websub/websub_controller_test.exs b/test/web/websub/websub_controller_test.exs index 9cbcda063..1e69ed01a 100644 --- a/test/web/websub/websub_controller_test.exs +++ b/test/web/websub/websub_controller_test.exs @@ -5,9 +5,10 @@  defmodule Pleroma.Web.Websub.WebsubControllerTest do    use Pleroma.Web.ConnCase    import Pleroma.Factory -  alias Pleroma.Web.Websub.WebsubClientSubscription -  alias Pleroma.{Repo, Activity} +  alias Pleroma.Activity +  alias Pleroma.Repo    alias Pleroma.Web.Websub +  alias Pleroma.Web.Websub.WebsubClientSubscription    test "websub subscription request", %{conn: conn} do      user = insert(:user) @@ -50,35 +51,37 @@ defmodule Pleroma.Web.Websub.WebsubControllerTest do      assert_in_delta NaiveDateTime.diff(websub.valid_until, NaiveDateTime.utc_now()), 100, 5    end -  test "handles incoming feed updates", %{conn: conn} do -    websub = insert(:websub_client_subscription) -    doc = "some stuff" -    signature = Websub.sign(websub.secret, doc) +  describe "websub_incoming" do +    test "handles incoming feed updates", %{conn: conn} do +      websub = insert(:websub_client_subscription) +      doc = "some stuff" +      signature = Websub.sign(websub.secret, doc) -    conn = -      conn -      |> put_req_header("x-hub-signature", "sha1=" <> signature) -      |> put_req_header("content-type", "application/atom+xml") -      |> post("/push/subscriptions/#{websub.id}", doc) +      conn = +        conn +        |> put_req_header("x-hub-signature", "sha1=" <> signature) +        |> put_req_header("content-type", "application/atom+xml") +        |> post("/push/subscriptions/#{websub.id}", doc) -    assert response(conn, 200) == "OK" +      assert response(conn, 200) == "OK" -    assert length(Repo.all(Activity)) == 1 -  end +      assert length(Repo.all(Activity)) == 1 +    end -  test "rejects incoming feed updates with the wrong signature", %{conn: conn} do -    websub = insert(:websub_client_subscription) -    doc = "some stuff" -    signature = Websub.sign("wrong secret", doc) +    test "rejects incoming feed updates with the wrong signature", %{conn: conn} do +      websub = insert(:websub_client_subscription) +      doc = "some stuff" +      signature = Websub.sign("wrong secret", doc) -    conn = -      conn -      |> put_req_header("x-hub-signature", "sha1=" <> signature) -      |> put_req_header("content-type", "application/atom+xml") -      |> post("/push/subscriptions/#{websub.id}", doc) +      conn = +        conn +        |> put_req_header("x-hub-signature", "sha1=" <> signature) +        |> put_req_header("content-type", "application/atom+xml") +        |> post("/push/subscriptions/#{websub.id}", doc) -    assert response(conn, 500) == "Error" +      assert response(conn, 500) == "Error" -    assert length(Repo.all(Activity)) == 0 +      assert Enum.empty?(Repo.all(Activity)) +    end    end  end diff --git a/test/web/websub/websub_test.exs b/test/web/websub/websub_test.exs index 9751d161d..74386d7db 100644 --- a/test/web/websub/websub_test.exs +++ b/test/web/websub/websub_test.exs @@ -4,10 +4,13 @@  defmodule Pleroma.Web.WebsubTest do    use Pleroma.DataCase + +  alias Pleroma.Web.Router.Helpers    alias Pleroma.Web.Websub -  alias Pleroma.Web.Websub.{WebsubServerSubscription, WebsubClientSubscription} +  alias Pleroma.Web.Websub.WebsubClientSubscription +  alias Pleroma.Web.Websub.WebsubServerSubscription +    import Pleroma.Factory -  alias Pleroma.Web.Router.Helpers    import Tesla.Mock    setup do | 
