2018-12-23 13:11:29 -07:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-12 23:49:20 -07:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 13:11:29 -07:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-12-16 09:04:31 -07:00
|
|
|
defmodule Mix.Tasks.Pleroma.UploadsTest do
|
|
|
|
alias Pleroma.Upload
|
2023-08-01 04:43:50 -06:00
|
|
|
use Pleroma.DataCase, async: false
|
2023-08-04 05:50:50 -06:00
|
|
|
@moduletag :mocked
|
2018-12-16 09:04:31 -07:00
|
|
|
|
|
|
|
import Mock
|
|
|
|
|
|
|
|
setup_all do
|
|
|
|
Mix.shell(Mix.Shell.Process)
|
|
|
|
|
|
|
|
on_exit(fn ->
|
|
|
|
Mix.shell(Mix.Shell.IO)
|
|
|
|
end)
|
|
|
|
|
|
|
|
:ok
|
|
|
|
end
|
|
|
|
|
2023-08-04 05:59:33 -06:00
|
|
|
setup do: clear_config([Pleroma.Upload, :uploader], Pleroma.Uploaders.Local)
|
|
|
|
|
2018-12-16 09:04:31 -07:00
|
|
|
describe "running migrate_local" do
|
|
|
|
test "uploads migrated" do
|
2023-08-04 05:59:33 -06:00
|
|
|
File.copy!("test/fixtures/video.mp4", "test/uploads/video.mp4")
|
|
|
|
|
2018-12-16 09:04:31 -07:00
|
|
|
with_mock Upload,
|
|
|
|
store: fn %Upload{name: _file, path: _path}, _opts -> {:ok, %{}} end do
|
|
|
|
Mix.Tasks.Pleroma.Uploads.run(["migrate_local", "S3"])
|
|
|
|
|
2023-08-04 05:59:33 -06:00
|
|
|
assert_receive {:mix_shell, :info, [message]}, 1_000
|
2018-12-16 09:04:31 -07:00
|
|
|
assert message =~ "Migrating files from local"
|
|
|
|
|
2023-08-04 05:59:33 -06:00
|
|
|
assert_receive {:mix_shell, :info, [message]}, 1_000
|
2018-12-16 09:04:31 -07:00
|
|
|
|
|
|
|
assert %{"total_count" => total_count} =
|
|
|
|
Regex.named_captures(~r"^Found (?<total_count>\d+) uploads$", message)
|
|
|
|
|
2023-08-04 05:59:33 -06:00
|
|
|
assert_receive {:mix_shell, :info, [message]}, 1_000
|
2018-12-16 09:04:31 -07:00
|
|
|
|
2018-12-17 12:55:24 -07:00
|
|
|
count =
|
|
|
|
min(50, String.to_integer(total_count))
|
|
|
|
|> to_string()
|
|
|
|
|
|
|
|
assert %{"count" => ^count, "total_count" => ^total_count} =
|
2018-12-16 09:04:31 -07:00
|
|
|
Regex.named_captures(
|
|
|
|
~r"^Uploaded (?<count>\d+)/(?<total_count>\d+) files$",
|
|
|
|
message
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "nonexistent uploader" do
|
|
|
|
assert_raise RuntimeError, ~r/The uploader .* is not an existing/, fn ->
|
|
|
|
Mix.Tasks.Pleroma.Uploads.run(["migrate_local", "nonexistent"])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|