Pleroma/test/pleroma/config/transfer_task_test.exs

121 lines
4.1 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Config.TransferTaskTest do
use Pleroma.DataCase
import ExUnit.CaptureLog
2020-05-31 09:46:02 +02:00
import Pleroma.Factory
2020-01-18 10:25:56 +01:00
alias Pleroma.Config.TransferTask
setup do: clear_config(:configurable_from_database, true)
test "transfer config values from db to env" do
refute Application.get_env(:pleroma, :test_key)
2019-06-23 07:16:16 +02:00
refute Application.get_env(:idna, :test_key)
refute Application.get_env(:quack, :test_key)
2020-04-16 09:36:37 +02:00
refute Application.get_env(:postgrex, :test_key)
2020-04-17 07:42:48 +02:00
initial = Application.get_env(:logger, :level)
2019-06-23 07:16:16 +02:00
2020-05-31 09:46:02 +02:00
insert(:config, key: :test_key, value: [live: 2, com: 3])
insert(:config, group: :idna, key: :test_key, value: [live: 15, com: 35])
insert(:config, group: :quack, key: :test_key, value: [:test_value1, :test_value2])
insert(:config, group: :postgrex, key: :test_key, value: :value)
insert(:config, group: :logger, key: :level, value: :debug)
2020-04-17 07:42:48 +02:00
2020-01-18 10:25:56 +01:00
TransferTask.start_link([])
assert Application.get_env(:pleroma, :test_key) == [live: 2, com: 3]
2019-06-23 07:16:16 +02:00
assert Application.get_env(:idna, :test_key) == [live: 15, com: 35]
assert Application.get_env(:quack, :test_key) == [:test_value1, :test_value2]
2020-04-17 07:42:48 +02:00
assert Application.get_env(:logger, :level) == :debug
2020-04-16 09:36:37 +02:00
assert Application.get_env(:postgrex, :test_key) == :value
on_exit(fn ->
Application.delete_env(:pleroma, :test_key)
2019-06-23 07:16:16 +02:00
Application.delete_env(:idna, :test_key)
Application.delete_env(:quack, :test_key)
2020-04-16 09:36:37 +02:00
Application.delete_env(:postgrex, :test_key)
2020-04-17 07:42:48 +02:00
Application.put_env(:logger, :level, initial)
end)
end
test "transfer config values for 1 group and some keys" do
level = Application.get_env(:quack, :level)
meta = Application.get_env(:quack, :meta)
2020-05-31 09:46:02 +02:00
insert(:config, group: :quack, key: :level, value: :info)
insert(:config, group: :quack, key: :meta, value: [:none])
2020-01-18 10:25:56 +01:00
TransferTask.start_link([])
assert Application.get_env(:quack, :level) == :info
assert Application.get_env(:quack, :meta) == [:none]
default = Pleroma.Config.Holder.default_config(:quack, :webhook_url)
assert Application.get_env(:quack, :webhook_url) == default
on_exit(fn ->
Application.put_env(:quack, :level, level)
Application.put_env(:quack, :meta, meta)
end)
end
2020-01-18 10:25:56 +01:00
test "transfer config values with full subkey update" do
2020-04-17 07:42:48 +02:00
clear_config(:emoji)
clear_config(:assets)
2020-01-18 10:25:56 +01:00
2020-05-31 09:46:02 +02:00
insert(:config, key: :emoji, value: [groups: [a: 1, b: 2]])
insert(:config, key: :assets, value: [mascots: [a: 1, b: 2]])
2020-01-18 10:25:56 +01:00
TransferTask.start_link([])
emoji_env = Application.get_env(:pleroma, :emoji)
assert emoji_env[:groups] == [a: 1, b: 2]
assets_env = Application.get_env(:pleroma, :assets)
assert assets_env[:mascots] == [a: 1, b: 2]
end
describe "pleroma restart" do
2020-02-08 10:55:37 +01:00
setup do
on_exit(fn -> Restarter.Pleroma.refresh() end)
end
test "don't restart if no reboot time settings were changed" do
2020-04-17 07:42:48 +02:00
clear_config(:emoji)
2020-05-31 09:46:02 +02:00
insert(:config, key: :emoji, value: [groups: [a: 1, b: 2]])
2020-01-25 17:21:21 +01:00
refute String.contains?(
capture_log(fn -> TransferTask.start_link([]) end),
"pleroma restarted"
)
end
2020-02-08 10:55:37 +01:00
test "on reboot time key" do
2020-04-17 07:42:48 +02:00
clear_config(:chat)
2020-05-31 09:46:02 +02:00
insert(:config, key: :chat, value: [enabled: false])
assert capture_log(fn -> TransferTask.start_link([]) end) =~ "pleroma restarted"
end
2020-02-08 10:55:37 +01:00
test "on reboot time subkey" do
2020-04-17 07:42:48 +02:00
clear_config(Pleroma.Captcha)
2020-05-31 09:46:02 +02:00
insert(:config, key: Pleroma.Captcha, value: [seconds_valid: 60])
assert capture_log(fn -> TransferTask.start_link([]) end) =~ "pleroma restarted"
end
test "don't restart pleroma on reboot time key and subkey if there is false flag" do
2020-04-17 07:42:48 +02:00
clear_config(:chat)
clear_config(Pleroma.Captcha)
2020-05-31 09:46:02 +02:00
insert(:config, key: :chat, value: [enabled: false])
insert(:config, key: Pleroma.Captcha, value: [seconds_valid: 60])
2020-01-28 16:02:11 +01:00
refute String.contains?(
capture_log(fn -> TransferTask.load_and_update_env([], false) end),
"pleroma restarted"
)
end
end
end