diff options
| author | Alexander <alex.strizhakov@gmail.com> | 2019-12-06 08:21:30 +0300 | 
|---|---|---|
| committer | Alexander Strizhakov <alex.strizhakov@gmail.com> | 2020-01-10 15:51:59 +0300 | 
| commit | 0656816c77875d87d64d89e0e549f73104104cfb (patch) | |
| tree | f50d11260f92bde2352c18b6d1cb42c8bb46e90f /test/web | |
| parent | 2753285b7722fdb47f0ebb2180e997cf72f65d1a (diff) | |
| download | pleroma-0656816c77875d87d64d89e0e549f73104104cfb.tar.gz pleroma-0656816c77875d87d64d89e0e549f73104104cfb.zip | |
tests for setttings without an explicit key
Diffstat (limited to 'test/web')
| -rw-r--r-- | test/web/admin_api/admin_api_controller_test.exs | 46 | 
1 files changed, 43 insertions, 3 deletions
| diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index fd54504ac..1372edcab 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -1970,8 +1970,6 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do      setup %{conn: conn} do        admin = insert(:user, is_admin: true) -      temp_file = "config/test.exported_from_db.secret.exs" -        on_exit(fn ->          Application.delete_env(:pleroma, :key1)          Application.delete_env(:pleroma, :key2) @@ -1981,7 +1979,7 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do          Application.delete_env(:pleroma, :keyaa2)          Application.delete_env(:pleroma, Pleroma.Web.Endpoint.NotReal)          Application.delete_env(:pleroma, Pleroma.Captcha.NotReal) -        :ok = File.rm(temp_file) +        :ok = File.rm("config/test.exported_from_db.secret.exs")        end)        %{conn: assign(conn, :user, admin)} @@ -2101,6 +2099,48 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do        assert Application.get_env(:idna, :key5) == {"string", Pleroma.Captcha.NotReal, []}      end +    test "save config setting without key", %{conn: conn} do +      initial = Application.get_all_env(:quack) +      on_exit(fn -> Application.put_all_env([{:quack, initial}]) end) + +      conn = +        post(conn, "/api/pleroma/admin/config", %{ +          configs: [ +            %{ +              group: ":quack", +              key: ":level", +              value: ":info" +            }, +            %{ +              group: ":quack", +              key: ":meta", +              value: [":none"] +            }, +            %{ +              group: ":quack", +              key: ":webhook_url", +              value: "https://hooks.slack.com/services/KEY" +            } +          ] +        }) + +      assert json_response(conn, 200) == %{ +               "configs" => [ +                 %{"group" => ":quack", "key" => ":level", "value" => ":info"}, +                 %{"group" => ":quack", "key" => ":meta", "value" => [":none"]}, +                 %{ +                   "group" => ":quack", +                   "key" => ":webhook_url", +                   "value" => "https://hooks.slack.com/services/KEY" +                 } +               ] +             } + +      assert Application.get_env(:quack, :level) == :info +      assert Application.get_env(:quack, :meta) == [:none] +      assert Application.get_env(:quack, :webhook_url) == "https://hooks.slack.com/services/KEY" +    end +      test "update config setting & delete", %{conn: conn} do        config1 = insert(:config, key: ":keyaa1")        config2 = insert(:config, key: ":keyaa2") | 
