wait in mix task while pleroma is rebooted
[akkoma] / lib / mix / pleroma.ex
index a6b00d4be2e1a77cde03741988bd8d0fc5973970..d2e443fdc624d5a4b422f974a20d4e30737a46d5 100644 (file)
@@ -4,15 +4,27 @@
 
 defmodule Mix.Pleroma do
   @doc "Common functions to be reused in mix tasks"
-  def start_pleroma(change_logger_level \\ true) do
+  def start_pleroma do
     Application.put_env(:phoenix, :serve_endpoints, false, persistent: true)
 
-    if Pleroma.Config.get(:env) != :test and change_logger_level do
-      require Logger
-      Logger.configure(:console, level: :debug)
+    if Pleroma.Config.get(:env) != :test do
+      Application.put_env(:logger, :console, level: :debug)
     end
 
     {:ok, _} = Application.ensure_all_started(:pleroma)
+
+    if Pleroma.Config.get(:env) not in [:test, :benchmark] do
+      pleroma_rebooted?()
+    end
+  end
+
+  defp pleroma_rebooted? do
+    if Restarter.Pleroma.rebooted?() do
+      :ok
+    else
+      Process.sleep(10)
+      pleroma_rebooted?()
+    end
   end
 
   def load_pleroma do