diff options
| author | lain <lain@soykaf.club> | 2018-09-08 14:02:38 +0200 | 
|---|---|---|
| committer | William Pitcock <nenolod@dereferenced.org> | 2018-11-01 09:01:43 +0000 | 
| commit | 1e9ced5af478ba38c9e9d46140891a8f4473e02d (patch) | |
| tree | 95e61013630aed3b29996bf226572d163d482fbc /test | |
| parent | e6ec01afb648cb99e5fc4db3a64fe1ed74fd0105 (diff) | |
| download | pleroma-1e9ced5af478ba38c9e9d46140891a8f4473e02d.tar.gz pleroma-1e9ced5af478ba38c9e9d46140891a8f4473e02d.zip | |
Test Relay, switch to runtime configuration.
Diffstat (limited to 'test')
| -rw-r--r-- | test/web/activity_pub/activity_pub_controller_test.exs | 23 | ||||
| -rw-r--r-- | test/web/activity_pub/relay_test.exs | 11 | ||||
| -rw-r--r-- | test/web/federator_test.exs | 45 | 
3 files changed, 79 insertions, 0 deletions
| diff --git a/test/web/activity_pub/activity_pub_controller_test.exs b/test/web/activity_pub/activity_pub_controller_test.exs index e63cd6583..5b46bbe76 100644 --- a/test/web/activity_pub/activity_pub_controller_test.exs +++ b/test/web/activity_pub/activity_pub_controller_test.exs @@ -4,6 +4,29 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do    alias Pleroma.Web.ActivityPub.{UserView, ObjectView}    alias Pleroma.{Repo, User}    alias Pleroma.Activity +  alias Pleroma.Config + +  describe "/relay" do +    test "with the relay active, it returns the relay user", %{conn: conn} do +      Config.put([:instance, :allow_relay], true) + +      res = +        conn +        |> get(activity_pub_path(conn, :relay)) +        |> json_response(200) + +      assert res["id"] =~ "/relay" +    end + +    test "with the relay disabled, it returns 404", %{conn: conn} do +      Config.put([:instance, :allow_relay], false) + +      res = +        conn +        |> get(activity_pub_path(conn, :relay)) +        |> json_response(404) +    end +  end    describe "/users/:nickname" do      test "it returns a json representation of the user", %{conn: conn} do diff --git a/test/web/activity_pub/relay_test.exs b/test/web/activity_pub/relay_test.exs new file mode 100644 index 000000000..41d13e055 --- /dev/null +++ b/test/web/activity_pub/relay_test.exs @@ -0,0 +1,11 @@ +defmodule Pleroma.Web.ActivityPub.RelayTest do +  use Pleroma.DataCase + +  alias Pleroma.Web.ActivityPub.Relay + +  test "gets an actor for the relay" do +    user = Relay.get_actor() + +    assert user.ap_id =~ "/relay" +  end +end diff --git a/test/web/federator_test.exs b/test/web/federator_test.exs index 09533362a..966702935 100644 --- a/test/web/federator_test.exs +++ b/test/web/federator_test.exs @@ -1,6 +1,10 @@  defmodule Pleroma.Web.FederatorTest do    alias Pleroma.Web.Federator +  alias Pleroma.Web.CommonAPI +  alias Pleroma.Config    use Pleroma.DataCase +  import Pleroma.Factory +  import Mock    test "enqueues an element according to priority" do      queue = [%{item: 1, priority: 2}] @@ -17,4 +21,45 @@ defmodule Pleroma.Web.FederatorTest do      assert {2, [%{item: 1, priority: 2}]} = Federator.queue_pop(queue)    end + +  describe "Publish an activity" do +    setup do +      user = insert(:user) +      {:ok, activity} = CommonAPI.post(user, %{"status" => "HI"}) + +      relay_mock = { +        Pleroma.Web.ActivityPub.Relay, +        [], +        [publish: fn _activity -> send(self(), :relay_publish) end] +      } + +      %{activity: activity, relay_mock: relay_mock} +    end + +    test "with relays active, it publishes to the relay", %{ +      activity: activity, +      relay_mock: relay_mock +    } do +      Config.put([:instance, :allow_relay], true) + +      with_mocks([relay_mock]) do +        Federator.handle(:publish, activity) +      end + +      assert_received :relay_publish +    end + +    test "with relays deactivated, it does not publish to the relay", %{ +      activity: activity, +      relay_mock: relay_mock +    } do +      Config.put([:instance, :allow_relay], false) + +      with_mocks([relay_mock]) do +        Federator.handle(:publish, activity) +      end + +      refute_received :relay_publish +    end +  end  end | 
