Maarten van Vliet 1de26cce1a
Add Dataloader instrumentation library (#137)
* Add Dataloader instrumentation library

* Move call to set context to @run_start event

---------

Co-authored-by: Tristan Sloughter <t@crashfast.com>
2023-04-05 10:34:49 -06:00

70 lines
1.8 KiB
Elixir

defmodule OpentelemetryDataloaderTest do
use ExUnit.Case
require OpenTelemetry.Tracer
alias OpentelemetryDataloader.TestRepo, as: Repo
alias OpentelemetryDataloader.TestModels.Post
require Record
for {name, spec} <- Record.extract_all(from_lib: "opentelemetry/include/otel_span.hrl") do
Record.defrecord(name, spec)
end
setup do
:application.stop(:opentelemetry)
:application.set_env(:opentelemetry, :tracer, :otel_tracer_default)
:application.set_env(:opentelemetry, :processors, [
{:otel_batch_processor, %{scheduled_delay_ms: 1}}
])
:application.start(:opentelemetry)
:otel_batch_processor.set_exporter(:otel_exporter_pid, self())
OpenTelemetry.Tracer.start_span("test")
on_exit(fn ->
OpenTelemetry.Tracer.end_span()
:telemetry.detach({__MODULE__, :batch})
:telemetry.detach({__MODULE__, :run})
end)
end
test "captures dataloader ecto source events" do
OpentelemetryDataloader.setup()
source = Dataloader.Ecto.new(Repo)
loader = Dataloader.new() |> Dataloader.add_source(:db, source)
loader =
loader
|> Dataloader.load(:db, Post, 1)
|> Dataloader.load_many(:db, Post, [4, 9])
Dataloader.run(loader)
assert_receive {:span,
span(
name: "dataloader.run",
attributes: attributes,
kind: :client
)}
assert %{} = :otel_attributes.map(attributes)
assert_receive {:span,
span(
name: "dataloader.batch",
attributes: attributes,
kind: :client
)}
assert %{"dataloader.batch_key" => key} = :otel_attributes.map(attributes)
assert key =~ ~r/OpentelemetryDataloader.TestModels.Post/
end
end