Procházet zdrojové kódy

Cleanup and ensure we obey custom Repo timeout

test/buildperf
Mark Felder před 3 roky
rodič
revize
959dc6e6fc
1 změnil soubory, kde provedl 10 přidání a 1 odebrání
  1. +10
    -1
      lib/pleroma/utils.ex

+ 10
- 1
lib/pleroma/utils.ex Zobrazit soubor

@@ -11,6 +11,8 @@ defmodule Pleroma.Utils do
eperm epipe erange erofs espipe esrch estale etxtbsy exdev eperm epipe erange erofs espipe esrch estale etxtbsy exdev
)a )a


@repo_timeout Pleroma.Config.get([Pleroma.Repo, :timeout], 15_000)

def compile_dir(dir) when is_binary(dir) do def compile_dir(dir) when is_binary(dir) do
dir dir
|> File.ls!() |> File.ls!()
@@ -64,13 +66,20 @@ defmodule Pleroma.Utils do


def posix_error_message(_), do: "" def posix_error_message(_), do: ""


@doc """
Returns [timeout: integer] suitable for passing as an option to Repo functions.

This function detects if the execution was triggered from IEx shell, Mix task, or
./bin/pleroma_ctl and sets the timeout to :infinity, else returns the default timeout value.
"""
@spec query_timeout() :: [timeout: integer]
def query_timeout do def query_timeout do
{parent, _, _, _} = Process.info(self(), :current_stacktrace) |> elem(1) |> Enum.fetch!(2) {parent, _, _, _} = Process.info(self(), :current_stacktrace) |> elem(1) |> Enum.fetch!(2)


cond do cond do
parent |> to_string |> String.starts_with?("Elixir.Mix.Task") -> [timeout: :infinity] parent |> to_string |> String.starts_with?("Elixir.Mix.Task") -> [timeout: :infinity]
parent == :erl_eval -> [timeout: :infinity] parent == :erl_eval -> [timeout: :infinity]
true -> [timeout: 15_000]
true -> [timeout: @repo_timeout]
end end
end end
end end

Načítá se…
Zrušit
Uložit