2018-12-16 11:04:31 -05:00
|
|
|
defmodule Mix.Tasks.Pleroma.UploadsTest do
|
|
|
|
alias Pleroma.Upload
|
|
|
|
use Pleroma.DataCase
|
|
|
|
|
|
|
|
import Mock
|
|
|
|
|
|
|
|
setup_all do
|
|
|
|
Mix.shell(Mix.Shell.Process)
|
|
|
|
|
|
|
|
on_exit(fn ->
|
|
|
|
Mix.shell(Mix.Shell.IO)
|
|
|
|
end)
|
|
|
|
|
|
|
|
:ok
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "running migrate_local" do
|
|
|
|
test "uploads migrated" do
|
|
|
|
with_mock Upload,
|
|
|
|
store: fn %Upload{name: _file, path: _path}, _opts -> {:ok, %{}} end do
|
|
|
|
Mix.Tasks.Pleroma.Uploads.run(["migrate_local", "S3"])
|
|
|
|
|
|
|
|
assert_received {:mix_shell, :info, [message]}
|
|
|
|
assert message =~ "Migrating files from local"
|
|
|
|
|
|
|
|
assert_received {:mix_shell, :info, [message]}
|
|
|
|
|
|
|
|
assert %{"total_count" => total_count} =
|
|
|
|
Regex.named_captures(~r"^Found (?<total_count>\d+) uploads$", message)
|
|
|
|
|
|
|
|
assert_received {:mix_shell, :info, [message]}
|
|
|
|
|
2018-12-17 14:55:24 -05:00
|
|
|
# @logevery in Mix.Tasks.Pleroma.Uploads
|
|
|
|
count =
|
|
|
|
min(50, String.to_integer(total_count))
|
|
|
|
|> to_string()
|
|
|
|
|
|
|
|
assert %{"count" => ^count, "total_count" => ^total_count} =
|
2018-12-16 11:04:31 -05: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
|