logo

pleroma

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

delete_handling_test.exs (3538B)


  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 Pleroma.Web.ActivityPub.Transmogrifier.DeleteHandlingTest do
  5. use Oban.Testing, repo: Pleroma.Repo
  6. use Pleroma.DataCase
  7. alias Pleroma.Activity
  8. alias Pleroma.Object
  9. alias Pleroma.Tests.ObanHelpers
  10. alias Pleroma.User
  11. alias Pleroma.Web.ActivityPub.Transmogrifier
  12. import Pleroma.Factory
  13. setup_all do
  14. Tesla.Mock.mock_global(fn env -> apply(HttpRequestMock, :request, [env]) end)
  15. :ok
  16. end
  17. test "it works for incoming deletes" do
  18. activity = insert(:note_activity)
  19. deleting_user = insert(:user)
  20. data =
  21. File.read!("test/fixtures/mastodon-delete.json")
  22. |> Jason.decode!()
  23. |> Map.put("actor", deleting_user.ap_id)
  24. |> put_in(["object", "id"], activity.data["object"])
  25. {:ok, %Activity{actor: actor, local: false, data: %{"id" => id}}} =
  26. Transmogrifier.handle_incoming(data)
  27. assert id == data["id"]
  28. # We delete the Create activity because we base our timelines on it.
  29. # This should be changed after we unify objects and activities
  30. refute Activity.get_by_id(activity.id)
  31. assert actor == deleting_user.ap_id
  32. # Objects are replaced by a tombstone object.
  33. object = Object.normalize(activity.data["object"], fetch: false)
  34. assert object.data["type"] == "Tombstone"
  35. end
  36. test "it works for incoming when the object has been pruned" do
  37. activity = insert(:note_activity)
  38. {:ok, object} =
  39. Object.normalize(activity.data["object"], fetch: false)
  40. |> Repo.delete()
  41. # TODO: mock cachex
  42. Cachex.del(:object_cache, "object:#{object.data["id"]}")
  43. deleting_user = insert(:user)
  44. data =
  45. File.read!("test/fixtures/mastodon-delete.json")
  46. |> Jason.decode!()
  47. |> Map.put("actor", deleting_user.ap_id)
  48. |> put_in(["object", "id"], activity.data["object"])
  49. {:ok, %Activity{actor: actor, local: false, data: %{"id" => id}}} =
  50. Transmogrifier.handle_incoming(data)
  51. assert id == data["id"]
  52. # We delete the Create activity because we base our timelines on it.
  53. # This should be changed after we unify objects and activities
  54. refute Activity.get_by_id(activity.id)
  55. assert actor == deleting_user.ap_id
  56. end
  57. test "it fails for incoming deletes with spoofed origin" do
  58. activity = insert(:note_activity)
  59. %{ap_id: ap_id} = insert(:user, ap_id: "https://gensokyo.2hu/users/raymoo")
  60. data =
  61. File.read!("test/fixtures/mastodon-delete.json")
  62. |> Jason.decode!()
  63. |> Map.put("actor", ap_id)
  64. |> put_in(["object", "id"], activity.data["object"])
  65. assert match?({:error, _}, Transmogrifier.handle_incoming(data))
  66. end
  67. @tag capture_log: true
  68. test "it works for incoming user deletes" do
  69. %{ap_id: ap_id} = insert(:user, ap_id: "http://mastodon.example.org/users/admin")
  70. data =
  71. File.read!("test/fixtures/mastodon-delete-user.json")
  72. |> Jason.decode!()
  73. {:ok, _} = Transmogrifier.handle_incoming(data)
  74. ObanHelpers.perform_all()
  75. refute User.get_cached_by_ap_id(ap_id).is_active
  76. end
  77. test "it fails for incoming user deletes with spoofed origin" do
  78. %{ap_id: ap_id} = insert(:user)
  79. data =
  80. File.read!("test/fixtures/mastodon-delete-user.json")
  81. |> Jason.decode!()
  82. |> Map.put("actor", ap_id)
  83. assert match?({:error, _}, Transmogrifier.handle_incoming(data))
  84. assert User.get_cached_by_ap_id(ap_id)
  85. end
  86. end