2018-12-23 20:11:29 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
2023-01-01 11:11:47 +00:00
|
|
|
# Copyright © 2017-2023 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 20:11:29 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-12-16 16:04:31 +00:00
|
|
|
defmodule Mix.Tasks.Pleroma.RelayTest do
|
|
|
|
alias Pleroma.Activity
|
2019-03-05 02:52:23 +00:00
|
|
|
alias Pleroma.User
|
2019-02-10 21:57:38 +00:00
|
|
|
alias Pleroma.Web.ActivityPub.ActivityPub
|
|
|
|
alias Pleroma.Web.ActivityPub.Relay
|
2019-03-05 02:52:23 +00:00
|
|
|
alias Pleroma.Web.ActivityPub.Utils
|
2018-12-16 16:04:31 +00:00
|
|
|
use Pleroma.DataCase
|
|
|
|
|
2020-07-08 15:07:24 +00:00
|
|
|
import Pleroma.Factory
|
|
|
|
|
2018-12-16 16:04:31 +00:00
|
|
|
setup_all do
|
|
|
|
Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
|
|
|
|
|
|
|
|
Mix.shell(Mix.Shell.Process)
|
|
|
|
|
|
|
|
on_exit(fn ->
|
|
|
|
Mix.shell(Mix.Shell.IO)
|
|
|
|
end)
|
|
|
|
|
|
|
|
:ok
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "running follow" do
|
|
|
|
test "relay is followed" do
|
|
|
|
target_instance = "http://mastodon.example.org/users/admin"
|
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
|
|
|
|
|
|
|
|
local_user = Relay.get_actor()
|
|
|
|
assert local_user.ap_id =~ "/relay"
|
|
|
|
|
2019-04-22 07:20:43 +00:00
|
|
|
target_user = User.get_cached_by_ap_id(target_instance)
|
2018-12-16 16:04:31 +00:00
|
|
|
refute target_user.local
|
|
|
|
|
|
|
|
activity = Utils.fetch_latest_follow(local_user, target_user)
|
|
|
|
assert activity.data["type"] == "Follow"
|
|
|
|
assert activity.data["actor"] == local_user.ap_id
|
|
|
|
assert activity.data["object"] == target_user.ap_id
|
2020-02-25 13:21:48 +00:00
|
|
|
|
|
|
|
:ok = Mix.Tasks.Pleroma.Relay.run(["list"])
|
2020-08-18 15:21:34 +00:00
|
|
|
|
|
|
|
assert_receive {:mix_shell, :info,
|
|
|
|
[
|
|
|
|
"http://mastodon.example.org/users/admin - no Accept received (relay didn't follow back)"
|
|
|
|
]}
|
2018-12-16 16:04:31 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "running unfollow" do
|
|
|
|
test "relay is unfollowed" do
|
2020-07-08 15:07:24 +00:00
|
|
|
user = insert(:user)
|
|
|
|
target_instance = user.ap_id
|
2018-12-16 16:04:31 +00:00
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
|
|
|
|
|
|
|
|
%User{ap_id: follower_id} = local_user = Relay.get_actor()
|
2019-04-22 07:20:43 +00:00
|
|
|
target_user = User.get_cached_by_ap_id(target_instance)
|
2018-12-16 16:04:31 +00:00
|
|
|
follow_activity = Utils.fetch_latest_follow(local_user, target_user)
|
2019-08-23 18:17:14 +00:00
|
|
|
User.follow(local_user, target_user)
|
2019-10-10 19:35:32 +00:00
|
|
|
assert "#{target_instance}/followers" in User.following(local_user)
|
2018-12-16 16:04:31 +00:00
|
|
|
Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance])
|
|
|
|
|
|
|
|
cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
|
|
|
|
assert cancelled_activity.data["state"] == "cancelled"
|
|
|
|
|
|
|
|
[undo_activity] =
|
|
|
|
ActivityPub.fetch_activities([], %{
|
2020-06-04 17:33:16 +00:00
|
|
|
type: "Undo",
|
|
|
|
actor_id: follower_id,
|
|
|
|
limit: 1,
|
|
|
|
skip_preload: true,
|
|
|
|
invisible_actors: true
|
2018-12-16 16:04:31 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
assert undo_activity.data["type"] == "Undo"
|
|
|
|
assert undo_activity.data["actor"] == local_user.ap_id
|
2020-07-08 15:07:24 +00:00
|
|
|
assert undo_activity.data["object"]["id"] == cancelled_activity.data["id"]
|
2019-10-10 19:35:32 +00:00
|
|
|
refute "#{target_instance}/followers" in User.following(local_user)
|
2018-12-16 16:04:31 +00:00
|
|
|
end
|
2020-09-28 06:16:42 +00:00
|
|
|
|
|
|
|
test "unfollow when relay is dead" do
|
|
|
|
user = insert(:user)
|
|
|
|
target_instance = user.ap_id
|
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
|
|
|
|
|
|
|
|
%User{ap_id: follower_id} = local_user = Relay.get_actor()
|
|
|
|
target_user = User.get_cached_by_ap_id(target_instance)
|
|
|
|
follow_activity = Utils.fetch_latest_follow(local_user, target_user)
|
|
|
|
User.follow(local_user, target_user)
|
|
|
|
|
|
|
|
assert "#{target_instance}/followers" in User.following(local_user)
|
|
|
|
|
|
|
|
Tesla.Mock.mock(fn %{method: :get, url: ^target_instance} ->
|
|
|
|
%Tesla.Env{status: 404}
|
|
|
|
end)
|
|
|
|
|
|
|
|
Pleroma.Repo.delete(user)
|
2020-12-18 12:18:17 +00:00
|
|
|
User.invalidate_cache(user)
|
2020-09-28 06:16:42 +00:00
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance])
|
|
|
|
|
|
|
|
cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
|
|
|
|
assert cancelled_activity.data["state"] == "accept"
|
|
|
|
|
|
|
|
assert [] ==
|
|
|
|
ActivityPub.fetch_activities(
|
|
|
|
[],
|
|
|
|
%{
|
|
|
|
type: "Undo",
|
|
|
|
actor_id: follower_id,
|
|
|
|
skip_preload: true,
|
|
|
|
invisible_actors: true
|
|
|
|
}
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "force unfollow when relay is dead" do
|
|
|
|
user = insert(:user)
|
|
|
|
target_instance = user.ap_id
|
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
|
|
|
|
|
|
|
|
%User{ap_id: follower_id} = local_user = Relay.get_actor()
|
|
|
|
target_user = User.get_cached_by_ap_id(target_instance)
|
|
|
|
follow_activity = Utils.fetch_latest_follow(local_user, target_user)
|
|
|
|
User.follow(local_user, target_user)
|
|
|
|
|
|
|
|
assert "#{target_instance}/followers" in User.following(local_user)
|
|
|
|
|
|
|
|
Tesla.Mock.mock(fn %{method: :get, url: ^target_instance} ->
|
|
|
|
%Tesla.Env{status: 404}
|
|
|
|
end)
|
|
|
|
|
|
|
|
Pleroma.Repo.delete(user)
|
2020-12-18 12:18:17 +00:00
|
|
|
User.invalidate_cache(user)
|
2020-09-28 06:16:42 +00:00
|
|
|
|
|
|
|
Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance, "--force"])
|
|
|
|
|
|
|
|
cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
|
|
|
|
assert cancelled_activity.data["state"] == "cancelled"
|
|
|
|
|
|
|
|
[undo_activity] =
|
|
|
|
ActivityPub.fetch_activities(
|
|
|
|
[],
|
|
|
|
%{type: "Undo", actor_id: follower_id, skip_preload: true, invisible_actors: true}
|
|
|
|
)
|
|
|
|
|
|
|
|
assert undo_activity.data["type"] == "Undo"
|
|
|
|
assert undo_activity.data["actor"] == local_user.ap_id
|
|
|
|
assert undo_activity.data["object"]["id"] == cancelled_activity.data["id"]
|
|
|
|
refute "#{target_instance}/followers" in User.following(local_user)
|
|
|
|
end
|
2018-12-16 16:04:31 +00:00
|
|
|
end
|
2019-08-19 10:31:56 +00:00
|
|
|
|
|
|
|
describe "mix pleroma.relay list" do
|
|
|
|
test "Prints relay subscription list" do
|
|
|
|
:ok = Mix.Tasks.Pleroma.Relay.run(["list"])
|
|
|
|
|
|
|
|
refute_receive {:mix_shell, :info, _}
|
|
|
|
|
2019-10-10 19:35:32 +00:00
|
|
|
relay_user = Relay.get_actor()
|
|
|
|
|
|
|
|
["http://mastodon.example.org/users/admin", "https://mstdn.io/users/mayuutann"]
|
|
|
|
|> Enum.each(fn ap_id ->
|
|
|
|
{:ok, user} = User.get_or_fetch_by_ap_id(ap_id)
|
|
|
|
User.follow(relay_user, user)
|
|
|
|
end)
|
2019-08-19 10:31:56 +00:00
|
|
|
|
|
|
|
:ok = Mix.Tasks.Pleroma.Relay.run(["list"])
|
|
|
|
|
2020-08-18 15:21:34 +00:00
|
|
|
assert_receive {:mix_shell, :info, ["https://mstdn.io/users/mayuutann"]}
|
|
|
|
assert_receive {:mix_shell, :info, ["http://mastodon.example.org/users/admin"]}
|
2019-08-19 10:31:56 +00:00
|
|
|
end
|
|
|
|
end
|
2018-12-16 16:04:31 +00:00
|
|
|
end
|