diff options
Diffstat (limited to 'test/web/activity_pub')
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 35 | ||||
| -rw-r--r-- | test/web/activity_pub/transmogrifier_test.exs | 70 | 
2 files changed, 104 insertions, 1 deletions
diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index 9adce84b5..081c202b1 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -425,7 +425,40 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do        assert activity.data["type"] == "Undo"        assert activity.data["actor"] == follower.ap_id -      assert activity.data["object"] == follow_activity.data["id"] + +      assert is_map(activity.data["object"]) +      assert activity.data["object"]["type"] == "Follow" +      assert activity.data["object"]["object"] == followed.ap_id +      assert activity.data["object"]["id"] == follow_activity.data["id"] +    end +  end + +  describe "blocking / unblocking" do +    test "creates a block activity" do +      blocker = insert(:user) +      blocked = insert(:user) + +      {:ok, activity} = ActivityPub.block(blocker, blocked) + +      assert activity.data["type"] == "Block" +      assert activity.data["actor"] == blocker.ap_id +      assert activity.data["object"] == blocked.ap_id +    end + +    test "creates an undo activity for the last block" do +      blocker = insert(:user) +      blocked = insert(:user) + +      {:ok, block_activity} = ActivityPub.block(blocker, blocked) +      {:ok, activity} = ActivityPub.unblock(blocker, blocked) + +      assert activity.data["type"] == "Undo" +      assert activity.data["actor"] == blocker.ap_id + +      assert is_map(activity.data["object"]) +      assert activity.data["object"]["type"] == "Block" +      assert activity.data["object"]["object"] == blocked.ap_id +      assert activity.data["object"]["id"] == block_activity.data["id"]      end    end diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index a0af75a69..cf6b1d0b5 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -315,6 +315,76 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        assert data["object"]["id"] ==                 "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity"      end + +    test "it works for incomming unfollows with an existing follow" do +      user = insert(:user) + +      follow_data = +        File.read!("test/fixtures/mastodon-follow-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: _, local: false}} = Transmogrifier.handle_incoming(follow_data) + +      data = +        File.read!("test/fixtures/mastodon-unfollow-activity.json") +        |> Poison.decode!() +        |> Map.put("object", follow_data) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Undo" +      assert data["object"]["type"] == "Follow" +      assert data["object"]["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      refute User.following?(User.get_by_ap_id(data["actor"]), user) +    end + +    test "it works for incoming blocks" do +      user = insert(:user) + +      data = +        File.read!("test/fixtures/mastodon-block-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Block" +      assert data["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      blocker = User.get_by_ap_id(data["actor"]) + +      assert User.blocks?(blocker, user) +    end + +    test "it works for incoming unblocks with an existing block" do +      user = insert(:user) + +      block_data = +        File.read!("test/fixtures/mastodon-block-activity.json") +        |> Poison.decode!() +        |> Map.put("object", user.ap_id) + +      {:ok, %Activity{data: _, local: false}} = Transmogrifier.handle_incoming(block_data) + +      data = +        File.read!("test/fixtures/mastodon-unblock-activity.json") +        |> Poison.decode!() +        |> Map.put("object", block_data) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) +      assert data["type"] == "Undo" +      assert data["object"]["type"] == "Block" +      assert data["object"]["object"] == user.ap_id +      assert data["actor"] == "http://mastodon.example.org/users/admin" + +      blocker = User.get_by_ap_id(data["actor"]) + +      refute User.blocks?(blocker, user) +    end    end    describe "prepare outgoing" do  | 
