diff --git a/lib/spandex_phoenix/plug/finish_trace.ex b/lib/spandex_phoenix/plug/finish_trace.ex index 69b31c3..718c0c8 100644 --- a/lib/spandex_phoenix/plug/finish_trace.ex +++ b/lib/spandex_phoenix/plug/finish_trace.ex @@ -5,13 +5,17 @@ defmodule SpandexPhoenix.Plug.FinishTrace do @init_opts Optimal.schema( opts: [ - tracer: :atom + tracer: :atom, + finish_trace?: :boolean ], defaults: [ - tracer: Application.get_env(:spandex_phoenix, :tracer) + tracer: Application.get_env(:spandex_phoenix, :tracer), + finish_trace?: Application.get_env(:spandex_phoenix, :finish_trace?, true) ], describe: [ - tracer: "The tracing module to be used to start the trace." + tracer: "The tracing module to be used to start the trace.", + finish_trace?: + "If we should finish traces, set to false if you're tracing your tests since your test middleware should finish the test trace." ] ) @@ -24,8 +28,9 @@ defmodule SpandexPhoenix.Plug.FinishTrace do @impl Plug def call(conn, opts) do tracer = opts[:tracer] + finish_trace? = opts[:finish_trace?] - if tracer.current_trace_id() do + if tracer.current_trace_id() && finish_trace? do tracer.finish_trace() end diff --git a/lib/spandex_phoenix/plug/start_trace.ex b/lib/spandex_phoenix/plug/start_trace.ex index a28f8eb..a2af313 100644 --- a/lib/spandex_phoenix/plug/start_trace.ex +++ b/lib/spandex_phoenix/plug/start_trace.ex @@ -52,7 +52,14 @@ defmodule SpandexPhoenix.Plug.StartTrace do tracer.continue_trace(opts[:span_name], span_context) {:error, _} -> - tracer.start_trace(opts[:span_name]) + # check to ensure we're not already in a trace + # before we start another trace + if {:error, :no_trace_context} == tracer.current_context() do + tracer.start_trace(opts[:span_name]) + else + # start a span if we're already in a trace + tracer.start_span(opts[:span_name]) + end end conn