diff options
| author | Mark Felder <feld@FreeBSD.org> | 2020-08-25 11:57:23 -0500 | 
|---|---|---|
| committer | Mark Felder <feld@FreeBSD.org> | 2020-08-25 11:57:23 -0500 | 
| commit | 479578b148f28f311a7d20f6da99bbc0dab1652c (patch) | |
| tree | 2b0e5bfe6bfa5c4b954b9442d4d2a1d4ad4bc8cf /test/web/activity_pub | |
| parent | 98f8851f29f940051656caa1715820bce70f8c29 (diff) | |
| parent | 361aa22e2862c1c914baf8257fdc8b20cbc7941d (diff) | |
| download | pleroma-479578b148f28f311a7d20f6da99bbc0dab1652c.tar.gz pleroma-479578b148f28f311a7d20f6da99bbc0dab1652c.zip | |
Merge branch 'develop' into feld-2168-media-preview-proxy
Diffstat (limited to 'test/web/activity_pub')
5 files changed, 109 insertions, 3 deletions
| diff --git a/test/web/activity_pub/activity_pub_controller_test.exs b/test/web/activity_pub/activity_pub_controller_test.exs index ed900d8f8..57988dc1e 100644 --- a/test/web/activity_pub/activity_pub_controller_test.exs +++ b/test/web/activity_pub/activity_pub_controller_test.exs @@ -533,7 +533,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubControllerTest do        end)        :ok = Mix.Tasks.Pleroma.Relay.run(["list"]) -      assert_receive {:mix_shell, :info, ["relay.mastodon.host"]} +      assert_receive {:mix_shell, :info, ["https://relay.mastodon.host/actor"]}      end      @tag capture_log: true diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs index d6eab7337..03f968aaf 100644 --- a/test/web/activity_pub/activity_pub_test.exs +++ b/test/web/activity_pub/activity_pub_test.exs @@ -990,13 +990,39 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do    end    describe "uploading files" do -    test "copies the file to the configured folder" do -      file = %Plug.Upload{ +    setup do +      test_file = %Plug.Upload{          content_type: "image/jpg",          path: Path.absname("test/fixtures/image.jpg"),          filename: "an_image.jpg"        } +      %{test_file: test_file} +    end + +    test "sets a description if given", %{test_file: file} do +      {:ok, %Object{} = object} = ActivityPub.upload(file, description: "a cool file") +      assert object.data["name"] == "a cool file" +    end + +    test "it sets the default description depending on the configuration", %{test_file: file} do +      clear_config([Pleroma.Upload, :default_description]) + +      Pleroma.Config.put([Pleroma.Upload, :default_description], nil) +      {:ok, %Object{} = object} = ActivityPub.upload(file) +      assert object.data["name"] == "" + +      Pleroma.Config.put([Pleroma.Upload, :default_description], :filename) +      {:ok, %Object{} = object} = ActivityPub.upload(file) +      assert object.data["name"] == "an_image.jpg" + +      Pleroma.Config.put([Pleroma.Upload, :default_description], "unnamed attachment") +      {:ok, %Object{} = object} = ActivityPub.upload(file) +      assert object.data["name"] == "unnamed attachment" +    end + +    test "copies the file to the configured folder", %{test_file: file} do +      clear_config([Pleroma.Upload, :default_description], :filename)        {:ok, %Object{} = object} = ActivityPub.upload(file)        assert object.data["name"] == "an_image.jpg"      end diff --git a/test/web/activity_pub/transmogrifier/audio_handling_test.exs b/test/web/activity_pub/transmogrifier/audio_handling_test.exs index c74a9c45d..0636d00c5 100644 --- a/test/web/activity_pub/transmogrifier/audio_handling_test.exs +++ b/test/web/activity_pub/transmogrifier/audio_handling_test.exs @@ -42,4 +42,42 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier.AudioHandlingTest do      assert object.data["album"] == "lain radio"      assert object.data["length"] == 180_000    end + +  test "Funkwhale Audio object" do +    Tesla.Mock.mock(fn +      %{url: "https://channels.tests.funkwhale.audio/federation/actors/compositions"} -> +        %Tesla.Env{ +          status: 200, +          body: File.read!("test/fixtures/tesla_mock/funkwhale_channel.json") +        } +    end) + +    data = File.read!("test/fixtures/tesla_mock/funkwhale_create_audio.json") |> Poison.decode!() + +    {:ok, %Activity{local: false} = activity} = Transmogrifier.handle_incoming(data) + +    assert object = Object.normalize(activity, false) + +    assert object.data["to"] == ["https://www.w3.org/ns/activitystreams#Public"] + +    assert object.data["cc"] == [] + +    assert object.data["url"] == "https://channels.tests.funkwhale.audio/library/tracks/74" + +    assert object.data["attachment"] == [ +             %{ +               "mediaType" => "audio/ogg", +               "type" => "Link", +               "name" => nil, +               "url" => [ +                 %{ +                   "href" => +                     "https://channels.tests.funkwhale.audio/api/v1/listen/3901e5d8-0445-49d5-9711-e096cf32e515/?upload=42342395-0208-4fee-a38d-259a6dae0871&download=false", +                   "mediaType" => "audio/ogg", +                   "type" => "Link" +                 } +               ] +             } +           ] +  end  end diff --git a/test/web/activity_pub/transmogrifier/event_handling_test.exs b/test/web/activity_pub/transmogrifier/event_handling_test.exs new file mode 100644 index 000000000..7f1ef2cbd --- /dev/null +++ b/test/web/activity_pub/transmogrifier/event_handling_test.exs @@ -0,0 +1,40 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.ActivityPub.Transmogrifier.EventHandlingTest do +  use Oban.Testing, repo: Pleroma.Repo +  use Pleroma.DataCase + +  alias Pleroma.Object.Fetcher + +  test "Mobilizon Event object" do +    Tesla.Mock.mock(fn +      %{url: "https://mobilizon.org/events/252d5816-00a3-4a89-a66f-15bf65c33e39"} -> +        %Tesla.Env{ +          status: 200, +          body: File.read!("test/fixtures/tesla_mock/mobilizon.org-event.json") +        } + +      %{url: "https://mobilizon.org/@tcit"} -> +        %Tesla.Env{ +          status: 200, +          body: File.read!("test/fixtures/tesla_mock/mobilizon.org-user.json") +        } +    end) + +    assert {:ok, object} = +             Fetcher.fetch_object_from_id( +               "https://mobilizon.org/events/252d5816-00a3-4a89-a66f-15bf65c33e39" +             ) + +    assert object.data["to"] == ["https://www.w3.org/ns/activitystreams#Public"] +    assert object.data["cc"] == [] + +    assert object.data["url"] == +             "https://mobilizon.org/events/252d5816-00a3-4a89-a66f-15bf65c33e39" + +    assert object.data["published"] == "2019-12-17T11:33:56Z" +    assert object.data["name"] == "Mobilizon Launching Party" +  end +end diff --git a/test/web/activity_pub/transmogrifier/question_handling_test.exs b/test/web/activity_pub/transmogrifier/question_handling_test.exs index 9fb965d7f..c82361828 100644 --- a/test/web/activity_pub/transmogrifier/question_handling_test.exs +++ b/test/web/activity_pub/transmogrifier/question_handling_test.exs @@ -24,6 +24,8 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier.QuestionHandlingTest do      object = Object.normalize(activity, false) +    assert object.data["url"] == "https://mastodon.sdf.org/@rinpatch/102070944809637304" +      assert object.data["closed"] == "2019-05-11T09:03:36Z"      assert object.data["context"] == activity.data["context"] | 
