akkoma/test/config/transfer_task_test.exs

63 lines
1.7 KiB
Elixir
Raw Normal View History

# Pleroma: A lightweight social networking server
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.Config.TransferTaskTest do
use Pleroma.DataCase
alias Pleroma.ConfigDB
2020-01-15 07:10:33 -07:00
clear_config(:configurable_from_database) do
Pleroma.Config.put(:configurable_from_database, true)
end
test "transfer config values from db to env" do
refute Application.get_env(:pleroma, :test_key)
2019-06-22 23:16:16 -06:00
refute Application.get_env(:idna, :test_key)
refute Application.get_env(:quack, :test_key)
2019-06-22 23:16:16 -06:00
ConfigDB.create(%{
2019-09-29 02:17:38 -06:00
group: ":pleroma",
key: ":test_key",
2019-06-22 23:16:16 -06:00
value: [live: 2, com: 3]
})
ConfigDB.create(%{
2019-09-29 02:17:38 -06:00
group: ":idna",
key: ":test_key",
2019-06-22 23:16:16 -06:00
value: [live: 15, com: 35]
})
ConfigDB.create(%{
group: ":quack",
key: ":test_key",
value: [:test_value1, :test_value2]
})
2019-08-14 09:55:17 -06:00
Pleroma.Config.TransferTask.start_link([])
assert Application.get_env(:pleroma, :test_key) == [live: 2, com: 3]
2019-06-22 23:16:16 -06:00
assert Application.get_env(:idna, :test_key) == [live: 15, com: 35]
assert Application.get_env(:quack, :test_key) == [:test_value1, :test_value2]
on_exit(fn ->
Application.delete_env(:pleroma, :test_key)
2019-06-22 23:16:16 -06:00
Application.delete_env(:idna, :test_key)
Application.delete_env(:quack, :test_key)
end)
end
test "non existing atom" do
ConfigDB.create(%{
2019-09-29 02:17:38 -06:00
group: ":pleroma",
key: ":undefined_atom_key",
2019-06-22 23:16:16 -06:00
value: [live: 2, com: 3]
})
assert ExUnit.CaptureLog.capture_log(fn ->
2019-08-14 09:55:17 -06:00
Pleroma.Config.TransferTask.start_link([])
end) =~
2019-09-29 02:17:38 -06:00
"updating env causes error, key: \":undefined_atom_key\", error: %ArgumentError{message: \"argument error\"}"
end
end