logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma git clone https://hacktivis.me/git/pleroma.git

relay_test.exs (5904B)


  1. # Pleroma: A lightweight social networking server
  2. # Copyright © 2017-2022 Pleroma Authors <https://pleroma.social/>
  3. # SPDX-License-Identifier: AGPL-3.0-only
  4. defmodule Mix.Tasks.Pleroma.RelayTest do
  5. alias Pleroma.Activity
  6. alias Pleroma.User
  7. alias Pleroma.Web.ActivityPub.ActivityPub
  8. alias Pleroma.Web.ActivityPub.Relay
  9. alias Pleroma.Web.ActivityPub.Utils
  10. use Pleroma.DataCase
  11. import Pleroma.Factory
  12. setup_all do
  13. Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
  14. Mix.shell(Mix.Shell.Process)
  15. on_exit(fn ->
  16. Mix.shell(Mix.Shell.IO)
  17. end)
  18. :ok
  19. end
  20. describe "running follow" do
  21. test "relay is followed" do
  22. target_instance = "http://mastodon.example.org/users/admin"
  23. Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
  24. local_user = Relay.get_actor()
  25. assert local_user.ap_id =~ "/relay"
  26. target_user = User.get_cached_by_ap_id(target_instance)
  27. refute target_user.local
  28. activity = Utils.fetch_latest_follow(local_user, target_user)
  29. assert activity.data["type"] == "Follow"
  30. assert activity.data["actor"] == local_user.ap_id
  31. assert activity.data["object"] == target_user.ap_id
  32. :ok = Mix.Tasks.Pleroma.Relay.run(["list"])
  33. assert_receive {:mix_shell, :info,
  34. [
  35. "http://mastodon.example.org/users/admin - no Accept received (relay didn't follow back)"
  36. ]}
  37. end
  38. end
  39. describe "running unfollow" do
  40. test "relay is unfollowed" do
  41. user = insert(:user)
  42. target_instance = user.ap_id
  43. Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
  44. %User{ap_id: follower_id} = local_user = Relay.get_actor()
  45. target_user = User.get_cached_by_ap_id(target_instance)
  46. follow_activity = Utils.fetch_latest_follow(local_user, target_user)
  47. User.follow(local_user, target_user)
  48. assert "#{target_instance}/followers" in User.following(local_user)
  49. Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance])
  50. cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
  51. assert cancelled_activity.data["state"] == "cancelled"
  52. [undo_activity] =
  53. ActivityPub.fetch_activities([], %{
  54. type: "Undo",
  55. actor_id: follower_id,
  56. limit: 1,
  57. skip_preload: true,
  58. invisible_actors: true
  59. })
  60. assert undo_activity.data["type"] == "Undo"
  61. assert undo_activity.data["actor"] == local_user.ap_id
  62. assert undo_activity.data["object"]["id"] == cancelled_activity.data["id"]
  63. refute "#{target_instance}/followers" in User.following(local_user)
  64. end
  65. test "unfollow when relay is dead" do
  66. user = insert(:user)
  67. target_instance = user.ap_id
  68. Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
  69. %User{ap_id: follower_id} = local_user = Relay.get_actor()
  70. target_user = User.get_cached_by_ap_id(target_instance)
  71. follow_activity = Utils.fetch_latest_follow(local_user, target_user)
  72. User.follow(local_user, target_user)
  73. assert "#{target_instance}/followers" in User.following(local_user)
  74. Tesla.Mock.mock(fn %{method: :get, url: ^target_instance} ->
  75. %Tesla.Env{status: 404}
  76. end)
  77. Pleroma.Repo.delete(user)
  78. User.invalidate_cache(user)
  79. Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance])
  80. cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
  81. assert cancelled_activity.data["state"] == "accept"
  82. assert [] ==
  83. ActivityPub.fetch_activities(
  84. [],
  85. %{
  86. type: "Undo",
  87. actor_id: follower_id,
  88. skip_preload: true,
  89. invisible_actors: true
  90. }
  91. )
  92. end
  93. test "force unfollow when relay is dead" do
  94. user = insert(:user)
  95. target_instance = user.ap_id
  96. Mix.Tasks.Pleroma.Relay.run(["follow", target_instance])
  97. %User{ap_id: follower_id} = local_user = Relay.get_actor()
  98. target_user = User.get_cached_by_ap_id(target_instance)
  99. follow_activity = Utils.fetch_latest_follow(local_user, target_user)
  100. User.follow(local_user, target_user)
  101. assert "#{target_instance}/followers" in User.following(local_user)
  102. Tesla.Mock.mock(fn %{method: :get, url: ^target_instance} ->
  103. %Tesla.Env{status: 404}
  104. end)
  105. Pleroma.Repo.delete(user)
  106. User.invalidate_cache(user)
  107. Mix.Tasks.Pleroma.Relay.run(["unfollow", target_instance, "--force"])
  108. cancelled_activity = Activity.get_by_ap_id(follow_activity.data["id"])
  109. assert cancelled_activity.data["state"] == "cancelled"
  110. [undo_activity] =
  111. ActivityPub.fetch_activities(
  112. [],
  113. %{type: "Undo", actor_id: follower_id, skip_preload: true, invisible_actors: true}
  114. )
  115. assert undo_activity.data["type"] == "Undo"
  116. assert undo_activity.data["actor"] == local_user.ap_id
  117. assert undo_activity.data["object"]["id"] == cancelled_activity.data["id"]
  118. refute "#{target_instance}/followers" in User.following(local_user)
  119. end
  120. end
  121. describe "mix pleroma.relay list" do
  122. test "Prints relay subscription list" do
  123. :ok = Mix.Tasks.Pleroma.Relay.run(["list"])
  124. refute_receive {:mix_shell, :info, _}
  125. relay_user = Relay.get_actor()
  126. ["http://mastodon.example.org/users/admin", "https://mstdn.io/users/mayuutann"]
  127. |> Enum.each(fn ap_id ->
  128. {:ok, user} = User.get_or_fetch_by_ap_id(ap_id)
  129. User.follow(relay_user, user)
  130. end)
  131. :ok = Mix.Tasks.Pleroma.Relay.run(["list"])
  132. assert_receive {:mix_shell, :info, ["https://mstdn.io/users/mayuutann"]}
  133. assert_receive {:mix_shell, :info, ["http://mastodon.example.org/users/admin"]}
  134. end
  135. end
  136. end