diff options
| author | lain <lain@soykaf.club> | 2018-05-13 11:59:35 +0200 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2018-05-13 11:59:35 +0200 | 
| commit | a5c9dd0a2aa792ed075c6ff83b1de262a1529026 (patch) | |
| tree | cde89f940be50a6ad13d3acc0a0c15d237ca7d96 /test | |
| parent | 3c3933e40bce7001b5025bf2e05412dd9c128f0f (diff) | |
| parent | aeff2d647483d5348cc1da5c901ce55f1c02b733 (diff) | |
| download | pleroma-a5c9dd0a2aa792ed075c6ff83b1de262a1529026.tar.gz pleroma-a5c9dd0a2aa792ed075c6ff83b1de262a1529026.zip | |
Merge branch 'develop' of git.pleroma.social:pleroma/pleroma into develop
Diffstat (limited to 'test')
| -rw-r--r-- | test/fixtures/mastodon-undo-announce.json | 47 | ||||
| -rw-r--r-- | test/web/activity_pub/activity_pub_test.exs | 32 | ||||
| -rw-r--r-- | test/web/activity_pub/transmogrifier_test.exs | 28 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 18 | 
4 files changed, 125 insertions, 0 deletions
| diff --git a/test/fixtures/mastodon-undo-announce.json b/test/fixtures/mastodon-undo-announce.json new file mode 100644 index 000000000..05332bed2 --- /dev/null +++ b/test/fixtures/mastodon-undo-announce.json @@ -0,0 +1,47 @@ +{ +   "type": "Undo", +   "signature": { +     "type": "RsaSignature2017", +     "signatureValue": "VU9AmHf3Pus9cWtMG/TOdxr+MRQfPHdTVKBBgFJBXhAlMhxEtcbxsu7zmqBgfIz6u0HpTCi5jRXEMftc228OJf/aBUkr4hyWADgcdmhPQgpibouDLgQf9BmnrPqb2rMbzZyt49GJkQZma8taLh077TTq6OKcnsAAJ1evEKOcRYS4OxBSwh4nI726bOXzZWoNzpTcrnm+llcUEN980sDSAS0uyZdb8AxZdfdG6DJQX4AkUD5qTpfqP/vC1ISirrNphvVhlxjUV9Amr4SYTsLx80vdZe5NjeL5Ir4jTIIQLedpxaDu1M9Q+Jpc0fYByQ2hOwUq8JxEmvHvarKjrq0Oww==", +     "creator": "http://mastodon.example.org/users/admin#main-key", +     "created": "2018-05-11T16:23:45Z" +   }, +   "object": { +     "type": "Announce", +     "to": [ +       "http://www.w3.org/ns/activitystreams#Public" +     ], +     "published": "2018-05-11T16:23:37Z", +     "object": "http://mastodon.example.org/@admin/99541947525187367", +     "id": "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity", +     "cc": [ +       "http://mastodon.example.org/users/admin", +       "http://mastodon.example.org/users/admin/followers" +     ], +     "atomUri": "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity", +     "actor": "http://mastodon.example.org/users/admin" +   }, +   "id": "http://mastodon.example.org/users/admin#announces/100011594053806179/undo", +   "actor": "http://mastodon.example.org/users/admin", +   "@context": [ +     "http://www.w3.org/ns/activitystreams", +     "http://w3id.org/security/v1", +     { +       "toot": "http://joinmastodon.org/ns#", +       "sensitive": "as:sensitive", +       "ostatus": "http://ostatus.org#", +       "movedTo": "as:movedTo", +       "manuallyApprovesFollowers": "as:manuallyApprovesFollowers", +       "inReplyToAtomUri": "ostatus:inReplyToAtomUri", +       "focalPoint": { +         "@id": "toot:focalPoint", +         "@container": "@list" +       }, +       "featured": "toot:featured", +       "conversation": "ostatus:conversation", +       "atomUri": "ostatus:atomUri", +       "Hashtag": "as:Hashtag", +       "Emoji": "toot:Emoji" +     } +   ] +} diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index d336fad95..a39ba9adb 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -302,6 +302,38 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do      end    end +  describe "unannouncing an object" do +    test "unannouncing a previously announced object" do +      note_activity = insert(:note_activity) +      object = Object.get_by_ap_id(note_activity.data["object"]["id"]) +      user = insert(:user) + +      # Unannouncing an object that is not announced does nothing +      # {:ok, object} = ActivityPub.unannounce(user, object) +      # assert object.data["announcement_count"] == 0 + +      {:ok, announce_activity, object} = ActivityPub.announce(user, object) +      assert object.data["announcement_count"] == 1 + +      {:ok, unannounce_activity, activity, object} = ActivityPub.unannounce(user, object) +      assert object.data["announcement_count"] == 0 + +      assert activity == announce_activity + +      assert unannounce_activity.data["to"] == [ +               User.ap_followers(user), +               announce_activity.data["actor"] +             ] + +      assert unannounce_activity.data["type"] == "Undo" +      assert unannounce_activity.data["object"] == announce_activity.data +      assert unannounce_activity.data["actor"] == user.ap_id +      assert unannounce_activity.data["context"] == announce_activity.data["context"] + +      assert Repo.get(Activity, announce_activity.id) == nil +    end +  end +    describe "uploading files" do      test "copies the file to the configured folder" do        file = %Plug.Upload{ diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index eb093262f..a3408da9d 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -232,6 +232,34 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do        refute Repo.get(Activity, activity.id)      end + +    test "it works for incoming unannounces with an existing notice" do +      user = insert(:user) +      {:ok, activity} = CommonAPI.post(user, %{"status" => "hey"}) + +      announce_data = +        File.read!("test/fixtures/mastodon-announce.json") +        |> Poison.decode!() +        |> Map.put("object", activity.data["object"]["id"]) + +      {:ok, %Activity{data: announce_data, local: false}} = +        Transmogrifier.handle_incoming(announce_data) + +      data = +        File.read!("test/fixtures/mastodon-undo-announce.json") +        |> Poison.decode!() +        |> Map.put("object", announce_data) +        |> Map.put("actor", announce_data["actor"]) + +      {:ok, %Activity{data: data, local: false}} = Transmogrifier.handle_incoming(data) + +      assert data["type"] == "Undo" +      assert data["object"]["type"] == "Announce" +      assert data["object"]["object"] == activity.data["object"]["id"] + +      assert data["object"]["id"] == +               "http://mastodon.example.org/users/admin/statuses/99542391527669785/activity" +    end    end    describe "prepare outgoing" do diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index 883ebc61e..882c92682 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -298,6 +298,24 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do      end    end +  describe "unreblogging" do +    test "unreblogs and returns the unreblogged status", %{conn: conn} do +      activity = insert(:note_activity) +      user = insert(:user) + +      {:ok, _, _} = CommonAPI.repeat(activity.id, user) + +      conn = +        conn +        |> assign(:user, user) +        |> post("/api/v1/statuses/#{activity.id}/unreblog") + +      assert %{"id" => id, "reblogged" => false, "reblogs_count" => 0} = json_response(conn, 200) + +      assert to_string(activity.id) == id +    end +  end +    describe "favoriting" do      test "favs a status and returns it", %{conn: conn} do        activity = insert(:note_activity) | 
