2018-12-23 20:11:29 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-13 06:49:20 +00:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 20:11:29 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2018-12-16 16:04:31 +00:00
|
|
|
defmodule Mix.Tasks.Pleroma.UploadsTest do
|
|
|
|
alias Pleroma.Upload
|
2023-08-01 10:43:50 +00:00
|
|
|
use Pleroma.DataCase, async: false
|
2023-08-04 11:50:50 +00:00
|
|
|
@moduletag :mocked
|
2018-12-16 16:04:31 +00:00
|
|
|
|
|
|
|
import Mock
|
|
|
|
|
|
|
|
setup_all do
|
|
|
|
Mix.shell(Mix.Shell.Process)
|
|
|
|
|
|
|
|
on_exit(fn ->
|
|
|
|
Mix.shell(Mix.Shell.IO)
|
|
|
|
end)
|
|
|
|
|
2023-08-03 17:10:27 +00:00
|
|
|
File.mkdir_p!("test/uploads")
|
|
|
|
|
2018-12-16 16:04:31 +00:00
|
|
|
: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"])
|
|
|
|
|
2023-08-01 10:43:50 +00:00
|
|
|
assert_receive {:mix_shell, :info, [message]}
|
2018-12-16 16:04:31 +00:00
|
|
|
assert message =~ "Migrating files from local"
|
|
|
|
|
2023-08-01 10:43:50 +00:00
|
|
|
assert_receive {:mix_shell, :info, [message]}
|
2018-12-16 16:04:31 +00:00
|
|
|
|
|
|
|
assert %{"total_count" => total_count} =
|
|
|
|
Regex.named_captures(~r"^Found (?<total_count>\d+) uploads$", message)
|
|
|
|
|
2023-08-01 10:43:50 +00:00
|
|
|
assert_receive {:mix_shell, :info, [message]}
|
2018-12-16 16:04:31 +00:00
|
|
|
|
2018-12-17 19:55:24 +00: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 16:04:31 +00: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
|