[#878] Merge remote-tracking branch 'remotes/upstream/develop' into 878-activity...
[akkoma] / test / web / ostatus / incoming_documents / delete_handling_test.exs
1 defmodule Pleroma.Web.OStatus.DeleteHandlingTest do
2 use Pleroma.DataCase
3
4 import Pleroma.Factory
5 import Tesla.Mock
6
7 alias Pleroma.Activity
8 alias Pleroma.Object
9 alias Pleroma.Web.OStatus
10
11 setup do
12 mock(fn env -> apply(HttpRequestMock, :request, [env]) end)
13 :ok
14 end
15
16 describe "deletions" do
17 test "it removes the mentioned activity" do
18 note = insert(:note_activity)
19 second_note = insert(:note_activity)
20 object = Object.normalize(note)
21 second_object = Object.normalize(second_note)
22 user = insert(:user)
23
24 {:ok, like, _object} = Pleroma.Web.ActivityPub.ActivityPub.like(user, object)
25
26 incoming =
27 File.read!("test/fixtures/delete.xml")
28 |> String.replace(
29 "tag:mastodon.sdf.org,2017-06-10:objectId=310513:objectType=Status",
30 object.data["id"]
31 )
32
33 {:ok, [delete]} = OStatus.handle_incoming(incoming)
34
35 refute Activity.get_by_id(note.id)
36 refute Activity.get_by_id(like.id)
37 assert Object.get_by_ap_id(object.data["id"]).data["type"] == "Tombstone"
38 assert Activity.get_by_id(second_note.id)
39 assert Object.get_by_ap_id(second_object.data["id"])
40
41 assert delete.data["type"] == "Delete"
42 end
43 end
44 end