forked from AkkomaGang/akkoma
FloatingGhost
98cb255d12
OTP builds to 1.15 Changelog entry Ensure policies are fully loaded Fix :warn use main branch for linkify Fix warn in tests Migrations for phoenix 1.17 Revert "Migrations for phoenix 1.17" This reverts commit 6a3b2f15b74ea5e33150529385215b7a531f3999. Oban upgrade Add default empty whitelist mix format limit test to amd64 OTP 26 tests for 1.15 use OTP_VERSION tag baka just 1.15 Massive deps update Update locale, deps Mix format shell???? multiline??? ? max cases 1 use assert_recieve don't put_env in async tests don't async conn/fs tests mix format FIx some uploader issues Fix tests
166 lines
5.5 KiB
Elixir
166 lines
5.5 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.ApplicationRequirementsTest do
|
|
use Pleroma.DataCase, async: false
|
|
|
|
import ExUnit.CaptureLog
|
|
import Mock
|
|
|
|
alias Pleroma.ApplicationRequirements
|
|
alias Pleroma.Repo
|
|
|
|
describe "check_repo_pool_size!/1" do
|
|
test "raises if the pool size is unexpected" do
|
|
clear_config([Pleroma.Repo, :pool_size], 11)
|
|
clear_config([:dangerzone, :override_repo_pool_size], false)
|
|
|
|
assert_raise Pleroma.ApplicationRequirements.VerifyError,
|
|
"Repo.pool_size different than recommended value.",
|
|
fn ->
|
|
capture_log(&Pleroma.ApplicationRequirements.verify!/0)
|
|
end
|
|
end
|
|
|
|
test "doesn't raise if the pool size is unexpected but the respective flag is set" do
|
|
clear_config([Pleroma.Repo, :pool_size], 11)
|
|
clear_config([:dangerzone, :override_repo_pool_size], true)
|
|
|
|
assert Pleroma.ApplicationRequirements.verify!() == :ok
|
|
end
|
|
end
|
|
|
|
describe "check_welcome_message_config!/1" do
|
|
setup do: clear_config([:welcome])
|
|
setup do: clear_config([Pleroma.Emails.Mailer])
|
|
|
|
test "warns if welcome email enabled but mail disabled" do
|
|
clear_config([:welcome, :email, :enabled], true)
|
|
clear_config([Pleroma.Emails.Mailer, :enabled], false)
|
|
|
|
assert capture_log(fn ->
|
|
assert Pleroma.ApplicationRequirements.verify!() == :ok
|
|
end) =~ "Welcome emails will NOT be sent"
|
|
end
|
|
end
|
|
|
|
describe "check_confirmation_accounts!" do
|
|
setup_with_mocks([
|
|
{Pleroma.ApplicationRequirements, [:passthrough],
|
|
[
|
|
check_migrations_applied!: fn _ -> :ok end
|
|
]}
|
|
]) do
|
|
:ok
|
|
end
|
|
|
|
setup do: clear_config([:instance, :account_activation_required])
|
|
|
|
test "warns if account confirmation is required but mailer isn't enabled" do
|
|
clear_config([:instance, :account_activation_required], true)
|
|
clear_config([Pleroma.Emails.Mailer, :enabled], false)
|
|
|
|
assert capture_log(fn ->
|
|
assert Pleroma.ApplicationRequirements.verify!() == :ok
|
|
end) =~ "Users will NOT be able to confirm their accounts"
|
|
end
|
|
|
|
test "doesn't do anything if account confirmation is disabled" do
|
|
clear_config([:instance, :account_activation_required], false)
|
|
clear_config([Pleroma.Emails.Mailer, :enabled], false)
|
|
assert Pleroma.ApplicationRequirements.verify!() == :ok
|
|
end
|
|
|
|
test "doesn't do anything if account confirmation is required and mailer is enabled" do
|
|
clear_config([:instance, :account_activation_required], true)
|
|
clear_config([Pleroma.Emails.Mailer, :enabled], true)
|
|
assert Pleroma.ApplicationRequirements.verify!() == :ok
|
|
end
|
|
end
|
|
|
|
describe "check_rum!" do
|
|
setup_with_mocks([
|
|
{Pleroma.ApplicationRequirements, [:passthrough],
|
|
[check_migrations_applied!: fn _ -> :ok end]}
|
|
]) do
|
|
:ok
|
|
end
|
|
|
|
setup do: clear_config([:database, :rum_enabled])
|
|
|
|
test "raises if rum is enabled and detects unapplied rum migrations" do
|
|
clear_config([:database, :rum_enabled], true)
|
|
|
|
with_mocks([{Repo, [:passthrough], [exists?: fn _, _ -> false end]}]) do
|
|
assert_raise ApplicationRequirements.VerifyError,
|
|
"Unapplied RUM Migrations detected",
|
|
fn ->
|
|
capture_log(&ApplicationRequirements.verify!/0)
|
|
end
|
|
end
|
|
end
|
|
|
|
test "raises if rum is disabled and detects rum migrations" do
|
|
clear_config([:database, :rum_enabled], false)
|
|
|
|
with_mocks([{Repo, [:passthrough], [exists?: fn _, _ -> true end]}]) do
|
|
assert_raise ApplicationRequirements.VerifyError,
|
|
"RUM Migrations detected",
|
|
fn ->
|
|
capture_log(&ApplicationRequirements.verify!/0)
|
|
end
|
|
end
|
|
end
|
|
|
|
test "doesn't do anything if rum enabled and applied migrations" do
|
|
clear_config([:database, :rum_enabled], true)
|
|
|
|
with_mocks([{Repo, [:passthrough], [exists?: fn _, _ -> true end]}]) do
|
|
assert ApplicationRequirements.verify!() == :ok
|
|
end
|
|
end
|
|
|
|
test "doesn't do anything if rum disabled" do
|
|
clear_config([:database, :rum_enabled], false)
|
|
|
|
with_mocks([{Repo, [:passthrough], [exists?: fn _, _ -> false end]}]) do
|
|
assert ApplicationRequirements.verify!() == :ok
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "check_migrations_applied!" do
|
|
setup_with_mocks([
|
|
{Ecto.Migrator, [],
|
|
[
|
|
with_repo: fn repo, fun -> passthrough([repo, fun]) end,
|
|
migrations: fn Repo ->
|
|
[
|
|
{:up, 20_191_128_153_944, "fix_missing_following_count"},
|
|
{:up, 20_191_203_043_610, "create_report_notes"},
|
|
{:down, 20_191_220_174_645, "add_scopes_to_pleroma_feo_auth_records"}
|
|
]
|
|
end
|
|
]}
|
|
]) do
|
|
:ok
|
|
end
|
|
|
|
setup do: clear_config([:i_am_aware_this_may_cause_data_loss, :disable_migration_check])
|
|
|
|
test "raises if it detects unapplied migrations" do
|
|
assert_raise ApplicationRequirements.VerifyError,
|
|
"Unapplied Migrations detected",
|
|
fn ->
|
|
capture_log(&ApplicationRequirements.verify!/0)
|
|
end
|
|
end
|
|
|
|
test "doesn't do anything if disabled" do
|
|
clear_config([:i_am_aware_this_may_cause_data_loss, :disable_migration_check], true)
|
|
|
|
assert :ok == ApplicationRequirements.verify!()
|
|
end
|
|
end
|
|
end
|