diff options
Diffstat (limited to 'test/web')
9 files changed, 365 insertions, 200 deletions
| diff --git a/test/web/activity_pub/object_validators/accept_validation_test.exs b/test/web/activity_pub/object_validators/accept_validation_test.exs new file mode 100644 index 000000000..d6111ba41 --- /dev/null +++ b/test/web/activity_pub/object_validators/accept_validation_test.exs @@ -0,0 +1,56 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.ObjectValidators.AcceptValidationTest do +  use Pleroma.DataCase + +  alias Pleroma.Web.ActivityPub.Builder +  alias Pleroma.Web.ActivityPub.ObjectValidator +  alias Pleroma.Web.ActivityPub.Pipeline + +  import Pleroma.Factory + +  setup do +    follower = insert(:user) +    followed = insert(:user, local: false) + +    {:ok, follow_data, _} = Builder.follow(follower, followed) +    {:ok, follow_activity, _} = Pipeline.common_pipeline(follow_data, local: true) + +    {:ok, accept_data, _} = Builder.accept(followed, follow_activity) + +    %{accept_data: accept_data, followed: followed} +  end + +  test "it validates a basic 'accept'", %{accept_data: accept_data} do +    assert {:ok, _, _} = ObjectValidator.validate(accept_data, []) +  end + +  test "it fails when the actor doesn't exist", %{accept_data: accept_data} do +    accept_data = +      accept_data +      |> Map.put("actor", "https://gensokyo.2hu/users/raymoo") + +    assert {:error, _} = ObjectValidator.validate(accept_data, []) +  end + +  test "it fails when the accepted activity doesn't exist", %{accept_data: accept_data} do +    accept_data = +      accept_data +      |> Map.put("object", "https://gensokyo.2hu/users/raymoo/follows/1") + +    assert {:error, _} = ObjectValidator.validate(accept_data, []) +  end + +  test "for an accepted follow, it only validates if the actor of the accept is the followed actor", +       %{accept_data: accept_data} do +    stranger = insert(:user) + +    accept_data = +      accept_data +      |> Map.put("actor", stranger.ap_id) + +    assert {:error, _} = ObjectValidator.validate(accept_data, []) +  end +end diff --git a/test/web/activity_pub/object_validators/reject_validation_test.exs b/test/web/activity_pub/object_validators/reject_validation_test.exs new file mode 100644 index 000000000..370bb6e5c --- /dev/null +++ b/test/web/activity_pub/object_validators/reject_validation_test.exs @@ -0,0 +1,56 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.ObjectValidators.RejectValidationTest do +  use Pleroma.DataCase + +  alias Pleroma.Web.ActivityPub.Builder +  alias Pleroma.Web.ActivityPub.ObjectValidator +  alias Pleroma.Web.ActivityPub.Pipeline + +  import Pleroma.Factory + +  setup do +    follower = insert(:user) +    followed = insert(:user, local: false) + +    {:ok, follow_data, _} = Builder.follow(follower, followed) +    {:ok, follow_activity, _} = Pipeline.common_pipeline(follow_data, local: true) + +    {:ok, reject_data, _} = Builder.reject(followed, follow_activity) + +    %{reject_data: reject_data, followed: followed} +  end + +  test "it validates a basic 'reject'", %{reject_data: reject_data} do +    assert {:ok, _, _} = ObjectValidator.validate(reject_data, []) +  end + +  test "it fails when the actor doesn't exist", %{reject_data: reject_data} do +    reject_data = +      reject_data +      |> Map.put("actor", "https://gensokyo.2hu/users/raymoo") + +    assert {:error, _} = ObjectValidator.validate(reject_data, []) +  end + +  test "it fails when the rejected activity doesn't exist", %{reject_data: reject_data} do +    reject_data = +      reject_data +      |> Map.put("object", "https://gensokyo.2hu/users/raymoo/follows/1") + +    assert {:error, _} = ObjectValidator.validate(reject_data, []) +  end + +  test "for an rejected follow, it only validates if the actor of the reject is the followed actor", +       %{reject_data: reject_data} do +    stranger = insert(:user) + +    reject_data = +      reject_data +      |> Map.put("actor", stranger.ap_id) + +    assert {:error, _} = ObjectValidator.validate(reject_data, []) +  end +end diff --git a/test/web/activity_pub/transmogrifier/accept_handling_test.exs b/test/web/activity_pub/transmogrifier/accept_handling_test.exs new file mode 100644 index 000000000..77d468f5c --- /dev/null +++ b/test/web/activity_pub/transmogrifier/accept_handling_test.exs @@ -0,0 +1,91 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.Transmogrifier.AcceptHandlingTest do +  use Pleroma.DataCase + +  alias Pleroma.User +  alias Pleroma.Web.ActivityPub.Transmogrifier +  alias Pleroma.Web.CommonAPI + +  import Pleroma.Factory + +  test "it works for incoming accepts which were pre-accepted" do +    follower = insert(:user) +    followed = insert(:user) + +    {:ok, follower} = User.follow(follower, followed) +    assert User.following?(follower, followed) == true + +    {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) + +    accept_data = +      File.read!("test/fixtures/mastodon-accept-activity.json") +      |> Poison.decode!() +      |> Map.put("actor", followed.ap_id) + +    object = +      accept_data["object"] +      |> Map.put("actor", follower.ap_id) +      |> Map.put("id", follow_activity.data["id"]) + +    accept_data = Map.put(accept_data, "object", object) + +    {:ok, activity} = Transmogrifier.handle_incoming(accept_data) +    refute activity.local + +    assert activity.data["object"] == follow_activity.data["id"] + +    assert activity.data["id"] == accept_data["id"] + +    follower = User.get_cached_by_id(follower.id) + +    assert User.following?(follower, followed) == true +  end + +  test "it works for incoming accepts which are referenced by IRI only" do +    follower = insert(:user) +    followed = insert(:user, locked: true) + +    {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) + +    accept_data = +      File.read!("test/fixtures/mastodon-accept-activity.json") +      |> Poison.decode!() +      |> Map.put("actor", followed.ap_id) +      |> Map.put("object", follow_activity.data["id"]) + +    {:ok, activity} = Transmogrifier.handle_incoming(accept_data) +    assert activity.data["object"] == follow_activity.data["id"] + +    follower = User.get_cached_by_id(follower.id) + +    assert User.following?(follower, followed) == true + +    follower = User.get_by_id(follower.id) +    assert follower.following_count == 1 + +    followed = User.get_by_id(followed.id) +    assert followed.follower_count == 1 +  end + +  test "it fails for incoming accepts which cannot be correlated" do +    follower = insert(:user) +    followed = insert(:user, locked: true) + +    accept_data = +      File.read!("test/fixtures/mastodon-accept-activity.json") +      |> Poison.decode!() +      |> Map.put("actor", followed.ap_id) + +    accept_data = +      Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) + +    {:error, _} = Transmogrifier.handle_incoming(accept_data) + +    follower = User.get_cached_by_id(follower.id) + +    refute User.following?(follower, followed) == true +  end +end diff --git a/test/web/activity_pub/transmogrifier/follow_handling_test.exs b/test/web/activity_pub/transmogrifier/follow_handling_test.exs index 17e764ca1..757d90941 100644 --- a/test/web/activity_pub/transmogrifier/follow_handling_test.exs +++ b/test/web/activity_pub/transmogrifier/follow_handling_test.exs @@ -185,5 +185,24 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier.FollowHandlingTest do        assert data["id"] == "https://hubzilla.example.org/channel/kaniini#follows/2"        assert User.following?(User.get_cached_by_ap_id(data["actor"]), user)      end + +    test "it works for incoming follows to locked account" do +      pending_follower = insert(:user, ap_id: "http://mastodon.example.org/users/admin") +      user = insert(:user, locked: true) + +      data = +        File.read!("test/fixtures/mastodon-follow-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Follow" +      assert data["object"] == user.ap_id +      assert data["state"] == "pending" +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      assert [^pending_follower] = User.get_follow_requests(user) +    end    end  end diff --git a/test/web/activity_pub/transmogrifier/reject_handling_test.exs b/test/web/activity_pub/transmogrifier/reject_handling_test.exs new file mode 100644 index 000000000..7592fbe1c --- /dev/null +++ b/test/web/activity_pub/transmogrifier/reject_handling_test.exs @@ -0,0 +1,67 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.Transmogrifier.RejectHandlingTest do +  use Pleroma.DataCase + +  alias Pleroma.Activity +  alias Pleroma.User +  alias Pleroma.Web.ActivityPub.Transmogrifier +  alias Pleroma.Web.CommonAPI + +  import Pleroma.Factory + +  test "it fails for incoming rejects which cannot be correlated" do +    follower = insert(:user) +    followed = insert(:user, locked: true) + +    accept_data = +      File.read!("test/fixtures/mastodon-reject-activity.json") +      |> Poison.decode!() +      |> Map.put("actor", followed.ap_id) + +    accept_data = +      Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) + +    {:error, _} = Transmogrifier.handle_incoming(accept_data) + +    follower = User.get_cached_by_id(follower.id) + +    refute User.following?(follower, followed) == true +  end + +  test "it works for incoming rejects which are referenced by IRI only" do +    follower = insert(:user) +    followed = insert(:user, locked: true) + +    {:ok, follower} = User.follow(follower, followed) +    {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) + +    assert User.following?(follower, followed) == true + +    reject_data = +      File.read!("test/fixtures/mastodon-reject-activity.json") +      |> Poison.decode!() +      |> Map.put("actor", followed.ap_id) +      |> Map.put("object", follow_activity.data["id"]) + +    {:ok, %Activity{data: _}} = Transmogrifier.handle_incoming(reject_data) + +    follower = User.get_cached_by_id(follower.id) + +    assert User.following?(follower, followed) == false +  end + +  test "it rejects activities without a valid ID" do +    user = insert(:user) + +    data = +      File.read!("test/fixtures/mastodon-follow-activity.json") +      |> Poison.decode!() +      |> Map.put("object", user.ap_id) +      |> Map.put("id", "") + +    :error = Transmogrifier.handle_incoming(data) +  end +end diff --git a/test/web/activity_pub/transmogrifier/undo_handling_test.exs b/test/web/activity_pub/transmogrifier/undo_handling_test.exs index 01dd6c370..8683f7135 100644 --- a/test/web/activity_pub/transmogrifier/undo_handling_test.exs +++ b/test/web/activity_pub/transmogrifier/undo_handling_test.exs @@ -130,7 +130,7 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier.UndoHandlingTest do               "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"    end -  test "it works for incomming unfollows with an existing follow" do +  test "it works for incoming unfollows with an existing follow" do      user = insert(:user)      follow_data = diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index 6dd9a3fec..0dd4e6e47 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -359,7 +359,7 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        refute Map.has_key?(object_data, "reaction_count")      end -    test "it works for incomming unfollows with an existing follow" do +    test "it works for incoming unfollows with an existing follow" do        user = insert(:user)        follow_data = @@ -384,204 +384,6 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        refute User.following?(User.get_cached_by_ap_id(data["actor"]), user)      end -    test "it works for incoming follows to locked account" do -      pending_follower = insert(:user, ap_id: "http://mastodon.example.org/users/admin") -      user = insert(:user, locked: true) - -      data = -        File.read!("test/fixtures/mastodon-follow-activity.json") -        |> Poison.decode!() -        |> Map.put("object", user.ap_id) - -      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) - -      assert data["type"] == "Follow" -      assert data["object"] == user.ap_id -      assert data["state"] == "pending" -      assert data["actor"] == "http://mastodon.example.org/users/admin" - -      assert [^pending_follower] = User.get_follow_requests(user) -    end - -    test "it works for incoming accepts which were pre-accepted" do -      follower = insert(:user) -      followed = insert(:user) - -      {:ok, follower} = User.follow(follower, followed) -      assert User.following?(follower, followed) == true - -      {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) - -      accept_data = -        File.read!("test/fixtures/mastodon-accept-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) - -      object = -        accept_data["object"] -        |> Map.put("actor", follower.ap_id) -        |> Map.put("id", follow_activity.data["id"]) - -      accept_data = Map.put(accept_data, "object", object) - -      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) -      refute activity.local - -      assert activity.data["object"] == follow_activity.data["id"] - -      assert activity.data["id"] == accept_data["id"] - -      follower = User.get_cached_by_id(follower.id) - -      assert User.following?(follower, followed) == true -    end - -    test "it works for incoming accepts which were orphaned" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) - -      accept_data = -        File.read!("test/fixtures/mastodon-accept-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) - -      accept_data = -        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) - -      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) -      assert activity.data["object"] == follow_activity.data["id"] - -      follower = User.get_cached_by_id(follower.id) - -      assert User.following?(follower, followed) == true -    end - -    test "it works for incoming accepts which are referenced by IRI only" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) - -      accept_data = -        File.read!("test/fixtures/mastodon-accept-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) -        |> Map.put("object", follow_activity.data["id"]) - -      {:ok, activity} = Transmogrifier.handle_incoming(accept_data) -      assert activity.data["object"] == follow_activity.data["id"] - -      follower = User.get_cached_by_id(follower.id) - -      assert User.following?(follower, followed) == true - -      follower = User.get_by_id(follower.id) -      assert follower.following_count == 1 - -      followed = User.get_by_id(followed.id) -      assert followed.follower_count == 1 -    end - -    test "it fails for incoming accepts which cannot be correlated" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      accept_data = -        File.read!("test/fixtures/mastodon-accept-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) - -      accept_data = -        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) - -      :error = Transmogrifier.handle_incoming(accept_data) - -      follower = User.get_cached_by_id(follower.id) - -      refute User.following?(follower, followed) == true -    end - -    test "it fails for incoming rejects which cannot be correlated" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      accept_data = -        File.read!("test/fixtures/mastodon-reject-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) - -      accept_data = -        Map.put(accept_data, "object", Map.put(accept_data["object"], "actor", follower.ap_id)) - -      :error = Transmogrifier.handle_incoming(accept_data) - -      follower = User.get_cached_by_id(follower.id) - -      refute User.following?(follower, followed) == true -    end - -    test "it works for incoming rejects which are orphaned" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      {:ok, follower} = User.follow(follower, followed) -      {:ok, _, _, _follow_activity} = CommonAPI.follow(follower, followed) - -      assert User.following?(follower, followed) == true - -      reject_data = -        File.read!("test/fixtures/mastodon-reject-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) - -      reject_data = -        Map.put(reject_data, "object", Map.put(reject_data["object"], "actor", follower.ap_id)) - -      {:ok, activity} = Transmogrifier.handle_incoming(reject_data) -      refute activity.local -      assert activity.data["id"] == reject_data["id"] - -      follower = User.get_cached_by_id(follower.id) - -      assert User.following?(follower, followed) == false -    end - -    test "it works for incoming rejects which are referenced by IRI only" do -      follower = insert(:user) -      followed = insert(:user, locked: true) - -      {:ok, follower} = User.follow(follower, followed) -      {:ok, _, _, follow_activity} = CommonAPI.follow(follower, followed) - -      assert User.following?(follower, followed) == true - -      reject_data = -        File.read!("test/fixtures/mastodon-reject-activity.json") -        |> Poison.decode!() -        |> Map.put("actor", followed.ap_id) -        |> Map.put("object", follow_activity.data["id"]) - -      {:ok, %Activity{data: _}} = Transmogrifier.handle_incoming(reject_data) - -      follower = User.get_cached_by_id(follower.id) - -      assert User.following?(follower, followed) == false -    end - -    test "it rejects activities without a valid ID" do -      user = insert(:user) - -      data = -        File.read!("test/fixtures/mastodon-follow-activity.json") -        |> Poison.decode!() -        |> Map.put("object", user.ap_id) -        |> Map.put("id", "") - -      :error = Transmogrifier.handle_incoming(data) -    end -      test "skip converting the content when it is nil" do        object_id = "https://peertube.social/videos/watch/278d2b7c-0f38-4aaa-afe6-9ecc0c4a34fe" diff --git a/test/web/admin_api/controllers/admin_api_controller_test.exs b/test/web/admin_api/controllers/admin_api_controller_test.exs index eca9272e0..66d4b1ef3 100644 --- a/test/web/admin_api/controllers/admin_api_controller_test.exs +++ b/test/web/admin_api/controllers/admin_api_controller_test.exs @@ -158,6 +158,8 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do        user = insert(:user)        clear_config([:instance, :federating], true) +      refute user.deactivated +        with_mock Pleroma.Web.Federator,          publish: fn _ -> nil end do          conn = @@ -176,6 +178,9 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do          assert json_response(conn, 200) == [user.nickname] +        user = Repo.get(User, user.id) +        assert user.deactivated +          assert called(Pleroma.Web.Federator.publish(:_))        end      end diff --git a/test/web/admin_api/controllers/config_controller_test.exs b/test/web/admin_api/controllers/config_controller_test.exs index 61bc9fd39..4e897455f 100644 --- a/test/web/admin_api/controllers/config_controller_test.exs +++ b/test/web/admin_api/controllers/config_controller_test.exs @@ -1342,6 +1342,75 @@ defmodule Pleroma.Web.AdminAPI.ConfigControllerTest do                 args: ["auto-orient", "strip", {"implode", "1"}, {"resize", "3840x1080>"}]               ]      end + +    test "enables the welcome messages", %{conn: conn} do +      clear_config([:welcome]) + +      params = %{ +        "group" => ":pleroma", +        "key" => ":welcome", +        "value" => [ +          %{ +            "tuple" => [ +              ":direct_message", +              [ +                %{"tuple" => [":enabled", true]}, +                %{"tuple" => [":message", "Welcome to Pleroma!"]}, +                %{"tuple" => [":sender_nickname", "pleroma"]} +              ] +            ] +          }, +          %{ +            "tuple" => [ +              ":chat_message", +              [ +                %{"tuple" => [":enabled", true]}, +                %{"tuple" => [":message", "Welcome to Pleroma!"]}, +                %{"tuple" => [":sender_nickname", "pleroma"]} +              ] +            ] +          }, +          %{ +            "tuple" => [ +              ":email", +              [ +                %{"tuple" => [":enabled", true]}, +                %{"tuple" => [":sender", %{"tuple" => ["pleroma@dev.dev", "Pleroma"]}]}, +                %{"tuple" => [":subject", "Welcome to <%= instance_name %>!"]}, +                %{"tuple" => [":html", "Welcome to <%= instance_name %>!"]}, +                %{"tuple" => [":text", "Welcome to <%= instance_name %>!"]} +              ] +            ] +          } +        ] +      } + +      refute Pleroma.User.WelcomeEmail.enabled?() +      refute Pleroma.User.WelcomeMessage.enabled?() +      refute Pleroma.User.WelcomeChatMessage.enabled?() + +      res = +        assert conn +               |> put_req_header("content-type", "application/json") +               |> post("/api/pleroma/admin/config", %{"configs" => [params]}) +               |> json_response_and_validate_schema(200) + +      assert Pleroma.User.WelcomeEmail.enabled?() +      assert Pleroma.User.WelcomeMessage.enabled?() +      assert Pleroma.User.WelcomeChatMessage.enabled?() + +      assert res == %{ +               "configs" => [ +                 %{ +                   "db" => [":direct_message", ":chat_message", ":email"], +                   "group" => ":pleroma", +                   "key" => ":welcome", +                   "value" => params["value"] +                 } +               ], +               "need_reboot" => false +             } +    end    end    describe "GET /api/pleroma/admin/config/descriptions" do | 
