mirror of
https://git.pleroma.social/sjw/pleroma.git
synced 2025-01-03 16:06:00 +01:00
edaae845af
Ensure console backend logs in test environment are :warn, but mix tasks run in test env do not run with :debug because it's far too verbose.
73 lines
1.8 KiB
Elixir
73 lines
1.8 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Mix.Pleroma do
|
|
@doc "Common functions to be reused in mix tasks"
|
|
def start_pleroma do
|
|
Application.put_env(:phoenix, :serve_endpoints, false, persistent: true)
|
|
|
|
if Pleroma.Config.get(:env) != :test do
|
|
Application.put_env(:logger, :console, level: :debug)
|
|
end
|
|
|
|
{:ok, _} = Application.ensure_all_started(:pleroma)
|
|
end
|
|
|
|
def load_pleroma do
|
|
Application.load(:pleroma)
|
|
end
|
|
|
|
def get_option(options, opt, prompt, defval \\ nil, defname \\ nil) do
|
|
Keyword.get(options, opt) || shell_prompt(prompt, defval, defname)
|
|
end
|
|
|
|
def shell_prompt(prompt, defval \\ nil, defname \\ nil) do
|
|
prompt_message = "#{prompt} [#{defname || defval}] "
|
|
|
|
input =
|
|
if mix_shell?(),
|
|
do: Mix.shell().prompt(prompt_message),
|
|
else: :io.get_line(prompt_message)
|
|
|
|
case input do
|
|
"\n" ->
|
|
case defval do
|
|
nil ->
|
|
shell_prompt(prompt, defval, defname)
|
|
|
|
defval ->
|
|
defval
|
|
end
|
|
|
|
input ->
|
|
String.trim(input)
|
|
end
|
|
end
|
|
|
|
def shell_yes?(message) do
|
|
if mix_shell?(),
|
|
do: Mix.shell().yes?("Continue?"),
|
|
else: shell_prompt(message, "Continue?") in ~w(Yn Y y)
|
|
end
|
|
|
|
def shell_info(message) do
|
|
if mix_shell?(),
|
|
do: Mix.shell().info(message),
|
|
else: IO.puts(message)
|
|
end
|
|
|
|
def shell_error(message) do
|
|
if mix_shell?(),
|
|
do: Mix.shell().error(message),
|
|
else: IO.puts(:stderr, message)
|
|
end
|
|
|
|
@doc "Performs a safe check whether `Mix.shell/0` is available (does not raise if Mix is not loaded)"
|
|
def mix_shell?, do: :erlang.function_exported(Mix, :shell, 0)
|
|
|
|
def escape_sh_path(path) do
|
|
~S(') <> String.replace(path, ~S('), ~S(\')) <> ~S(')
|
|
end
|
|
end
|