2019-07-10 07:13:23 +02:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-02 06:08:45 +01:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2019-07-10 07:13:23 +02:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2019-06-14 17:45:05 +02:00
|
|
|
defmodule Pleroma.Config.TransferTaskTest do
|
|
|
|
use Pleroma.DataCase
|
|
|
|
|
2020-01-25 16:42:04 +01:00
|
|
|
import ExUnit.CaptureLog
|
|
|
|
|
2020-01-18 10:25:56 +01:00
|
|
|
alias Pleroma.Config.TransferTask
|
2020-01-16 06:50:27 +01:00
|
|
|
alias Pleroma.ConfigDB
|
2019-12-06 06:21:30 +01:00
|
|
|
|
2020-03-20 16:33:00 +01:00
|
|
|
setup do: clear_config(:configurable_from_database, true)
|
2019-06-14 17:45:05 +02:00
|
|
|
|
|
|
|
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)
|
2019-12-06 06:21:30 +01:00
|
|
|
refute Application.get_env(:quack, :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-01-16 06:50:27 +01:00
|
|
|
ConfigDB.create(%{
|
2019-09-29 10:17:38 +02:00
|
|
|
group: ":pleroma",
|
|
|
|
key: ":test_key",
|
2019-06-23 07:16:16 +02:00
|
|
|
value: [live: 2, com: 3]
|
|
|
|
})
|
|
|
|
|
2020-01-16 06:50:27 +01:00
|
|
|
ConfigDB.create(%{
|
2019-09-29 10:17:38 +02:00
|
|
|
group: ":idna",
|
|
|
|
key: ":test_key",
|
2019-06-23 07:16:16 +02:00
|
|
|
value: [live: 15, com: 35]
|
|
|
|
})
|
2019-06-14 17:45:05 +02:00
|
|
|
|
2020-01-16 06:50:27 +01:00
|
|
|
ConfigDB.create(%{
|
2019-12-06 06:21:30 +01:00
|
|
|
group: ":quack",
|
|
|
|
key: ":test_key",
|
|
|
|
value: [:test_value1, :test_value2]
|
|
|
|
})
|
|
|
|
|
2020-04-17 07:42:48 +02:00
|
|
|
ConfigDB.create(%{group: ":logger", key: ":level", value: :debug})
|
|
|
|
|
2020-01-18 10:25:56 +01:00
|
|
|
TransferTask.start_link([])
|
2019-06-14 17:45:05 +02:00
|
|
|
|
|
|
|
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]
|
2019-12-06 06:21:30 +01:00
|
|
|
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
|
2019-06-14 17:45:05 +02:00
|
|
|
|
|
|
|
on_exit(fn ->
|
|
|
|
Application.delete_env(:pleroma, :test_key)
|
2019-06-23 07:16:16 +02:00
|
|
|
Application.delete_env(:idna, :test_key)
|
2019-12-06 06:21:30 +01:00
|
|
|
Application.delete_env(:quack, :test_key)
|
2020-04-17 07:42:48 +02:00
|
|
|
Application.put_env(:logger, :level, initial)
|
2019-06-14 17:45:05 +02:00
|
|
|
end)
|
|
|
|
end
|
|
|
|
|
2020-01-17 09:45:44 +01:00
|
|
|
test "transfer config values for 1 group and some keys" do
|
|
|
|
level = Application.get_env(:quack, :level)
|
|
|
|
meta = Application.get_env(:quack, :meta)
|
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":quack",
|
|
|
|
key: ":level",
|
|
|
|
value: :info
|
|
|
|
})
|
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":quack",
|
|
|
|
key: ":meta",
|
|
|
|
value: [:none]
|
|
|
|
})
|
|
|
|
|
2020-01-18 10:25:56 +01:00
|
|
|
TransferTask.start_link([])
|
2020-01-17 09:45:44 +01:00
|
|
|
|
|
|
|
assert Application.get_env(:quack, :level) == :info
|
|
|
|
assert Application.get_env(:quack, :meta) == [:none]
|
2020-03-11 14:25:53 +01:00
|
|
|
default = Pleroma.Config.Holder.default_config(:quack, :webhook_url)
|
2020-01-17 09:45:44 +01:00
|
|
|
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
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
key: ":emoji",
|
|
|
|
value: [groups: [a: 1, b: 2]]
|
|
|
|
})
|
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
key: ":assets",
|
|
|
|
value: [mascots: [a: 1, b: 2]]
|
|
|
|
})
|
|
|
|
|
|
|
|
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
|
2020-01-25 16:42:04 +01:00
|
|
|
|
|
|
|
describe "pleroma restart" do
|
2020-02-08 10:55:37 +01:00
|
|
|
setup do
|
|
|
|
on_exit(fn -> Restarter.Pleroma.refresh() end)
|
|
|
|
end
|
|
|
|
|
2020-01-25 16:42:04 +01:00
|
|
|
test "don't restart if no reboot time settings were changed" do
|
2020-04-17 07:42:48 +02:00
|
|
|
clear_config(:emoji)
|
2020-01-25 16:42:04 +01:00
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
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"
|
|
|
|
)
|
2020-01-25 16:42:04 +01:00
|
|
|
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-01-25 16:42:04 +01:00
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
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-01-25 16:42:04 +01:00
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
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-01-25 16:42:04 +01:00
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
key: ":chat",
|
|
|
|
value: [enabled: false]
|
|
|
|
})
|
|
|
|
|
|
|
|
ConfigDB.create(%{
|
|
|
|
group: ":pleroma",
|
|
|
|
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"
|
|
|
|
)
|
2020-01-25 16:42:04 +01:00
|
|
|
end
|
|
|
|
end
|
2019-06-14 17:45:05 +02:00
|
|
|
end
|