diff options
| author | sxsdv1 <sxsdv1@gmail.com> | 2019-01-01 23:19:40 +0100 | 
|---|---|---|
| committer | sxsdv1 <sxsdv1@gmail.com> | 2019-01-01 23:20:43 +0100 | 
| commit | 4e1cc2bab6ec76af1b6de986561a82887d18f366 (patch) | |
| tree | aa04ba4a3fd68e9bce3e5472b60db2059a26ee7a /test/web/activity_pub | |
| parent | 551c3d9391c0eeb282d750979b8eef5025c41482 (diff) | |
| download | pleroma-4e1cc2bab6ec76af1b6de986561a82887d18f366.tar.gz pleroma-4e1cc2bab6ec76af1b6de986561a82887d18f366.zip | |
Implement delete activity
Diffstat (limited to 'test/web/activity_pub')
| -rw-r--r-- | test/web/activity_pub/activity_pub_controller_test.exs | 49 | 
1 files changed, 47 insertions, 2 deletions
| diff --git a/test/web/activity_pub/activity_pub_controller_test.exs b/test/web/activity_pub/activity_pub_controller_test.exs index 77dc96617..620e03674 100644 --- a/test/web/activity_pub/activity_pub_controller_test.exs +++ b/test/web/activity_pub/activity_pub_controller_test.exs @@ -6,7 +6,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do    use Pleroma.Web.ConnCase    import Pleroma.Factory    alias Pleroma.Web.ActivityPub.{UserView, ObjectView} -  alias Pleroma.{Repo, User} +  alias Pleroma.{Object, Repo, User}    alias Pleroma.Activity    setup_all do @@ -179,7 +179,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do        assert json_response(conn, 403)      end -    test "it inserts an incoming activity into the database", %{conn: conn} do +    test "it inserts an incoming create activity into the database", %{conn: conn} do        data = File.read!("test/fixtures/activitypub-client-post-activity.json") |> Poison.decode!()        user = insert(:user) @@ -209,6 +209,51 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do        assert json_response(conn, 400)      end + +    test "it erects a tombstone when receiving a delete activity", %{conn: conn} do +      note_activity = insert(:note_activity) +      user = User.get_cached_by_ap_id(note_activity.data["actor"]) + +      data = %{ +        type: "Delete", +        object: %{ +          id: note_activity.data["object"]["id"] +        } +      } + +      conn = +        conn +        |> assign(:user, user) +        |> put_req_header("content-type", "application/activity+json") +        |> post("/users/#{user.nickname}/outbox", data) + +      result = json_response(conn, 201) +      assert Activity.get_by_ap_id(result["id"]) + +      object = Object.get_by_ap_id(note_activity.data["object"]["id"]) +      assert object +      assert object.data["type"] == "Tombstone" +    end + +    test "it rejects delete activity of object from other actor", %{conn: conn} do +      note_activity = insert(:note_activity) +      user = insert(:user) + +      data = %{ +        type: "Delete", +        object: %{ +          id: note_activity.data["object"]["id"] +        } +      } + +      conn = +        conn +        |> assign(:user, user) +        |> put_req_header("content-type", "application/activity+json") +        |> post("/users/#{user.nickname}/outbox", data) + +      assert json_response(conn, 400) +    end    end    describe "/users/:nickname/followers" do | 
