Enable a frontend automatically with --primary arg

This commit is contained in:
Alex Gleason 2021-06-14 17:55:21 -05:00
parent 9a768429a3
commit 8527faecf5
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 38 additions and 4 deletions

View file

@ -28,7 +28,9 @@ def run(["install", name | args]) do
ref: :string,
build_url: :string,
build_dir: :string,
file: :string
file: :string,
admin: :boolean,
primary: :boolean
]
)
@ -40,6 +42,10 @@ def run(["install", name | args]) do
|> opts_to_frontend()
|> Frontend.install() do
shell_info("Frontend #{fe.name} installed")
if get_frontend_type(options) do
run(["enable", name] ++ args)
end
else
error ->
shell_error("Failed to install frontend")
@ -63,7 +69,7 @@ def run(["enable", name | args]) do
]
)
frontend_type = get_frontend_type(options)
frontend_type = get_frontend_type(options) || :primary
shell_info("Enabling frontend #{name}...")
@ -92,8 +98,11 @@ defp get_frontend_type(opts) do
%{admin: true} ->
:admin
_ ->
%{primary: true} ->
:primary
_ ->
nil
end
end
end

View file

@ -39,6 +39,28 @@ test "it downloads and unzips a known frontend" do
assert File.exists?(Path.join([@dir, "frontends", "pleroma", "fantasy", "test.txt"]))
end
test "it enables a frontend with the --primary flag" do
frontend = %Pleroma.Frontend{
ref: "fantasy",
name: "pleroma",
build_url: "http://gensokyo.2hu/builds/${ref}"
}
map = Pleroma.Frontend.to_map(frontend)
clear_config(:configurable_from_database, true)
clear_config([:frontends, :available], %{"pleroma" => map})
Tesla.Mock.mock(fn %{url: "http://gensokyo.2hu/builds/fantasy"} ->
%Tesla.Env{status: 200, body: File.read!("test/fixtures/tesla_mock/frontend_dist.zip")}
end)
capture_io(fn ->
Frontend.run(["install", "pleroma", "--primary"])
end)
assert Pleroma.Config.get([:frontends, :primary]) == map
end
test "it also works given a file" do
clear_config([:frontends, :available], %{
"pleroma" => %{
@ -104,7 +126,10 @@ test "enabling an admin frontend" do
test "raise if configurable_from_database is disabled" do
clear_config(:configurable_from_database, false)
assert_raise(RuntimeError, fn -> Frontend.run(["enable", "soapbox-fe"]) end)
assert_raise(RuntimeError, fn ->
capture_io(fn -> Frontend.run(["enable", "soapbox-fe"]) end)
end)
end
end
end