2018-12-23 13:11:29 -07:00
|
|
|
# Pleroma: A lightweight social networking server
|
2022-02-25 23:11:42 -07:00
|
|
|
# Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 13:11:29 -07:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-09-08 06:02:38 -06:00
|
|
|
defmodule Pleroma.Web.ActivityPub.RelayTest do
|
|
|
|
use Pleroma.DataCase
|
|
|
|
|
2019-08-13 15:12:59 -06:00
|
|
|
alias Pleroma.Activity
|
2019-10-10 13:35:32 -06:00
|
|
|
alias Pleroma.User
|
2018-09-08 06:02:38 -06:00
|
|
|
alias Pleroma.Web.ActivityPub.Relay
|
2020-07-08 09:07:24 -06:00
|
|
|
alias Pleroma.Web.CommonAPI
|
2018-09-08 06:02:38 -06:00
|
|
|
|
2019-09-13 09:46:41 -06:00
|
|
|
import ExUnit.CaptureLog
|
2019-08-13 15:12:59 -06:00
|
|
|
import Pleroma.Factory
|
2019-08-24 08:41:53 -06:00
|
|
|
import Mock
|
2019-08-13 15:12:59 -06:00
|
|
|
|
2018-09-08 06:02:38 -06:00
|
|
|
test "gets an actor for the relay" do
|
|
|
|
user = Relay.get_actor()
|
2019-08-13 15:12:59 -06:00
|
|
|
assert user.ap_id == "#{Pleroma.Web.Endpoint.url()}/relay"
|
|
|
|
end
|
|
|
|
|
2019-10-19 11:50:17 -06:00
|
|
|
test "relay actor is invisible" do
|
|
|
|
user = Relay.get_actor()
|
|
|
|
assert User.invisible?(user)
|
|
|
|
end
|
|
|
|
|
2019-08-13 15:12:59 -06:00
|
|
|
describe "follow/1" do
|
|
|
|
test "returns errors when user not found" do
|
2019-09-13 09:46:41 -06:00
|
|
|
assert capture_log(fn ->
|
2019-10-17 20:52:08 -06:00
|
|
|
{:error, _} = Relay.follow("test-ap-id")
|
|
|
|
end) =~ "Could not decode user at fetch"
|
2019-08-13 15:12:59 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test "returns activity" do
|
|
|
|
user = insert(:user)
|
|
|
|
service_actor = Relay.get_actor()
|
|
|
|
assert {:ok, %Activity{} = activity} = Relay.follow(user.ap_id)
|
|
|
|
assert activity.actor == "#{Pleroma.Web.Endpoint.url()}/relay"
|
|
|
|
assert user.ap_id in activity.recipients
|
|
|
|
assert activity.data["type"] == "Follow"
|
|
|
|
assert activity.data["actor"] == service_actor.ap_id
|
|
|
|
assert activity.data["object"] == user.ap_id
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "unfollow/1" do
|
|
|
|
test "returns errors when user not found" do
|
2019-09-13 09:46:41 -06:00
|
|
|
assert capture_log(fn ->
|
2019-10-17 20:52:08 -06:00
|
|
|
{:error, _} = Relay.unfollow("test-ap-id")
|
|
|
|
end) =~ "Could not decode user at fetch"
|
2019-08-13 15:12:59 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test "returns activity" do
|
|
|
|
user = insert(:user)
|
|
|
|
service_actor = Relay.get_actor()
|
2020-07-08 09:07:24 -06:00
|
|
|
CommonAPI.follow(service_actor, user)
|
2019-10-10 13:35:32 -06:00
|
|
|
assert "#{user.ap_id}/followers" in User.following(service_actor)
|
2019-08-13 15:12:59 -06:00
|
|
|
assert {:ok, %Activity{} = activity} = Relay.unfollow(user.ap_id)
|
|
|
|
assert activity.actor == "#{Pleroma.Web.Endpoint.url()}/relay"
|
|
|
|
assert user.ap_id in activity.recipients
|
|
|
|
assert activity.data["type"] == "Undo"
|
|
|
|
assert activity.data["actor"] == service_actor.ap_id
|
|
|
|
assert activity.data["to"] == [user.ap_id]
|
2019-10-10 13:35:32 -06:00
|
|
|
refute "#{user.ap_id}/followers" in User.following(service_actor)
|
2019-08-13 15:12:59 -06:00
|
|
|
end
|
2020-09-28 00:16:42 -06:00
|
|
|
|
|
|
|
test "force unfollow when target service is dead" do
|
|
|
|
user = insert(:user)
|
|
|
|
user_ap_id = user.ap_id
|
|
|
|
user_id = user.id
|
|
|
|
|
|
|
|
Tesla.Mock.mock(fn %{method: :get, url: ^user_ap_id} ->
|
|
|
|
%Tesla.Env{status: 404}
|
|
|
|
end)
|
|
|
|
|
|
|
|
service_actor = Relay.get_actor()
|
|
|
|
CommonAPI.follow(service_actor, user)
|
|
|
|
assert "#{user.ap_id}/followers" in User.following(service_actor)
|
|
|
|
|
|
|
|
assert Pleroma.Repo.get_by(
|
|
|
|
Pleroma.FollowingRelationship,
|
|
|
|
follower_id: service_actor.id,
|
|
|
|
following_id: user_id
|
|
|
|
)
|
|
|
|
|
|
|
|
Pleroma.Repo.delete(user)
|
2020-12-18 05:18:17 -07:00
|
|
|
User.invalidate_cache(user)
|
2020-09-28 00:16:42 -06:00
|
|
|
|
|
|
|
assert {:ok, %Activity{} = activity} = Relay.unfollow(user_ap_id, %{force: true})
|
|
|
|
|
|
|
|
assert refresh_record(service_actor).following_count == 0
|
|
|
|
|
|
|
|
refute Pleroma.Repo.get_by(
|
|
|
|
Pleroma.FollowingRelationship,
|
|
|
|
follower_id: service_actor.id,
|
|
|
|
following_id: user_id
|
|
|
|
)
|
|
|
|
|
|
|
|
assert activity.actor == "#{Pleroma.Web.Endpoint.url()}/relay"
|
|
|
|
assert user.ap_id in activity.recipients
|
|
|
|
assert activity.data["type"] == "Undo"
|
|
|
|
assert activity.data["actor"] == service_actor.ap_id
|
|
|
|
assert activity.data["to"] == [user_ap_id]
|
|
|
|
refute "#{user.ap_id}/followers" in User.following(service_actor)
|
|
|
|
end
|
2019-08-13 15:12:59 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "publish/1" do
|
2020-03-20 09:33:00 -06:00
|
|
|
setup do: clear_config([:instance, :federating])
|
2019-08-24 08:41:53 -06:00
|
|
|
|
2019-08-13 15:12:59 -06:00
|
|
|
test "returns error when activity not `Create` type" do
|
|
|
|
activity = insert(:like_activity)
|
|
|
|
assert Relay.publish(activity) == {:error, "Not implemented"}
|
|
|
|
end
|
|
|
|
|
2020-07-08 09:07:24 -06:00
|
|
|
@tag capture_log: true
|
2019-08-13 15:12:59 -06:00
|
|
|
test "returns error when activity not public" do
|
|
|
|
activity = insert(:direct_note_activity)
|
|
|
|
assert Relay.publish(activity) == {:error, false}
|
|
|
|
end
|
2018-09-08 06:02:38 -06:00
|
|
|
|
2019-08-24 08:41:53 -06:00
|
|
|
test "returns error when object is unknown" do
|
|
|
|
activity =
|
|
|
|
insert(:note_activity,
|
|
|
|
data: %{
|
|
|
|
"type" => "Create",
|
|
|
|
"object" => "http://mastodon.example.org/eee/99541947525187367"
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2020-03-05 07:31:06 -07:00
|
|
|
Tesla.Mock.mock(fn
|
|
|
|
%{method: :get, url: "http://mastodon.example.org/eee/99541947525187367"} ->
|
|
|
|
%Tesla.Env{status: 500, body: ""}
|
|
|
|
end)
|
|
|
|
|
2019-09-13 09:46:41 -06:00
|
|
|
assert capture_log(fn ->
|
2020-05-21 05:16:21 -06:00
|
|
|
assert Relay.publish(activity) == {:error, false}
|
|
|
|
end) =~ "[error] error: false"
|
2019-08-24 08:41:53 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test_with_mock "returns announce activity and publish to federate",
|
|
|
|
Pleroma.Web.Federator,
|
|
|
|
[:passthrough],
|
|
|
|
[] do
|
2020-05-21 05:16:21 -06:00
|
|
|
clear_config([:instance, :federating], true)
|
2019-08-24 08:41:53 -06:00
|
|
|
service_actor = Relay.get_actor()
|
|
|
|
note = insert(:note_activity)
|
2020-05-21 05:16:21 -06:00
|
|
|
assert {:ok, %Activity{} = activity} = Relay.publish(note)
|
2019-08-24 08:41:53 -06:00
|
|
|
assert activity.data["type"] == "Announce"
|
|
|
|
assert activity.data["actor"] == service_actor.ap_id
|
2021-06-08 19:43:01 -06:00
|
|
|
assert service_actor.follower_address in activity.data["to"]
|
2019-08-31 05:25:43 -06:00
|
|
|
assert called(Pleroma.Web.Federator.publish(activity))
|
2019-08-24 08:41:53 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test_with_mock "returns announce activity and not publish to federate",
|
|
|
|
Pleroma.Web.Federator,
|
|
|
|
[:passthrough],
|
|
|
|
[] do
|
2020-05-21 05:16:21 -06:00
|
|
|
clear_config([:instance, :federating], false)
|
2019-08-13 15:12:59 -06:00
|
|
|
service_actor = Relay.get_actor()
|
|
|
|
note = insert(:note_activity)
|
2020-05-21 05:16:21 -06:00
|
|
|
assert {:ok, %Activity{} = activity} = Relay.publish(note)
|
2019-08-13 15:12:59 -06:00
|
|
|
assert activity.data["type"] == "Announce"
|
|
|
|
assert activity.data["actor"] == service_actor.ap_id
|
2019-08-31 05:25:43 -06:00
|
|
|
refute called(Pleroma.Web.Federator.publish(activity))
|
2019-08-13 15:12:59 -06:00
|
|
|
end
|
2018-09-08 06:02:38 -06:00
|
|
|
end
|
|
|
|
end
|