aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorfeld <feld@feld.me>2020-01-28 14:52:57 +0000
committerfeld <feld@feld.me>2020-01-28 14:52:57 +0000
commitd9cb8acd3e43f2b3502f2b08ce469483c67789f6 (patch)
treed9820c0f25a2d2ab7606de30597a095a194969fc /test
parentffa9e3a2ce7c9fee281aae429052eb6e1d736239 (diff)
parentd18a2e4e360bd6e630101a7dd2f4ae0902ac43a1 (diff)
downloadpleroma-d9cb8acd3e43f2b3502f2b08ce469483c67789f6.tar.gz
Merge branch 'fix/attachments-cleanup' into 'develop'
Fix attachments cleanup with custom base_url See merge request pleroma/pleroma!2154
Diffstat (limited to 'test')
-rw-r--r--test/object_test.exs33
1 files changed, 33 insertions, 0 deletions
diff --git a/test/object_test.exs b/test/object_test.exs
index 9b4e6f0bf..c6b2bc399 100644
--- a/test/object_test.exs
+++ b/test/object_test.exs
@@ -177,6 +177,39 @@ defmodule Pleroma.ObjectTest do
assert {:ok, []} == File.ls("#{uploads_dir}/#{path}")
end
+
+ test "With custom base_url" do
+ Pleroma.Config.put([Pleroma.Upload, :uploader], Pleroma.Uploaders.Local)
+ Pleroma.Config.put([Pleroma.Upload, :base_url], "https://sub.domain.tld/dir/")
+
+ file = %Plug.Upload{
+ content_type: "image/jpg",
+ path: Path.absname("test/fixtures/image.jpg"),
+ filename: "an_image.jpg"
+ }
+
+ user = insert(:user)
+
+ {:ok, %Object{} = attachment} =
+ Pleroma.Web.ActivityPub.ActivityPub.upload(file, actor: user.ap_id)
+
+ %{data: %{"attachment" => [%{"url" => [%{"href" => href}]}]}} =
+ note = insert(:note, %{user: user, data: %{"attachment" => [attachment.data]}})
+
+ uploads_dir = Pleroma.Config.get!([Pleroma.Uploaders.Local, :uploads])
+
+ path = href |> Path.dirname() |> Path.basename()
+
+ assert {:ok, ["an_image.jpg"]} == File.ls("#{uploads_dir}/#{path}")
+
+ Object.delete(note)
+
+ ObanHelpers.perform(all_enqueued(worker: Pleroma.Workers.AttachmentsCleanupWorker))
+
+ assert Object.get_by_id(attachment.id) == nil
+
+ assert {:ok, []} == File.ls("#{uploads_dir}/#{path}")
+ end
end
describe "normalizer" do