From 0afcd5d8cef3c3698c1f10471d4593e22f7c8eb4 Mon Sep 17 00:00:00 2001 From: Maksym Ochenashko Date: Tue, 10 Sep 2024 09:26:40 +0300 Subject: [PATCH 1/2] scalafmt: set maxColumn to 120 --- .scalafmt.conf | 1 + build.sbt | 4 +- .../org/typelevel/otel4s/Attribute.scala | 3 +- .../org/typelevel/otel4s/AttributeKey.scala | 9 +- .../org/typelevel/otel4s/AttributeType.scala | 4 +- .../org/typelevel/otel4s/Attributes.scala | 67 +++--- .../typelevel/otel4s/KindTransformer.scala | 21 +- .../typelevel/otel4s/baggage/Baggage.scala | 6 +- .../typelevel/otel4s/context/Contextual.scala | 23 +- .../otel4s/context/LocalProvider.scala | 21 +- .../propagation/ContextPropagators.scala | 7 +- .../propagation/PassThroughPropagator.scala | 8 +- .../context/propagation/TextMapGetter.scala | 19 +- .../propagation/TextMapPropagator.scala | 29 +-- .../context/propagation/TextMapUpdater.scala | 34 +-- .../otel4s/instances/LocalInstances.scala | 4 +- .../otel4s/meta/InstrumentMeta.scala | 6 +- .../otel4s/NotQuiteExhaustiveChecks.scala | 4 +- .../otel4s/baggage/BaggageSuite.scala | 41 ++-- .../propagation/TextMapGetterSuite.scala | 15 +- .../propagation/TextMapUpdaterSuite.scala | 11 +- .../otel4s/context/vault/VaultContext.scala | 10 +- .../otel4s/metrics/BatchCallback.scala | 6 +- .../typelevel/otel4s/metrics/Counter.scala | 13 +- .../org/typelevel/otel4s/metrics/Gauge.scala | 10 +- .../typelevel/otel4s/metrics/Histogram.scala | 19 +- .../org/typelevel/otel4s/metrics/Meter.scala | 92 +++----- .../otel4s/metrics/MeterProvider.scala | 8 +- .../otel4s/metrics/ObservableCounter.scala | 24 +- .../otel4s/metrics/ObservableGauge.scala | 24 +- .../metrics/ObservableUpDownCounter.scala | 24 +- .../otel4s/metrics/UpDownCounter.scala | 16 +- .../otel4s/metrics/BaseMeterSuite.scala | 15 +- .../otel4s/metrics/CounterSuite.scala | 3 +- .../otel4s/metrics/HistogramSuite.scala | 3 +- .../otel4s/metrics/ObservableSuite.scala | 7 +- .../otel4s/metrics/UpDownCounterSuite.scala | 3 +- .../otel4s/trace/SpanBuilderMacro.scala | 44 ++-- .../typelevel/otel4s/trace/SpanMacro.scala | 42 ++-- .../typelevel/otel4s/trace/TracerMacro.scala | 34 ++- .../otel4s/trace/SpanBuilderMacro.scala | 41 ++-- .../typelevel/otel4s/trace/SpanMacro.scala | 42 ++-- .../typelevel/otel4s/trace/TracerMacro.scala | 34 ++- .../org/typelevel/otel4s/trace/Span.scala | 40 ++-- .../typelevel/otel4s/trace/SpanBuilder.scala | 22 +- .../typelevel/otel4s/trace/SpanContext.scala | 39 ++-- .../org/typelevel/otel4s/trace/SpanKind.scala | 20 +- .../org/typelevel/otel4s/trace/SpanOps.scala | 60 ++--- .../typelevel/otel4s/trace/StatusCode.scala | 3 +- .../typelevel/otel4s/trace/TraceFlags.scala | 6 +- .../typelevel/otel4s/trace/TraceScope.scala | 53 ++--- .../typelevel/otel4s/trace/TraceState.scala | 62 ++--- .../org/typelevel/otel4s/trace/Tracer.scala | 54 ++--- .../otel4s/trace/TracerBuilder.scala | 3 +- .../otel4s/trace/TracerProvider.scala | 11 +- .../otel4s/trace/TraceStateSuite.scala | 16 +- examples/src/main/scala/KleisliExample.scala | 3 +- .../src/main/scala/PekkoHttpExample.scala | 28 +-- .../src/main/scala/SdkTracingExample.scala | 3 +- examples/src/main/scala/TraceExample.scala | 85 ++++--- examples/src/main/scala/TracingExample.scala | 43 ++-- .../typelevel/otel4s/oteljava/OtelJava.scala | 33 +-- .../testkit/InstrumentationScope.scala | 7 +- .../otel4s/oteljava/AttributeConverters.scala | 20 +- .../otel4s/oteljava/context/Context.scala | 18 +- .../propagation/JavaPropagatorWrappers.scala | 16 +- .../propagation/PropagatorConverters.scala | 57 ++--- .../PropagatorConvertersProps.scala | 216 +++++++++--------- .../PropagatorConvertersSuite.scala | 4 +- .../testkit/metrics/MetricsTestkit.scala | 3 +- .../metrics/data/HistogramPointData.scala | 11 +- .../testkit/metrics/data/Metric.scala | 8 +- .../testkit/metrics/data/MetricData.scala | 9 +- .../metrics/data/SummaryPointData.scala | 3 +- .../oteljava/metrics/BatchCallbackImpl.scala | 4 +- .../otel4s/oteljava/metrics/MeterImpl.scala | 3 +- .../ObservableCounterBuilderImpl.scala | 4 +- .../metrics/ObservableGaugeBuilderImpl.scala | 4 +- .../metrics/ObservableMeasurementImpl.scala | 4 +- .../ObservableUpDownCounterBuilderImpl.scala | 4 +- .../oteljava/testkit/OtelJavaTestkit.scala | 10 +- .../testkit/trace/TracesTestkit.scala | 14 +- .../otel4s/oteljava/trace/TracerImpl.scala | 4 +- .../otel4s/scalafix/V0_5_0Rewrites.scala | 8 +- .../aws/resource/AWSLambdaDetector.scala | 11 +- .../propagation/AWSXRayLambdaPropagator.scala | 18 +- .../propagation/AWSXRayPropagator.scala | 7 +- .../OtlpExportersAutoConfigure.scala | 13 +- .../sdk/exporter/otlp/ProtoEncoder.scala | 22 +- .../OtlpHttpClientAutoConfigure.scala | 15 +- .../autoconfigure/ProtocolAutoConfigure.scala | 9 +- .../OtlpHttpClientAutoConfigureSuite.scala | 4 +- .../otlp/metrics/MetricsProtoEncoder.scala | 8 +- .../otlp/metrics/OtlpHttpMetricExporter.scala | 27 +-- .../OtlpMetricExporterAutoConfigure.scala | 69 +++--- .../otlp/metrics/MetricsJsonCodecs.scala | 6 +- .../metrics/OtlpHttpMetricExporterSuite.scala | 16 +- ...OtlpMetricExporterAutoConfigureSuite.scala | 4 +- .../otlp/trace/OtlpHttpSpanExporter.scala | 18 +- .../otlp/trace/SpansProtoEncoder.scala | 64 +++--- .../OtlpSpanExporterAutoConfigure.scala | 54 ++--- .../trace/OtlpHttpSpanExporterSuite.scala | 5 +- .../OtlpSpanExporterAutoConfigureSuite.scala | 4 +- .../otel4s/sdk/OpenTelemetrySdk.scala | 80 +++---- .../ExportersAutoConfigure.scala | 6 +- .../otel4s/sdk/OpenTelemetrySdkSuite.scala | 8 +- .../otel4s/sdk/trace/SdkTracerSuite.scala | 4 +- .../otel4s/sdk/TelemetryResource.scala | 37 ++- .../sdk/autoconfigure/AutoConfigure.scala | 12 +- .../autoconfigure/AutoConfigureError.scala | 5 +- .../otel4s/sdk/autoconfigure/Config.scala | 27 +-- .../sdk/common/InstrumentationScope.scala | 23 +- .../otel4s/sdk/context/Context.scala | 6 +- .../sdk/internal/ComponentRegistry.scala | 11 +- .../otel4s/sdk/resource/ProcessDetector.scala | 3 +- .../resource/TelemetryResourceDetector.scala | 8 +- .../autoconfigure/AutoConfigureSuite.scala | 4 +- .../otel4s/sdk/context/ContextSuite.scala | 7 +- .../otel4s/sdk/test/InMemoryConsole.scala | 3 +- .../metrics/InMemoryMetricExporter.scala | 19 +- .../metrics/InMemoryMetricReader.scala | 19 +- .../sdk/testkit/metrics/MetricsTestkit.scala | 25 +- .../otel4s/sdk/metrics/Aggregation.scala | 34 +-- .../otel4s/sdk/metrics/InstrumentType.scala | 32 ++- .../otel4s/sdk/metrics/SdkHistogram.scala | 3 +- .../otel4s/sdk/metrics/SdkMeterProvider.scala | 50 ++-- .../otel4s/sdk/metrics/SdkMetrics.scala | 49 ++-- .../sdk/metrics/SdkObservableCounter.scala | 3 +- .../sdk/metrics/aggregation/Aggregator.scala | 9 +- .../ExplicitBucketHistogramAggregator.scala | 3 +- .../aggregation/LastValueAggregator.scala | 3 +- .../metrics/aggregation/SumAggregator.scala | 3 +- .../ExemplarFilterAutoConfigure.scala | 3 +- .../MeterProviderAutoConfigure.scala | 9 +- .../MetricReadersAutoConfigure.scala | 6 +- .../sdk/metrics/data/ExemplarData.scala | 10 +- .../otel4s/sdk/metrics/data/MetricData.scala | 6 +- .../sdk/metrics/data/MetricPoints.scala | 16 +- .../otel4s/sdk/metrics/data/PointData.scala | 12 +- .../otel4s/sdk/metrics/data/TimeWindow.scala | 3 +- .../sdk/metrics/exemplar/CellSelector.scala | 3 +- .../sdk/metrics/exemplar/ExemplarFilter.scala | 6 +- .../metrics/exemplar/ExemplarReservoir.scala | 12 +- .../sdk/metrics/exemplar/Reservoirs.scala | 15 +- .../exporter/AggregationSelector.scala | 6 +- .../AggregationTemporalitySelector.scala | 13 +- .../exporter/ConsoleMetricExporter.scala | 9 +- .../sdk/metrics/exporter/MetricExporter.scala | 12 +- .../sdk/metrics/exporter/MetricProducer.scala | 5 +- .../sdk/metrics/exporter/MetricReader.scala | 19 +- .../exporter/PeriodicMetricReader.scala | 3 +- .../otel4s/sdk/metrics/internal/Advice.scala | 6 +- .../internal/CallbackRegistration.scala | 3 +- .../metrics/internal/MeterSharedState.scala | 9 +- .../metrics/internal/MetricDescriptor.scala | 3 +- .../internal/MetricStorageRegistry.scala | 7 +- .../internal/SdkObservableMeasurement.scala | 3 +- .../storage/AsynchronousStorage.scala | 2 +- .../internal/storage/MetricStorage.scala | 7 +- .../metrics/view/AttributesProcessor.scala | 10 +- .../sdk/metrics/view/InstrumentSelector.scala | 12 +- .../otel4s/sdk/metrics/view/View.scala | 14 +- .../sdk/metrics/view/ViewRegistry.scala | 7 +- .../metrics/SdkObservableCounterSuite.scala | 4 +- .../sdk/metrics/SdkObservableGaugeSuite.scala | 4 +- .../SdkObservableUpDownCounterSuite.scala | 4 +- ...plicitBucketHistogramAggregatorSuite.scala | 13 +- .../LastValueAggregatorSuite.scala | 4 +- .../MeterProviderAutoConfigureSuite.scala | 3 +- .../exemplar/ExemplarReservoirSuite.scala | 4 +- .../exporter/ConsoleMetricExporterSuite.scala | 4 +- .../exporter/InMemoryMetricExporter.scala | 9 +- .../exporter/PeriodicMetricReaderSuite.scala | 4 +- .../internal/MetricStorageRegistrySuite.scala | 4 +- .../SdkObservableMeasurementSuite.scala | 4 +- .../storage/AsynchronousStorageSuite.scala | 7 +- .../storage/SynchronousStorageSuite.scala | 7 +- .../otel4s/sdk/metrics/scalacheck/Gens.scala | 21 +- .../test/InMemoryMeterSharedState.scala | 3 +- .../sdk/metrics/test/PointDataUtils.scala | 9 +- .../sdk/testkit/OpenTelemetrySdkTestkit.scala | 28 +-- .../sdk/testkit/trace/TracesTestkit.scala | 3 +- .../otel4s/sdk/trace/IdGenerator.scala | 9 +- .../otel4s/sdk/trace/SdkContextKeys.scala | 8 +- .../otel4s/sdk/trace/SdkSpanBackend.scala | 15 +- .../otel4s/sdk/trace/SdkTracerProvider.scala | 43 ++-- .../otel4s/sdk/trace/SdkTraces.scala | 66 +++--- .../otel4s/sdk/trace/SpanLimits.scala | 8 +- .../typelevel/otel4s/sdk/trace/SpanRef.scala | 23 +- .../autoconfigure/SamplerAutoConfigure.scala | 17 +- .../context/propagation/B3Propagator.scala | 10 +- .../propagation/JaegerPropagator.scala | 7 +- .../propagation/W3CBaggagePropagator.scala | 46 ++-- .../W3CTraceContextPropagator.scala | 3 +- .../otel4s/sdk/trace/data/EventData.scala | 7 +- .../otel4s/sdk/trace/data/LimitedData.scala | 14 +- .../otel4s/sdk/trace/data/LinkData.scala | 3 +- .../otel4s/sdk/trace/data/SpanData.scala | 6 +- .../otel4s/sdk/trace/data/StatusData.scala | 9 +- .../trace/exporter/ConsoleSpanExporter.scala | 9 +- .../sdk/trace/exporter/SpanExporter.scala | 27 +-- .../trace/processor/BatchSpanProcessor.scala | 30 +-- .../trace/processor/SimpleSpanProcessor.scala | 13 +- .../sdk/trace/processor/SpanProcessor.scala | 18 +- .../trace/samplers/ParentBasedSampler.scala | 39 ++-- .../otel4s/sdk/trace/samplers/Sampler.scala | 36 ++- .../sdk/trace/samplers/SamplingDecision.scala | 9 +- .../sdk/trace/samplers/SamplingResult.scala | 39 ++-- .../samplers/TraceIdRatioBasedSampler.scala | 22 +- .../sdk/trace/SdkSpanBackendSuite.scala | 3 +- .../sdk/trace/SdkSpanBuilderSuite.scala | 8 +- .../typelevel/otel4s/sdk/trace/SpanNode.scala | 4 +- .../TracerProviderAutoConfigureSuite.scala | 3 +- .../propagation/B3PropagatorSuite.scala | 29 ++- .../sdk/trace/data/LimitedDataSuite.scala | 5 +- .../exporter/ConsoleSpanExporterSuite.scala | 4 +- .../processor/BatchSpanProcessorSuite.scala | 4 +- .../processor/SimpleSpanProcessorSuite.scala | 4 +- .../samplers/ParentBasedSamplerSuite.scala | 63 +++-- .../otel4s/sdk/trace/scalacheck/Cogens.scala | 4 +- .../otel4s/sdk/trace/scalacheck/Gens.scala | 4 +- .../AndroidExperimentalAttributes.scala | 28 +-- .../ArtifactExperimentalAttributes.scala | 55 ++--- .../AwsExperimentalAttributes.scala | 164 +++++-------- .../attributes/AzExperimentalAttributes.scala | 3 +- .../BrowserExperimentalAttributes.scala | 32 +-- .../CicdExperimentalAttributes.scala | 13 +- .../ClientExperimentalAttributes.scala | 14 +- .../CloudExperimentalAttributes.scala | 100 +++----- .../CloudeventsExperimentalAttributes.scala | 26 +-- .../CodeExperimentalAttributes.scala | 25 +- .../ContainerExperimentalAttributes.scala | 54 ++--- .../attributes/DbExperimentalAttributes.scala | 135 +++++------ .../DeploymentExperimentalAttributes.scala | 15 +- .../DestinationExperimentalAttributes.scala | 10 +- .../DeviceExperimentalAttributes.scala | 33 ++- .../DnsExperimentalAttributes.scala | 8 +- .../ErrorExperimentalAttributes.scala | 27 +-- .../EventExperimentalAttributes.scala | 8 +- .../ExceptionExperimentalAttributes.scala | 38 ++- .../FaasExperimentalAttributes.scala | 92 +++----- .../FeatureFlagExperimentalAttributes.scala | 16 +- .../FileExperimentalAttributes.scala | 10 +- .../GcpExperimentalAttributes.scala | 36 ++- .../GenAiExperimentalAttributes.scala | 46 ++-- .../attributes/GoExperimentalAttributes.scala | 6 +- .../HostExperimentalAttributes.scala | 32 ++- .../HttpExperimentalAttributes.scala | 129 +++++------ .../JvmExperimentalAttributes.scala | 7 +- .../K8sExperimentalAttributes.scala | 49 ++-- .../LogExperimentalAttributes.scala | 20 +- .../MessagingExperimentalAttributes.scala | 141 +++++------- .../NetExperimentalAttributes.scala | 6 +- .../NetworkExperimentalAttributes.scala | 41 ++-- .../OciExperimentalAttributes.scala | 16 +- .../OpentracingExperimentalAttributes.scala | 3 +- .../attributes/OsExperimentalAttributes.scala | 7 +- .../OtelExperimentalAttributes.scala | 12 +- .../PeerExperimentalAttributes.scala | 5 +- .../ProcessExperimentalAttributes.scala | 57 ++--- .../RpcExperimentalAttributes.scala | 120 ++++------ .../ServerExperimentalAttributes.scala | 13 +- .../ServiceExperimentalAttributes.scala | 75 +++--- .../SourceExperimentalAttributes.scala | 10 +- .../SystemExperimentalAttributes.scala | 3 +- .../TelemetryExperimentalAttributes.scala | 21 +- .../TestExperimentalAttributes.scala | 6 +- .../TlsExperimentalAttributes.scala | 106 ++++----- .../UrlExperimentalAttributes.scala | 100 +++----- .../UserAgentExperimentalAttributes.scala | 29 +-- .../UserExperimentalAttributes.scala | 6 +- .../V8jsExperimentalAttributes.scala | 3 +- .../VcsExperimentalAttributes.scala | 52 ++--- .../WebengineExperimentalAttributes.scala | 3 +- .../semconv/attributes/ClientAttributes.scala | 14 +- .../semconv/attributes/ErrorAttributes.scala | 27 +-- .../attributes/ExceptionAttributes.scala | 38 ++- .../semconv/attributes/HttpAttributes.scala | 95 +++----- .../semconv/attributes/JvmAttributes.scala | 7 +- .../attributes/NetworkAttributes.scala | 30 +-- .../semconv/attributes/OtelAttributes.scala | 12 +- .../semconv/attributes/ServerAttributes.scala | 13 +- .../attributes/ServiceAttributes.scala | 12 +- .../attributes/TelemetryAttributes.scala | 13 +- .../semconv/attributes/UrlAttributes.scala | 36 ++- .../attributes/UserAgentAttributes.scala | 5 +- 286 files changed, 2401 insertions(+), 3764 deletions(-) diff --git a/.scalafmt.conf b/.scalafmt.conf index 4614214fa..01c5f9ccf 100644 --- a/.scalafmt.conf +++ b/.scalafmt.conf @@ -1,5 +1,6 @@ version = 3.8.3 runner.dialect = scala213 +maxColumn = 120 fileOverride { "glob:**/scala-3/**" { diff --git a/build.sbt b/build.sbt index ecc34df21..0bf1d19b9 100644 --- a/build.sbt +++ b/build.sbt @@ -16,9 +16,7 @@ ThisBuild / tlSonatypeUseLegacyHost := false ThisBuild / tlSitePublishBranch := Some("main") lazy val scalafixSettings = Seq( - semanticdbOptions ++= Seq("-P:semanticdb:synthetics:on").filter(_ => - !tlIsScala3.value - ) + semanticdbOptions ++= Seq("-P:semanticdb:synthetics:on").filter(_ => !tlIsScala3.value) ) lazy val scalaJSLinkerSettings = Def.settings( diff --git a/core/common/src/main/scala/org/typelevel/otel4s/Attribute.scala b/core/common/src/main/scala/org/typelevel/otel4s/Attribute.scala index 103e2003f..bac7709b6 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/Attribute.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/Attribute.scala @@ -36,8 +36,7 @@ object Attribute { def apply[A: AttributeKey.KeySelect](name: String, value: A): Attribute[A] = Attribute(AttributeKey.KeySelect[A].make(name), value) - implicit val showAttribute: Show[Attribute[_]] = (a: Attribute[_]) => - s"${show"${a.key}"}=${a.value}" + implicit val showAttribute: Show[Attribute[_]] = (a: Attribute[_]) => s"${show"${a.key}"}=${a.value}" implicit def hashAttribute[T: Hash]: Hash[Attribute[T]] = Hash.by(a => (a.key, a.value)) diff --git a/core/common/src/main/scala/org/typelevel/otel4s/AttributeKey.scala b/core/common/src/main/scala/org/typelevel/otel4s/AttributeKey.scala index 904fb2339..be06c738c 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/AttributeKey.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/AttributeKey.scala @@ -20,8 +20,7 @@ import cats.Hash import cats.Show import cats.syntax.show._ -/** The type of value that can be set with an implementation of this key is - * denoted by the type parameter. +/** The type of value that can be set with an implementation of this key is denoted by the type parameter. * * @tparam A * the type of value that can be set with the key @@ -36,16 +35,14 @@ sealed trait AttributeKey[A] { final def apply(value: A): Attribute[A] = Attribute(this, value) /** @return - * an [[`AttributeKey`]] of the same type as this key, with name - * transformed by `f` + * an [[`AttributeKey`]] of the same type as this key, with name transformed by `f` */ final def transformName(f: String => String): AttributeKey[A] = new AttributeKey.Impl[A](f(name), `type`) } object AttributeKey { - private class Impl[A](val name: String, val `type`: AttributeType[A]) - extends AttributeKey[A] { + private class Impl[A](val name: String, val `type`: AttributeType[A]) extends AttributeKey[A] { override final def toString: String = Show[AttributeKey[A]].show(this) diff --git a/core/common/src/main/scala/org/typelevel/otel4s/AttributeType.scala b/core/common/src/main/scala/org/typelevel/otel4s/AttributeType.scala index a8c765298..e0e74e074 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/AttributeType.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/AttributeType.scala @@ -19,8 +19,8 @@ package org.typelevel.otel4s import cats.Hash import cats.Show -/** Represents all possible value types for an [[AttributeKey]] and hence the - * types of values that are allowed for [[Attribute]]. +/** Represents all possible value types for an [[AttributeKey]] and hence the types of values that are allowed for + * [[Attribute]]. */ sealed trait AttributeType[A] extends Product with Serializable diff --git a/core/common/src/main/scala/org/typelevel/otel4s/Attributes.scala b/core/common/src/main/scala/org/typelevel/otel4s/Attributes.scala index cef84f6cd..1cc71958f 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/Attributes.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/Attributes.scala @@ -37,59 +37,51 @@ sealed trait Attributes with IterableOps[Attribute[_], immutable.Iterable, Attributes] { /** @return - * an [[`Attribute`]] matching the given attribute name and type, or `None` - * if not found. + * an [[`Attribute`]] matching the given attribute name and type, or `None` if not found. */ final def get[T: KeySelect](name: String): Option[Attribute[T]] = get(KeySelect[T].make(name)) /** @return - * an [[`Attribute`]] matching the given attribute key, or `None` if not - * found + * an [[`Attribute`]] matching the given attribute key, or `None` if not found */ def get[T](key: AttributeKey[T]): Option[Attribute[T]] - /** Adds an [[`Attribute`]] with the given name and value to these - * `Attributes`, replacing any `Attribute` with the same name and type if one - * exists. + /** Adds an [[`Attribute`]] with the given name and value to these `Attributes`, replacing any `Attribute` with the + * same name and type if one exists. */ final def added[T: KeySelect](name: String, value: T): Attributes = added(Attribute(name, value)) - /** Adds an [[`Attribute`]] with the given key and value to these - * `Attributes`, replacing any `Attribute` with the same key if one exists. + /** Adds an [[`Attribute`]] with the given key and value to these `Attributes`, replacing any `Attribute` with the + * same key if one exists. */ final def added[T](key: AttributeKey[T], value: T): Attributes = added(Attribute(key, value)) - /** Adds the given [[`Attribute`]] to these `Attributes`, replacing any - * `Attribute` with the same key if one exists. + /** Adds the given [[`Attribute`]] to these `Attributes`, replacing any `Attribute` with the same key if one exists. */ def added(attribute: Attribute[_]): Attributes - /** Adds the given [[`Attribute`]] to these `Attributes`, replacing any - * `Attribute` with the same key if one exists. + /** Adds the given [[`Attribute`]] to these `Attributes`, replacing any `Attribute` with the same key if one exists. */ final def +(attribute: Attribute[_]): Attributes = added(attribute) - /** Invariant overload of - * [[scala.collection.IterableOps.concat `IterableOps#concat`]] that returns - * `Attributes` rather than `Iterable`. + /** Invariant overload of [[scala.collection.IterableOps.concat `IterableOps#concat`]] that returns `Attributes` + * rather than `Iterable`. * - * If multiple [[`Attribute`]]s in `this` and/or `that` have the same key, - * only the final one (according to `that`'s iterator) will be retained in - * the resulting `Attributes`. + * If multiple [[`Attribute`]]s in `this` and/or `that` have the same key, only the final one (according to `that`'s + * iterator) will be retained in the resulting `Attributes`. */ def concat(that: IterableOnce[Attribute[_]]): Attributes = fromSpecific(this.view ++ that) - /** Invariant overload of [[scala.collection.IterableOps.++ `IterableOps#++`]] - * that returns `Attributes` rather than `Iterable`. + /** Invariant overload of [[scala.collection.IterableOps.++ `IterableOps#++`]] that returns `Attributes` rather than + * `Iterable`. * - * If multiple [[`Attribute`]]s in `this` and/or `that` have the same key, - * only the final one (according to `that`'s iterator) will be retained in - * the resulting `Attributes`. + * If multiple [[`Attribute`]]s in `this` and/or `that` have the same key, only the final one (according to `that`'s + * iterator) will be retained in the resulting `Attributes`. */ final def ++(that: IterableOnce[Attribute[_]]): Attributes = concat(that) @@ -109,8 +101,7 @@ sealed trait Attributes coll: IterableOnce[Attribute[_]] ): Attributes = attributesFactory.fromSpecific(coll) - override protected def newSpecificBuilder - : mutable.Builder[Attribute[_], Attributes] = + override protected def newSpecificBuilder: mutable.Builder[Attribute[_], Attributes] = attributesFactory.newBuilder override protected[this] def className: String = "Attributes" @@ -133,8 +124,7 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { /** Creates [[Attributes]] with the given `attributes`. * * @note - * if there are duplicated keys in the given `attributes`, only the last - * occurrence will be retained. + * if there are duplicated keys in the given `attributes`, only the last occurrence will be retained. * * @param attributes * the attributes to use @@ -153,8 +143,7 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { /** Creates [[Attributes]] from the given collection. * * @note - * if there are duplicated keys in the given `attributes`, only the last - * occurrence will be retained. + * if there are duplicated keys in the given `attributes`, only the last occurrence will be retained. * * @param attributes * the attributes to use @@ -191,8 +180,7 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { /** Adds the attribute with the given `key` and `value` to the builder. * * @note - * if the given `key` is already present in the builder, the value will - * be overwritten with the given `value`. + * if the given `key` is already present in the builder, the value will be overwritten with the given `value`. * * @param key * the key of the attribute. Denotes the types of the `value` @@ -205,12 +193,10 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { this } - /** Adds the attribute with the given `key` (created from `name`) and - * `value` to the builder. + /** Adds the attribute with the given `key` (created from `name`) and `value` to the builder. * * @note - * if the given `key` is already present in the builder, the value will - * be overwritten with the given `value`. + * if the given `key` is already present in the builder, the value will be overwritten with the given `value`. * * @param name * the name of the attribute's key @@ -227,8 +213,8 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { /** Adds the given `attribute` to the builder. * * @note - * if the key of the given `attribute` is already present in the builder, - * the value will be overwritten with the corresponding given attribute. + * if the key of the given `attribute` is already present in the builder, the value will be overwritten with the + * corresponding given attribute. * * @param attribute * the attribute to add @@ -241,9 +227,8 @@ object Attributes extends SpecificIterableFactory[Attribute[_], Attributes] { /** Adds the given `attributes` to the builder. * * @note - * if the keys of the given `attributes` are already present in the - * builder, the values will be overwritten with the corresponding given - * attributes. + * if the keys of the given `attributes` are already present in the builder, the values will be overwritten with + * the corresponding given attributes. * * @param attributes * the attributes to add diff --git a/core/common/src/main/scala/org/typelevel/otel4s/KindTransformer.scala b/core/common/src/main/scala/org/typelevel/otel4s/KindTransformer.scala index 889dd0992..c4f0b12fd 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/KindTransformer.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/KindTransformer.scala @@ -28,8 +28,7 @@ import cats.effect.kernel.MonadCancelThrow import cats.effect.kernel.Resource import cats.~> -/** A utility for transforming the higher-kinded type `F` to another - * higher-kinded type `G`. +/** A utility for transforming the higher-kinded type `F` to another higher-kinded type `G`. */ @annotation.implicitNotFound("No transformer defined from ${F} to ${G}") trait KindTransformer[F[_], G[_]] { @@ -37,28 +36,25 @@ trait KindTransformer[F[_], G[_]] { /** A higher-kinded function that lifts the kind `F` into a `G`. * * @note - * This method is usually best implemented by a `liftK` method on `G`'s - * companion object. + * This method is usually best implemented by a `liftK` method on `G`'s companion object. */ val liftK: F ~> G /** Modify the context of `G[A]` using the natural transformation `f`. * - * This method is "limited" in the sense that while most `mapK` methods can - * modify the context using arbitrary transformations, this method can only - * modify the context using natural transformations. + * This method is "limited" in the sense that while most `mapK` methods can modify the context using arbitrary + * transformations, this method can only modify the context using natural transformations. * * @note * This method is usually best implemented by a `mapK` method on `G`. */ def limitedMapK[A](ga: G[A])(f: F ~> F): G[A] - /** Lifts a natural transformation from `F` to `F` into a natural - * transformation from `G` to `G`. + /** Lifts a natural transformation from `F` to `F` into a natural transformation from `G` to `G`. * * @note - * Implementors SHOULD NOT override this method; the only reason it is not - * final is for optimization of the identity case. + * Implementors SHOULD NOT override this method; the only reason it is not final is for optimization of the + * identity case. */ def liftFunctionK(f: F ~> F): G ~> G = new (G ~> G) { @@ -109,8 +105,7 @@ object KindTransformer { ga.mapK(f) } - implicit def resource[F[_]: MonadCancelThrow] - : KindTransformer[F, Resource[F, *]] = + implicit def resource[F[_]: MonadCancelThrow]: KindTransformer[F, Resource[F, *]] = new KindTransformer[F, Resource[F, *]] { val liftK: F ~> Resource[F, *] = Resource.liftK def limitedMapK[A](ga: Resource[F, A])(f: F ~> F): Resource[F, A] = diff --git a/core/common/src/main/scala/org/typelevel/otel4s/baggage/Baggage.scala b/core/common/src/main/scala/org/typelevel/otel4s/baggage/Baggage.scala index c9825cd08..02382a09b 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/baggage/Baggage.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/baggage/Baggage.scala @@ -20,8 +20,7 @@ import cats.Hash import cats.Show import cats.syntax.show._ -/** A baggage can be used to attach log messages or debugging information to the - * context. +/** A baggage can be used to attach log messages or debugging information to the context. * * @see * [[https://opentelemetry.io/docs/specs/otel/baggage/api/]] @@ -34,8 +33,7 @@ import cats.syntax.show._ */ sealed trait Baggage { - /** Returns the entry to which the specified key is mapped, or `None` if this - * map contains no mapping for the key. + /** Returns the entry to which the specified key is mapped, or `None` if this map contains no mapping for the key. */ def get(key: String): Option[Baggage.Entry] diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/Contextual.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/Contextual.scala index 01687c3fb..36048ccdb 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/Contextual.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/Contextual.scala @@ -22,19 +22,17 @@ trait Contextual[C] { outer => /** The type of [[context.Key `Key`]] used by contexts of type `C`. */ type Key[A] <: context.Key[A] - /** Retrieves the value associated with the given key from the context, if - * such a value exists. + /** Retrieves the value associated with the given key from the context, if such a value exists. */ def get[A](ctx: C)(key: Key[A]): Option[A] - /** Retrieves the value associated with the given key from the context, if - * such a value exists; otherwise, returns the provided default value. + /** Retrieves the value associated with the given key from the context, if such a value exists; otherwise, returns the + * provided default value. */ def getOrElse[A](ctx: C)(key: Key[A], default: => A): A = get(ctx)(key).getOrElse(default) - /** Creates a copy of this context with the given value associated with the - * given key. + /** Creates a copy of this context with the given value associated with the given key. */ def updated[A](ctx: C)(key: Key[A], value: A): C @@ -43,20 +41,18 @@ trait Contextual[C] { outer => class ContextSyntax(ctx: C) { - /** Retrieves the value associated with the given key from the context, if - * such a value exists. + /** Retrieves the value associated with the given key from the context, if such a value exists. */ def get[A](key: Key[A]): Option[A] = outer.get(ctx)(key) - /** Retrieves the value associated with the given key from the context, if - * such a value exists; otherwise, returns the provided default value. + /** Retrieves the value associated with the given key from the context, if such a value exists; otherwise, returns + * the provided default value. */ def getOrElse[A](key: Key[A], default: => A): A = outer.getOrElse(ctx)(key, default) - /** Creates a copy of this context with the given value associated with the - * given key. + /** Creates a copy of this context with the given value associated with the given key. */ def updated[A](key: Key[A], value: A): C = outer.updated(ctx)(key, value) @@ -65,8 +61,7 @@ trait Contextual[C] { outer => object Contextual { - /** A type alias for a [[`Contextual`]] explicitly parameterized by its - * [[Contextual.Key `Key`]] type. + /** A type alias for a [[`Contextual`]] explicitly parameterized by its [[Contextual.Key `Key`]] type. */ type Keyed[C, K[X] <: Key[X]] = Contextual[C] { type Key[A] = K[A] } diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/LocalProvider.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/LocalProvider.scala index 9d7c93d04..688a1b522 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/LocalProvider.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/LocalProvider.scala @@ -52,8 +52,7 @@ val provider = LocalProvider[IO, ${Ctx}] """) trait LocalProvider[F[_], Ctx] { - /** Creates a [[cats.mtl.Local Local]] instance. The method is invoked once - * per creation of the Otel4s instance. + /** Creates a [[cats.mtl.Local Local]] instance. The method is invoked once per creation of the Otel4s instance. */ def local: F[Local[F, Ctx]] } @@ -62,8 +61,8 @@ object LocalProvider extends LocalProviderLowPriority { def apply[F[_], C](implicit ev: LocalProvider[F, C]): LocalProvider[F, C] = ev - /** Creates [[LocalProvider]] that derives [[cats.mtl.Local Local]] instance - * from the given [[cats.effect.IOLocal IOLocal]]. + /** Creates [[LocalProvider]] that derives [[cats.mtl.Local Local]] instance from the given + * [[cats.effect.IOLocal IOLocal]]. * * @param ioLocal * the [[cats.effect.IOLocal IOLocal]] to use @@ -86,8 +85,7 @@ object LocalProvider extends LocalProviderLowPriority { override def toString: String = "LocalProvider.fromIOLocal" } - /** Creates [[LocalProvider]] that returns the given [[cats.mtl.Local Local]] - * instance. + /** Creates [[LocalProvider]] that returns the given [[cats.mtl.Local Local]] instance. * * @param l * the [[cats.mtl.Local Local]] to use @@ -106,14 +104,13 @@ object LocalProvider extends LocalProviderLowPriority { override def toString: String = "LocalProvider.fromLocal" } - /** Creates [[LocalProvider]] that creates [[cats.effect.IOLocal IOLocal]] - * under the hood to derive the [[cats.mtl.Local Local]] instance. + /** Creates [[LocalProvider]] that creates [[cats.effect.IOLocal IOLocal]] under the hood to derive the + * [[cats.mtl.Local Local]] instance. * * @note - * every invocation of the [[LocalProvider.local]] creates new - * [[cats.effect.IOLocal IOLocal]]. If you want to use a custom - * [[cats.effect.IOLocal IOLocal]] (e.g. to share it with other components) - * use [[LocalProvider.fromIOLocal]]. + * every invocation of the [[LocalProvider.local]] creates new [[cats.effect.IOLocal IOLocal]]. If you want to use + * a custom [[cats.effect.IOLocal IOLocal]] (e.g. to share it with other components) use + * [[LocalProvider.fromIOLocal]]. * * @tparam F * the higher-kinded type of a polymorphic effect diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/ContextPropagators.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/ContextPropagators.scala index f23db2635..1b4b74f5a 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/ContextPropagators.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/ContextPropagators.scala @@ -30,11 +30,10 @@ sealed trait ContextPropagators[Ctx] { object ContextPropagators { - /** Creates a [[ContextPropagators]] which can be used to extract and inject - * context in text payloads with the given [[TextMapPropagator]]. + /** Creates a [[ContextPropagators]] which can be used to extract and inject context in text payloads with the given + * [[TextMapPropagator]]. * - * If multiple text map propagators are passed, the combined (composite) - * TextMapPropagator instance will be created. + * If multiple text map propagators are passed, the combined (composite) TextMapPropagator instance will be created. * * It's a shortcut for: * {{{ diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/PassThroughPropagator.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/PassThroughPropagator.scala index 517c11684..88caf714c 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/PassThroughPropagator.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/PassThroughPropagator.scala @@ -20,9 +20,8 @@ package propagation import cats.effect.SyncIO import org.typelevel.otel4s.context.syntax._ -/** A [[TextMapPropagator]] that extracts a specified collection of fields and - * stores them in a context, and extracts them from a context later for - * injection. It does not interact with telemetry. +/** A [[TextMapPropagator]] that extracts a specified collection of fields and stores them in a context, and extracts + * them from a context later for injection. It does not interact with telemetry. */ final class PassThroughPropagator[Ctx, K[X] <: Key[X]] private ( val fields: Iterable[String], @@ -49,8 +48,7 @@ final class PassThroughPropagator[Ctx, K[X] <: Key[X]] private ( } object PassThroughPropagator { - private def forDistinctFields[Ctx, K[X] <: Key[X]](fields: Seq[String])( - implicit + private def forDistinctFields[Ctx, K[X] <: Key[X]](fields: Seq[String])(implicit c: Contextual.Keyed[Ctx, K], kp: Key.Provider[SyncIO, K] ): TextMapPropagator[Ctx] = diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapGetter.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapGetter.scala index 38805837a..8888f752a 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapGetter.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapGetter.scala @@ -23,15 +23,12 @@ import scala.collection.generic.IsSeq /** Offers a way to get a string value associated with a given key. * - * A type class can be implemented for any data structure that stores key-value - * pairs. + * A type class can be implemented for any data structure that stores key-value pairs. * - * Implicit instances of `TextMapGetter` are provided for - * [[scala.collection.Map]] and [[scala.collection.Seq]] types. The behavior of - * `TextMapGetter[Seq[(String, String)]]` when duplicate keys are present is - * unspecified, and may change at any time. In particular, if the behavior of - * `Seq` types with duplicate keys is ever specified by open telemetry, the - * behavior of such implicit instances will be made to match the specification. + * Implicit instances of `TextMapGetter` are provided for [[scala.collection.Map]] and [[scala.collection.Seq]] types. + * The behavior of `TextMapGetter[Seq[(String, String)]]` when duplicate keys are present is unspecified, and may + * change at any time. In particular, if the behavior of `Seq` types with duplicate keys is ever specified by open + * telemetry, the behavior of such implicit instances will be made to match the specification. * * @see * See [[TextMapUpdater]] to update values of an immutable carrier @@ -53,13 +50,11 @@ trait TextMapGetter[A] { * the key to get the value at * * @return - * a [[scala.Some]] if the `key` is present in `carrier` and [[scala.None]] - * otherwise + * a [[scala.Some]] if the `key` is present in `carrier` and [[scala.None]] otherwise */ def get(carrier: A, key: String): Option[String] - /** Returns a collection of all available keys in the given `carrier`. The - * collection SHOULD never return duplicates. + /** Returns a collection of all available keys in the given `carrier`. The collection SHOULD never return duplicates. * * @param carrier * the carrier to get keys from diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapPropagator.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapPropagator.scala index ce04ab081..cfe7fb8df 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapPropagator.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapPropagator.scala @@ -19,17 +19,15 @@ package org.typelevel.otel4s.context.propagation import cats.Monoid import cats.syntax.foldable._ -/** The process of propagating data across process boundaries involves injecting - * and extracting values in the form of text into carriers that travel in-band. +/** The process of propagating data across process boundaries involves injecting and extracting values in the form of + * text into carriers that travel in-band. * - * The encoding used for this process is expected to conform to HTTP Header - * Field semantics, and values are commonly encoded as request headers for - * RPC/HTTP requests. + * The encoding used for this process is expected to conform to HTTP Header Field semantics, and values are commonly + * encoded as request headers for RPC/HTTP requests. * - * The carriers used for propagating the data are typically HTTP requests, and - * the process is often implemented using library-specific request - * interceptors. On the client side, values are injected into the carriers, - * while on the server side, values are extracted from them. + * The carriers used for propagating the data are typically HTTP requests, and the process is often implemented using + * library-specific request interceptors. On the client side, values are injected into the carriers, while on the + * server side, values are extracted from them. * * @tparam Ctx * the context to use to extract or inject data @@ -39,8 +37,7 @@ trait TextMapPropagator[Ctx] { /** The collection of propagation fields. */ def fields: Iterable[String] - /** Extracts key-value pairs from the given `carrier` and adds them to the - * given context. + /** Extracts key-value pairs from the given `carrier` and adds them to the given context. * * @param ctx * the context object to which the key-value pairs are added @@ -56,11 +53,10 @@ trait TextMapPropagator[Ctx] { */ def extract[A: TextMapGetter](ctx: Ctx, carrier: A): Ctx - /** Injects data from the context into a copy of the given immutable `carrier` - * for downstream consumers, for example as HTTP headers. + /** Injects data from the context into a copy of the given immutable `carrier` for downstream consumers, for example + * as HTTP headers. * - * This method is an extension to the OpenTelemetry specification to support - * immutable carrier types. + * This method is an extension to the OpenTelemetry specification to support immutable carrier types. * * @param ctx * the context containing the value to be injected @@ -79,8 +75,7 @@ trait TextMapPropagator[Ctx] { object TextMapPropagator { - /** Creates a [[TextMapPropagator]] which delegates injection and extraction - * to the provided propagators. + /** Creates a [[TextMapPropagator]] which delegates injection and extraction to the provided propagators. * * @example * {{{ diff --git a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapUpdater.scala b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapUpdater.scala index ca3c70399..ff6f2dcc8 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapUpdater.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/context/propagation/TextMapUpdater.scala @@ -22,15 +22,12 @@ import scala.collection.immutable.MapOps import scala.collection.immutable.SeqOps import scala.collection.immutable.SortedMapOps -/** Offers a way to store a string value associated with a given key to an - * immutable carrier type. +/** Offers a way to store a string value associated with a given key to an immutable carrier type. * - * Implicit instances of `TextMapUpdater` are provided for - * [[scala.collection.immutable.Map]] and [[scala.collection.immutable.Seq]] - * types.The behavior of `TextMapUpdater[Seq[(String, String)]]` when duplicate - * keys are present is unspecified, and may change at any time. In particular, - * if the behavior of `Seq` types with duplicate keys is ever specified by open - * telemetry, the behavior of such implicit instances will be made to match the + * Implicit instances of `TextMapUpdater` are provided for [[scala.collection.immutable.Map]] and + * [[scala.collection.immutable.Seq]] types.The behavior of `TextMapUpdater[Seq[(String, String)]]` when duplicate keys + * are present is unspecified, and may change at any time. In particular, if the behavior of `Seq` types with duplicate + * keys is ever specified by open telemetry, the behavior of such implicit instances will be made to match the * specification. * * @see @@ -41,8 +38,7 @@ import scala.collection.immutable.SortedMapOps */ trait TextMapUpdater[A] { - /** Updates a carrier with the given `key` associated with the given `value`. - * The original `carrier` is unmodified. + /** Updates a carrier with the given `key` associated with the given `value`. The original `carrier` is unmodified. * * '''Important:''' the carrier must to be '''immutable'''. * @@ -61,28 +57,22 @@ trait TextMapUpdater[A] { object TextMapUpdater { def apply[A](implicit updater: TextMapUpdater[A]): TextMapUpdater[A] = updater - implicit def forMap[CC[x, +y] <: MapOps[x, y, CC, CC[x, y]]] - : TextMapUpdater[CC[String, String]] = - (carrier: CC[String, String], key: String, value: String) => - carrier.updated(key, value) + implicit def forMap[CC[x, +y] <: MapOps[x, y, CC, CC[x, y]]]: TextMapUpdater[CC[String, String]] = + (carrier: CC[String, String], key: String, value: String) => carrier.updated(key, value) implicit def forSortedMap[ CC[x, +y] <: Map[x, y] with SortedMapOps[x, y, CC, CC[x, y]] ]: TextMapUpdater[CC[String, String]] = - (carrier: CC[String, String], key: String, value: String) => - carrier.updated(key, value) + (carrier: CC[String, String], key: String, value: String) => carrier.updated(key, value) - implicit def forSeq[CC[x] <: SeqOps[x, CC, CC[x]]] - : TextMapUpdater[CC[(String, String)]] = - (carrier: CC[(String, String)], key: String, value: String) => - carrier.appended(key -> value) + implicit def forSeq[CC[x] <: SeqOps[x, CC, CC[x]]]: TextMapUpdater[CC[(String, String)]] = + (carrier: CC[(String, String)], key: String, value: String) => carrier.appended(key -> value) implicit val invariant: Invariant[TextMapUpdater] = new Invariant[TextMapUpdater] { override def imap[A, B]( fa: TextMapUpdater[A] )(f: A => B)(g: B => A): TextMapUpdater[B] = - (carrier: B, key: String, value: String) => - f(fa.updated(g(carrier), key, value)) + (carrier: B, key: String, value: String) => f(fa.updated(g(carrier), key, value)) } } diff --git a/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala b/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala index 8c44322bb..1c48dc03a 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala @@ -36,9 +36,7 @@ trait LocalInstances { def ask[E2 >: E]: F[E2] = Functor[F].widen[E, E2](ioLocal.get.to[F]) def local[A](fa: F[A])(f: E => E): F[A] = - MonadCancelThrow[F].bracket(ioLocal.modify(e => (f(e), e)).to[F])(_ => - fa - )(ioLocal.set(_).to[F]) + MonadCancelThrow[F].bracket(ioLocal.modify(e => (f(e), e)).to[F])(_ => fa)(ioLocal.set(_).to[F]) } } diff --git a/core/common/src/main/scala/org/typelevel/otel4s/meta/InstrumentMeta.scala b/core/common/src/main/scala/org/typelevel/otel4s/meta/InstrumentMeta.scala index d8b946645..b18eb727c 100644 --- a/core/common/src/main/scala/org/typelevel/otel4s/meta/InstrumentMeta.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/meta/InstrumentMeta.scala @@ -34,8 +34,7 @@ trait InstrumentMeta[F[_]] { def mapK[G[_]](f: F ~> G): InstrumentMeta[G] = new InstrumentMeta.MappedK(this)(f) - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]](implicit kt: KindTransformer[F, G]): InstrumentMeta[G] = mapK(kt.liftK) @@ -55,8 +54,7 @@ object InstrumentMeta { val unit: F[Unit] = Applicative[F].unit } - private class MappedK[F[_], G[_]](meta: InstrumentMeta[F])(f: F ~> G) - extends InstrumentMeta[G] { + private class MappedK[F[_], G[_]](meta: InstrumentMeta[F])(f: F ~> G) extends InstrumentMeta[G] { def isEnabled: Boolean = meta.isEnabled def unit: G[Unit] = f(meta.unit) } diff --git a/core/common/src/test/scala/org/typelevel/otel4s/NotQuiteExhaustiveChecks.scala b/core/common/src/test/scala/org/typelevel/otel4s/NotQuiteExhaustiveChecks.scala index 45f5676cc..851804db6 100644 --- a/core/common/src/test/scala/org/typelevel/otel4s/NotQuiteExhaustiveChecks.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/NotQuiteExhaustiveChecks.scala @@ -20,8 +20,8 @@ import cats.laws.discipline.ExhaustiveCheck import cats.syntax.traverse._ import org.scalacheck.util.Buildable -/** [[cats.laws.discipline.ExhaustiveCheck]] instances that aren't actually - * exhaustive but are needed for laws testing of `TextMap` types. +/** [[cats.laws.discipline.ExhaustiveCheck]] instances that aren't actually exhaustive but are needed for laws testing + * of `TextMap` types. */ object NotQuiteExhaustiveChecks { implicit val notQuiteExhaustiveCheckString: ExhaustiveCheck[String] = diff --git a/core/common/src/test/scala/org/typelevel/otel4s/baggage/BaggageSuite.scala b/core/common/src/test/scala/org/typelevel/otel4s/baggage/BaggageSuite.scala index a9e83ec99..75a823223 100644 --- a/core/common/src/test/scala/org/typelevel/otel4s/baggage/BaggageSuite.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/baggage/BaggageSuite.scala @@ -37,9 +37,7 @@ class BaggageSuite extends DisciplineSuite { Arbitrary( for { entries <- Gen.listOfN(5, keyValueGen) - } yield entries.foldLeft(Baggage.empty)((b, v) => - b.updated(v._1, v._2, v._3) - ) + } yield entries.foldLeft(Baggage.empty)((b, v) => b.updated(v._1, v._2, v._3)) ) private implicit val baggageCogen: Cogen[Baggage] = @@ -64,23 +62,22 @@ class BaggageSuite extends DisciplineSuite { } test("update entries") { - Prop.forAll(keyValueGen, Gen.alphaNumStr) { - case ((key, value1, metadata), value2) => - val entry1 = Baggage.Entry(value1, metadata.map(Baggage.Metadata(_))) - val baggage1 = Baggage.empty.updated(key, value1, metadata) - - assertEquals(baggage1.asMap, Map(key -> entry1)) - assertEquals(baggage1.size, 1) - assertEquals(baggage1.isEmpty, false) - assertEquals(baggage1.get(key), Some(entry1)) - - val entry2 = Baggage.Entry(value2, None) - val baggage2 = baggage1.updated(key, value2) - - assertEquals(baggage2.asMap, Map(key -> entry2)) - assertEquals(baggage2.size, 1) - assertEquals(baggage2.isEmpty, false) - assertEquals(baggage2.get(key), Some(entry2)) + Prop.forAll(keyValueGen, Gen.alphaNumStr) { case ((key, value1, metadata), value2) => + val entry1 = Baggage.Entry(value1, metadata.map(Baggage.Metadata(_))) + val baggage1 = Baggage.empty.updated(key, value1, metadata) + + assertEquals(baggage1.asMap, Map(key -> entry1)) + assertEquals(baggage1.size, 1) + assertEquals(baggage1.isEmpty, false) + assertEquals(baggage1.get(key), Some(entry1)) + + val entry2 = Baggage.Entry(value2, None) + val baggage2 = baggage1.updated(key, value2) + + assertEquals(baggage2.asMap, Map(key -> entry2)) + assertEquals(baggage2.size, 1) + assertEquals(baggage2.isEmpty, false) + assertEquals(baggage2.get(key), Some(entry2)) } } @@ -97,8 +94,8 @@ class BaggageSuite extends DisciplineSuite { test("Show[Baggage]") { Prop.forAll(Gen.listOfN(5, keyValueGen)) { entries => - val baggage = entries.foldLeft(Baggage.empty) { - case (builder, (key, value, meta)) => builder.updated(key, value, meta) + val baggage = entries.foldLeft(Baggage.empty) { case (builder, (key, value, meta)) => + builder.updated(key, value, meta) } val entriesString = entries diff --git a/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapGetterSuite.scala b/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapGetterSuite.scala index 72f64a59e..5072e2e4b 100644 --- a/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapGetterSuite.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapGetterSuite.scala @@ -91,14 +91,13 @@ class TextMapGetterSuite extends FunSuite with DisciplineSuite { locally { // constrain `import NotQuiteExhaustiveChecks._` to a limited scope import NotQuiteExhaustiveChecks._ - implicit def getterEq[A: ExhaustiveCheck]: Eq[TextMapGetter[A]] = { - (x, y) => - ExhaustiveCheck[(A, String)].allValues - .forall { case (carrier, key) => - x.get(carrier, key) === y.get(carrier, key) - } && - ExhaustiveCheck[A].allValues - .forall(carrier => x.keys(carrier).toSet === y.keys(carrier).toSet) + implicit def getterEq[A: ExhaustiveCheck]: Eq[TextMapGetter[A]] = { (x, y) => + ExhaustiveCheck[(A, String)].allValues + .forall { case (carrier, key) => + x.get(carrier, key) === y.get(carrier, key) + } && + ExhaustiveCheck[A].allValues + .forall(carrier => x.keys(carrier).toSet === y.keys(carrier).toSet) } test("TextMapGetter is contravariant") { diff --git a/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapUpdaterSuite.scala b/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapUpdaterSuite.scala index 4b07ceed4..3350b0967 100644 --- a/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapUpdaterSuite.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/context/propagation/TextMapUpdaterSuite.scala @@ -80,12 +80,11 @@ class TextMapUpdaterSuite extends FunSuite with DisciplineSuite { locally { // constrain `import NotQuiteExhaustiveChecks._` to a limited scope import NotQuiteExhaustiveChecks._ - implicit def updaterEq[A: ExhaustiveCheck: Eq]: Eq[TextMapUpdater[A]] = { - (x, y) => - ExhaustiveCheck[(A, String, String)].allValues - .forall { case (carrier, key, value) => - x.updated(carrier, key, value) === y.updated(carrier, key, value) - } + implicit def updaterEq[A: ExhaustiveCheck: Eq]: Eq[TextMapUpdater[A]] = { (x, y) => + ExhaustiveCheck[(A, String, String)].allValues + .forall { case (carrier, key, value) => + x.updated(carrier, key, value) === y.updated(carrier, key, value) + } } test("TextMapUpdater is invariant") { diff --git a/core/common/src/test/scala/org/typelevel/otel4s/context/vault/VaultContext.scala b/core/common/src/test/scala/org/typelevel/otel4s/context/vault/VaultContext.scala index 5546b894f..8cc8a9479 100644 --- a/core/common/src/test/scala/org/typelevel/otel4s/context/vault/VaultContext.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/context/vault/VaultContext.scala @@ -28,20 +28,18 @@ import org.typelevel.vault.Vault */ final class VaultContext private (vault: Vault) { - /** Retrieves the value associated with the given key from the context, if - * such a value exists. + /** Retrieves the value associated with the given key from the context, if such a value exists. */ def get[A](key: VaultContext.Key[A]): Option[A] = vault.lookup(key.underlying) - /** Retrieves the value associated with the given key from the context, if - * such a value exists; otherwise, returns the provided default value. + /** Retrieves the value associated with the given key from the context, if such a value exists; otherwise, returns the + * provided default value. */ def getOrElse[A](key: VaultContext.Key[A], default: => A): A = get(key).getOrElse(default) - /** Creates a copy of this context with the given value associated with the - * given key. + /** Creates a copy of this context with the given value associated with the given key. */ def updated[A](key: VaultContext.Key[A], value: A): VaultContext = new VaultContext(vault.insert(key.underlying, value)) diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/BatchCallback.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/BatchCallback.scala index ab6d16106..e90af39d5 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/BatchCallback.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/BatchCallback.scala @@ -24,8 +24,7 @@ trait BatchCallback[F[_]] { /** Constructs a batch callback. * - * Batch callbacks allow a single callback to observe measurements for - * multiple asynchronous instruments. + * Batch callbacks allow a single callback to observe measurements for multiple asynchronous instruments. * * The callback will be called when the instruments are being observed. * @@ -68,8 +67,7 @@ trait BatchCallback[F[_]] { /** Constructs a batch callback. * - * Batch callbacks allow a single callback to observe measurements for - * multiple asynchronous instruments. + * Batch callbacks allow a single callback to observe measurements for multiple asynchronous instruments. * * The callback will be called when the instruments are being observed. * diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Counter.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Counter.scala index 50ea8fda9..d0d85cd22 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Counter.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Counter.scala @@ -24,8 +24,7 @@ import scala.collection.immutable /** A `Counter` instrument that records values of type `A`. * - * The [[Counter]] is monotonic. This means the aggregated value is nominally - * increasing. + * The [[Counter]] is monotonic. This means the aggregated value is nominally increasing. * * @see * See [[UpDownCounter]] for non-monotonic alternative @@ -34,9 +33,8 @@ import scala.collection.immutable * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Counter[F[_], A] extends CounterMacro[F, A] @@ -48,9 +46,8 @@ object Counter { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Gauge.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Gauge.scala index 125736c5b..0d0ee5aab 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Gauge.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Gauge.scala @@ -34,9 +34,8 @@ import scala.collection.immutable * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Gauge[F[_], A] extends GaugeMacro[F, A] @@ -48,9 +47,8 @@ object Gauge { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Histogram.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Histogram.scala index 6e41e6264..b741cf1aa 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Histogram.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Histogram.scala @@ -26,18 +26,15 @@ import scala.concurrent.duration.TimeUnit /** A `Histogram` instrument that records values of type `A`. * - * [[Histogram]] metric data points convey a population of recorded - * measurements in a compressed format. A histogram bundles a set of events - * into divided populations with an overall event count and aggregate sum for - * all events. + * [[Histogram]] metric data points convey a population of recorded measurements in a compressed format. A histogram + * bundles a set of events into divided populations with an overall event count and aggregate sum for all events. * * @tparam F * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Histogram[F[_], A] extends HistogramMacro[F, A] @@ -49,9 +46,8 @@ object Histogram { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { @@ -87,8 +83,7 @@ object Histogram { boundaries: BucketBoundaries ): Builder[F, A] - /** Creates a [[Histogram]] with the given `unit`, `description`, and - * `bucket boundaries` (if any). + /** Creates a [[Histogram]] with the given `unit`, `description`, and `bucket boundaries` (if any). */ def create: F[Histogram[F, A]] } diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Meter.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Meter.scala index 594377122..192efa91d 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Meter.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/Meter.scala @@ -35,15 +35,12 @@ meterProvider """) trait Meter[F[_]] { - /** Creates a builder of [[Counter]] instrument that records values of type - * `A`. + /** Creates a builder of [[Counter]] instrument that records values of type `A`. * - * The [[Counter]] is monotonic. This means the aggregated value is nominally - * increasing. + * The [[Counter]] is monotonic. This means the aggregated value is nominally increasing. * * @note - * the `A` type must be provided explicitly, for example - * `meter.counter[Long]` or `meter.counter[Double]` + * the `A` type must be provided explicitly, for example `meter.counter[Long]` or `meter.counter[Double]` * * @example * {{{ @@ -63,22 +60,17 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def counter[A: MeasurementValue](name: String): Counter.Builder[F, A] - /** Creates a builder of [[Histogram]] instrument that records values of type - * `A`. + /** Creates a builder of [[Histogram]] instrument that records values of type `A`. * - * [[Histogram]] metric data points convey a population of recorded - * measurements in a compressed format. A histogram bundles a set of events - * into divided populations with an overall event count and aggregate sum for - * all events. + * [[Histogram]] metric data points convey a population of recorded measurements in a compressed format. A histogram + * bundles a set of events into divided populations with an overall event count and aggregate sum for all events. * * @note - * the `A` type must be provided explicitly, for example - * `meter.histogram[Long]` or `meter.histogram[Double]` + * the `A` type must be provided explicitly, for example `meter.histogram[Long]` or `meter.histogram[Double]` * * @example * {{{ @@ -95,20 +87,17 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def histogram[A: MeasurementValue](name: String): Histogram.Builder[F, A] - /** Creates a builder of [[UpDownCounter]] instrument that records values of - * type `A`. + /** Creates a builder of [[UpDownCounter]] instrument that records values of type `A`. * - * The [[UpDownCounter]] is non-monotonic. This means the aggregated value - * can increase and decrease. + * The [[UpDownCounter]] is non-monotonic. This means the aggregated value can increase and decrease. * * @note - * the `A` type must be provided explicitly, for example - * `meter.upDownCounter[Long]` or `meter.upDownCounter[Double]` + * the `A` type must be provided explicitly, for example `meter.upDownCounter[Long]` or + * `meter.upDownCounter[Double]` * * @example * {{{ @@ -128,8 +117,7 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def upDownCounter[A: MeasurementValue]( name: String @@ -140,8 +128,7 @@ trait Meter[F[_]] { * The [[Gauge]] records non-additive values. * * @note - * the `A` type must be provided explicitly, for example - * `meter.gauge[Long]` or `meter.gauge[Double]` + * the `A` type must be provided explicitly, for example `meter.gauge[Long]` or `meter.gauge[Double]` * * @example * {{{ @@ -161,17 +148,15 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def gauge[A: MeasurementValue](name: String): Gauge.Builder[F, A] - /** Creates a builder of [[ObservableGauge]] instrument that collects values - * of type `A` from the given callback. + /** Creates a builder of [[ObservableGauge]] instrument that collects values of type `A` from the given callback. * * @note - * the `A` type must be provided explicitly, for example - * `meter.observableGauge[Long]` or `meter.observableGauge[Double]` + * the `A` type must be provided explicitly, for example `meter.observableGauge[Long]` or + * `meter.observableGauge[Double]` * * @example * {{{ @@ -192,22 +177,19 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def observableGauge[A: MeasurementValue]( name: String ): ObservableGauge.Builder[F, A] - /** Creates a builder of [[ObservableCounter]] instrument that collects values - * of type `A` from the given callback. + /** Creates a builder of [[ObservableCounter]] instrument that collects values of type `A` from the given callback. * - * The [[ObservableCounter]] is monotonic. This means the aggregated value is - * nominally increasing. + * The [[ObservableCounter]] is monotonic. This means the aggregated value is nominally increasing. * * @note - * the `A` type must be provided explicitly, for example - * `meter.observableCounter[Long]` or `meter.observableCounter[Double]` + * the `A` type must be provided explicitly, for example `meter.observableCounter[Long]` or + * `meter.observableCounter[Double]` * * @example * {{{ @@ -231,22 +213,19 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def observableCounter[A: MeasurementValue]( name: String ): ObservableCounter.Builder[F, A] - /** Creates a builder of [[ObservableUpDownCounter]] instrument that collects - * values of type `A` from the given callback. + /** Creates a builder of [[ObservableUpDownCounter]] instrument that collects values of type `A` from the given + * callback. * - * The [[ObservableUpDownCounter]] is non-monotonic. This means the - * aggregated value can increase and decrease. + * The [[ObservableUpDownCounter]] is non-monotonic. This means the aggregated value can increase and decrease. * * @note - * the `A` type must be provided explicitly, for example - * `meter.observableUpDownCounter[Long]` or + * the `A` type must be provided explicitly, for example `meter.observableUpDownCounter[Long]` or * `meter.observableUpDownCounter[Double]` * * @example @@ -265,8 +244,8 @@ trait Meter[F[_]] { * }}} * * @note - * the `A` type must be provided explicitly, for example - * `meter.observableCounter[Long]` or `meter.observableCounter[Double]` + * the `A` type must be provided explicitly, for example `meter.observableCounter[Long]` or + * `meter.observableCounter[Double]` * * @see * See [[observableCounter]] for monotonic alternative @@ -275,8 +254,7 @@ trait Meter[F[_]] { * the name of the instrument * * @tparam A - * the type of the measurement. [[scala.Long]] and [[scala.Double]] are - * supported out of the box + * the type of the measurement. [[scala.Long]] and [[scala.Double]] are supported out of the box */ def observableUpDownCounter[A: MeasurementValue]( name: String @@ -284,8 +262,7 @@ trait Meter[F[_]] { /** Constructs a batch callback. * - * Batch callbacks allow a single callback to observe measurements for - * multiple asynchronous instruments. + * Batch callbacks allow a single callback to observe measurements for multiple asynchronous instruments. * * The callback will be called when the instruments are being observed. * @@ -316,8 +293,7 @@ object Meter { /** Creates a no-op implementation of the [[Meter]]. * - * All meter instruments ([[Counter]], [[Histogram]], etc) have no-op - * implementation too. + * All meter instruments ([[Counter]], [[Histogram]], etc) have no-op implementation too. * * @tparam F * the higher-kinded type of a polymorphic effect diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/MeterProvider.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/MeterProvider.scala index 600f366e7..22c6cf09e 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/MeterProvider.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/MeterProvider.scala @@ -31,8 +31,8 @@ trait MeterProvider[F[_]] { * }}} * * @param name - * the name of the instrumentation scope, such as the instrumentation - * library, package, or fully qualified class name + * the name of the instrumentation scope, such as the instrumentation library, package, or fully qualified class + * name */ def get(name: String): F[Meter[F]] = meter(name).get @@ -50,8 +50,8 @@ trait MeterProvider[F[_]] { * }}} * * @param name - * the name of the instrumentation scope, such as the instrumentation - * library, package, or fully qualified class name + * the name of the instrumentation scope, such as the instrumentation library, package, or fully qualified class + * name */ def meter(name: String): MeterBuilder[F] diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableCounter.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableCounter.scala index 5e0d186e7..b85b87049 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableCounter.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableCounter.scala @@ -28,9 +28,8 @@ object ObservableCounter { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { @@ -54,8 +53,7 @@ object ObservableCounter { */ def withDescription(description: String): Builder[F, A] - /** Creates an instrument with the given callback, using `unit` and - * `description` (if any). + /** Creates an instrument with the given callback, using `unit` and `description` (if any). * * The callback will be called when the instrument is being observed. * @@ -71,14 +69,11 @@ object ObservableCounter { cb: ObservableMeasurement[F, A] => F[Unit] ): Resource[F, ObservableCounter] - /** Creates an asynchronous instrument based on an effect that produces a - * number of measurements. + /** Creates an asynchronous instrument based on an effect that produces a number of measurements. * - * The measurement effect will be evaluated when the instrument is being - * observed. + * The measurement effect will be evaluated when the instrument is being observed. * - * The measurement effect is expected to abide by the following - * restrictions: + * The measurement effect is expected to abide by the following restrictions: * - Short-living and (ideally) non-blocking * - Run in a finite amount of time * - Safe to call repeatedly, across multiple threads @@ -90,12 +85,11 @@ object ObservableCounter { measurements: F[Iterable[Measurement[A]]] ): Resource[F, ObservableCounter] - /** Creates an observer for this instrument to observe values from a - * [[BatchCallback]]. + /** Creates an observer for this instrument to observe values from a [[BatchCallback]]. * * @note - * The observer '''must''' be registered via [[Meter.batchCallback]]. - * Values observed outside registered callbacks are ignored. + * The observer '''must''' be registered via [[Meter.batchCallback]]. Values observed outside registered + * callbacks are ignored. */ def createObserver: F[ObservableMeasurement[F, A]] } diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableGauge.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableGauge.scala index 18a55943c..8b424a939 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableGauge.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableGauge.scala @@ -28,9 +28,8 @@ object ObservableGauge { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { @@ -54,8 +53,7 @@ object ObservableGauge { */ def withDescription(description: String): Builder[F, A] - /** Creates an instrument with the given callback, using `unit` and - * `description` (if any). + /** Creates an instrument with the given callback, using `unit` and `description` (if any). * * The callback will be called when the instrument is being observed. * @@ -71,14 +69,11 @@ object ObservableGauge { cb: ObservableMeasurement[F, A] => F[Unit] ): Resource[F, ObservableGauge] - /** Creates an asynchronous instrument based on an effect that produces a - * number of measurements. + /** Creates an asynchronous instrument based on an effect that produces a number of measurements. * - * The measurement effect will be evaluated when the instrument is being - * observed. + * The measurement effect will be evaluated when the instrument is being observed. * - * The measurement effect is expected to abide by the following - * restrictions: + * The measurement effect is expected to abide by the following restrictions: * - Short-living and (ideally) non-blocking * - Run in a finite amount of time * - Safe to call repeatedly, across multiple threads @@ -90,12 +85,11 @@ object ObservableGauge { measurements: F[Iterable[Measurement[A]]] ): Resource[F, ObservableGauge] - /** Creates an observer for this instrument to observe values from a - * [[BatchCallback]]. + /** Creates an observer for this instrument to observe values from a [[BatchCallback]]. * * @note - * The observer '''must''' be registered via [[Meter.batchCallback]]. - * Values observed outside registered callbacks are ignored. + * The observer '''must''' be registered via [[Meter.batchCallback]]. Values observed outside registered + * callbacks are ignored. */ def createObserver: F[ObservableMeasurement[F, A]] } diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableUpDownCounter.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableUpDownCounter.scala index f53025856..8bdd6a31b 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableUpDownCounter.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/ObservableUpDownCounter.scala @@ -28,9 +28,8 @@ object ObservableUpDownCounter { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { @@ -54,8 +53,7 @@ object ObservableUpDownCounter { */ def withDescription(description: String): Builder[F, A] - /** Creates an instrument with the given callback, using `unit` and - * `description` (if any). + /** Creates an instrument with the given callback, using `unit` and `description` (if any). * * The callback will be called when the instrument is being observed. * @@ -71,14 +69,11 @@ object ObservableUpDownCounter { cb: ObservableMeasurement[F, A] => F[Unit] ): Resource[F, ObservableUpDownCounter] - /** Creates an asynchronous instrument based on an effect that produces a - * number of measurements. + /** Creates an asynchronous instrument based on an effect that produces a number of measurements. * - * The measurement effect will be evaluated when the instrument is being - * observed. + * The measurement effect will be evaluated when the instrument is being observed. * - * The measurement effect is expected to abide by the following - * restrictions: + * The measurement effect is expected to abide by the following restrictions: * - Short-living and (ideally) non-blocking * - Run in a finite amount of time * - Safe to call repeatedly, across multiple threads @@ -90,12 +85,11 @@ object ObservableUpDownCounter { measurements: F[Iterable[Measurement[A]]] ): Resource[F, ObservableUpDownCounter] - /** Creates an observer for this instrument to observe values from a - * [[BatchCallback]]. + /** Creates an observer for this instrument to observe values from a [[BatchCallback]]. * * @note - * The observer '''must''' be registered via [[Meter.batchCallback]]. - * Values observed outside registered callbacks are ignored. + * The observer '''must''' be registered via [[Meter.batchCallback]]. Values observed outside registered + * callbacks are ignored. */ def createObserver: F[ObservableMeasurement[F, A]] } diff --git a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/UpDownCounter.scala b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/UpDownCounter.scala index 68459bf7a..2ed39dd0c 100644 --- a/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/UpDownCounter.scala +++ b/core/metrics/src/main/scala/org/typelevel/otel4s/metrics/UpDownCounter.scala @@ -24,8 +24,7 @@ import scala.collection.immutable /** A `Counter` instrument that records values of type `A`. * - * The [[UpDownCounter]] is non-monotonic. This means the aggregated value can - * increase and decrease. + * The [[UpDownCounter]] is non-monotonic. This means the aggregated value can increase and decrease. * * @see * See [[Counter]] for monotonic alternative @@ -34,9 +33,8 @@ import scala.collection.immutable * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait UpDownCounter[F[_], A] extends UpDownCounterMacro[F, A] @@ -48,9 +46,8 @@ object UpDownCounter { * the higher-kinded type of a polymorphic effect * * @tparam A - * the type of the values to record. The type must have an instance of - * [[MeasurementValue]]. [[scala.Long]] and [[scala.Double]] are supported - * out of the box. + * the type of the values to record. The type must have an instance of [[MeasurementValue]]. [[scala.Long]] and + * [[scala.Double]] are supported out of the box. */ trait Builder[F[_], A] { @@ -74,8 +71,7 @@ object UpDownCounter { */ def withDescription(description: String): Builder[F, A] - /** Creates an [[UpDownCounter]] with the given `unit` and `description` (if - * any). + /** Creates an [[UpDownCounter]] with the given `unit` and `description` (if any). */ def create: F[UpDownCounter[F, A]] } diff --git a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/BaseMeterSuite.scala b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/BaseMeterSuite.scala index 3f60928a8..05e0a4c78 100644 --- a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/BaseMeterSuite.scala +++ b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/BaseMeterSuite.scala @@ -330,8 +330,7 @@ object BaseMeterSuite { aggregationTemporality: AggregationTemporality ) extends MetricPoints - final case class Gauge(points: Vector[PointData.NumberPoint]) - extends MetricPoints + final case class Gauge(points: Vector[PointData.NumberPoint]) extends MetricPoints final case class Histogram( points: Vector[PointData.Histogram], @@ -348,8 +347,7 @@ object BaseMeterSuite { object MetricData { private val DefaultBoundaries = BucketBoundaries( - 0.0, 5.0, 10.0, 25.0, 50.0, 75.0, 100.0, 250.0, 500.0, 750.0, 1000.0, - 2500.0, 5000.0, 7500.0, 10000.0 + 0.0, 5.0, 10.0, 25.0, 50.0, 75.0, 100.0, 250.0, 500.0, 750.0, 1000.0, 2500.0, 5000.0, 7500.0, 10000.0 ) def sum( @@ -422,12 +420,11 @@ object BaseMeterSuite { exemplarValue: Option[Double] = None ): MetricData = { val counts: Vector[Long] = - values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { - case (acc, value) => - val i = boundaries.boundaries.indexWhere(b => value <= b) - val idx = if (i == -1) boundaries.length else i + values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { case (acc, value) => + val i = boundaries.boundaries.indexWhere(b => value <= b) + val idx = if (i == -1) boundaries.length else i - acc.updated(idx, acc(idx) + 1L) + acc.updated(idx, acc(idx) + 1L) } MetricData( diff --git a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/CounterSuite.scala b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/CounterSuite.scala index 2ace9d6d2..41be65a7f 100644 --- a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/CounterSuite.scala +++ b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/CounterSuite.scala @@ -95,8 +95,7 @@ object CounterSuite { final case class Record[A](value: A, attributes: Attributes) - class InMemoryCounter(ref: Ref[IO, List[Record[Long]]]) - extends Counter[IO, Long] { + class InMemoryCounter(ref: Ref[IO, List[Record[Long]]]) extends Counter[IO, Long] { val backend: Counter.Backend[IO, Long] = new Counter.Backend[IO, Long] { diff --git a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/HistogramSuite.scala b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/HistogramSuite.scala index 16d37d235..97c3b01d8 100644 --- a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/HistogramSuite.scala +++ b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/HistogramSuite.scala @@ -110,8 +110,7 @@ object HistogramSuite { final case class Record[A](value: A, attributes: Attributes) - class InMemoryHistogram(ref: Ref[IO, List[Record[Double]]]) - extends Histogram[IO, Double] { + class InMemoryHistogram(ref: Ref[IO, List[Record[Double]]]) extends Histogram[IO, Double] { val backend: Histogram.Backend[IO, Double] = new Histogram.Backend[IO, Double] { diff --git a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/ObservableSuite.scala b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/ObservableSuite.scala index b7226757d..feb6d93fc 100644 --- a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/ObservableSuite.scala +++ b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/ObservableSuite.scala @@ -31,9 +31,7 @@ class ObservableSuite extends CatsEffectSuite { for { _ <- new InMemoryObservableInstrumentBuilder[Double] - .createObservableWithCallback(instrument => - instrument.record(2.0) *> instrument.record(3.0) - ) + .createObservableWithCallback(instrument => instrument.record(2.0) *> instrument.record(3.0)) .use { r => for { _ <- r.observations.get.assertEquals(List.empty) @@ -98,8 +96,7 @@ object ObservableSuite { }) } - class InMemoryObservableInstrumentBuilder[A] - extends ObservableGauge.Builder[IO, A] { + class InMemoryObservableInstrumentBuilder[A] extends ObservableGauge.Builder[IO, A] { type Self = ObservableGauge.Builder[IO, A] diff --git a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/UpDownCounterSuite.scala b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/UpDownCounterSuite.scala index 0076321c3..fc2bcf224 100644 --- a/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/UpDownCounterSuite.scala +++ b/core/metrics/src/test/scala/org/typelevel/otel4s/metrics/UpDownCounterSuite.scala @@ -117,8 +117,7 @@ object UpDownCounterSuite { final case class Record[A](value: A, attributes: Attributes) - class InMemoryUpDownCounter(ref: Ref[IO, List[Record[Long]]]) - extends UpDownCounter[IO, Long] { + class InMemoryUpDownCounter(ref: Ref[IO, List[Record[Long]]]) extends UpDownCounter[IO, Long] { val backend: UpDownCounter.Backend[IO, Long] = new UpDownCounter.Backend[IO, Long] { diff --git a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanBuilderMacro.scala b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanBuilderMacro.scala index 7b9b9ccf0..32c158920 100644 --- a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanBuilderMacro.scala +++ b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanBuilderMacro.scala @@ -22,9 +22,8 @@ import scala.concurrent.duration.FiniteDuration private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => - /** Adds an attribute to the newly created span. If [[SpanBuilder]] previously - * contained a mapping for the key, the old value is replaced by the - * specified value. + /** Adds an attribute to the newly created span. If [[SpanBuilder]] previously contained a mapping for the key, the + * old value is replaced by the specified value. * * @param attribute * the attribute to associate with the span @@ -32,9 +31,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => def addAttribute[A](attribute: Attribute[A]): SpanBuilder[F] = macro SpanBuilderMacro.addAttribute[A] - /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously - * contained a mapping for any of the keys, the old values are replaced by - * the specified values. + /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously contained a mapping for any of the keys, the + * old values are replaced by the specified values. * * @param attributes * the set of attributes to associate with the span @@ -42,9 +40,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => def addAttributes(attributes: Attribute[_]*): SpanBuilder[F] = macro SpanBuilderMacro.addAttributes - /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously - * contained a mapping for any of the keys, the old values are replaced by - * the specified values. + /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously contained a mapping for any of the keys, the + * old values are replaced by the specified values. * * @param attributes * the set of attributes to associate with the span @@ -56,9 +53,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Adds a link to the newly created span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -74,9 +70,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Adds a link to the newly created span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -104,8 +99,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => ): SpanBuilder[F] = macro SpanBuilderMacro.withFinalizationStrategy - /** Sets the [[SpanKind]] for the newly created span. If not called, the - * implementation will provide a default value [[SpanKind.Internal]]. + /** Sets the [[SpanKind]] for the newly created span. If not called, the implementation will provide a default value + * [[SpanKind.Internal]]. * * @param spanKind * the kind of the newly created span @@ -115,13 +110,11 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Sets an explicit start timestamp for the newly created span. * - * Use this method to specify an explicit start timestamp. If not called, the - * implementation will use the timestamp value from the method called on - * [[build]], which should be the default case. + * Use this method to specify an explicit start timestamp. If not called, the implementation will use the timestamp + * value from the method called on [[build]], which should be the default case. * * @note - * the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to a missing span. + * the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to a missing span. * * @param timestamp * the explicit start timestamp from the epoch @@ -129,8 +122,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => def withStartTimestamp(timestamp: FiniteDuration): SpanBuilder[F] = macro SpanBuilderMacro.withStartTimestamp - /** Sets the parent to use from the specified [[SpanContext]]. If not set, the - * span that is currently available in the scope will be used as parent. + /** Sets the parent to use from the specified [[SpanContext]]. If not set, the span that is currently available in the + * scope will be used as parent. * * @note * if called multiple times, only the last specified value will be used. @@ -254,8 +247,7 @@ object SpanBuilderMacro { * } * }}} * - * To optimize this madness, we can inspect the current tree and chain - * `modify` operations instead: + * To optimize this madness, we can inspect the current tree and chain `modify` operations instead: * {{{ * val builder = Tracer[F].spanBuilder("name") * if (builder.meta.isEnabled) { diff --git a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanMacro.scala b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanMacro.scala index 2e6f0d9ce..02d76b588 100644 --- a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanMacro.scala +++ b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/SpanMacro.scala @@ -23,8 +23,8 @@ import scala.concurrent.duration.FiniteDuration private[otel4s] trait SpanMacro[F[_]] { self: Span[F] => - /** Adds an attribute to the span. If the span previously contained a mapping - * for the key, the old value is replaced by the specified value. + /** Adds an attribute to the span. If the span previously contained a mapping for the key, the old value is replaced + * by the specified value. * * @param attribute * the attribute to add to the span @@ -32,8 +32,8 @@ private[otel4s] trait SpanMacro[F[_]] { def addAttribute[A](attribute: Attribute[A]): F[Unit] = macro SpanMacro.addAttribute[A] - /** Adds attributes to the span. If the span previously contained a mapping - * for any of the keys, the old values are replaced by the specified values. + /** Adds attributes to the span. If the span previously contained a mapping for any of the keys, the old values are + * replaced by the specified values. * * @param attributes * the set of attributes to add to the span @@ -41,8 +41,8 @@ private[otel4s] trait SpanMacro[F[_]] { def addAttributes(attributes: Attribute[_]*): F[Unit] = macro SpanMacro.addAttributes - /** Adds attributes to the span. If the span previously contained a mapping - * for any of the keys, the old values are replaced by the specified values. + /** Adds attributes to the span. If the span previously contained a mapping for any of the keys, the old values are + * replaced by the specified values. * * @param attributes * the set of attributes to add to the span @@ -50,8 +50,7 @@ private[otel4s] trait SpanMacro[F[_]] { def addAttributes(attributes: immutable.Iterable[Attribute[_]]): F[Unit] = macro SpanMacro.addAttributesColl - /** Adds an event to the span with the given attributes. The timestamp of the - * event will be the current time. + /** Adds an event to the span with the given attributes. The timestamp of the event will be the current time. * * @param name * the name of the event @@ -62,8 +61,7 @@ private[otel4s] trait SpanMacro[F[_]] { def addEvent(name: String, attributes: Attribute[_]*): F[Unit] = macro SpanMacro.addEvent - /** Adds an event to the span with the given attributes. The timestamp of the - * event will be the current time. + /** Adds an event to the span with the given attributes. The timestamp of the event will be the current time. * * @param name * the name of the event @@ -79,8 +77,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds an event to the span with the given attributes and timestamp. * - * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to an incorrect data. + * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to an + * incorrect data. * * @param name * the name of the event @@ -100,8 +98,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds an event to the span with the given attributes and timestamp. * - * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to an incorrect data. + * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to an + * incorrect data. * * @param name * the name of the event @@ -121,9 +119,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds a link to the span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -139,9 +136,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds a link to the span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -185,8 +181,7 @@ private[otel4s] trait SpanMacro[F[_]] { /** Sets the status to the span. * - * Only the value of the last call will be recorded, and implementations are - * free to ignore previous calls. + * Only the value of the last call will be recorded, and implementations are free to ignore previous calls. * * @param status * the [[StatusCode]] to set @@ -196,8 +191,7 @@ private[otel4s] trait SpanMacro[F[_]] { /** Sets the status to the span. * - * Only the value of the last call will be recorded, and implementations are - * free to ignore previous calls. + * Only the value of the last call will be recorded, and implementations are free to ignore previous calls. * * @param status * the [[StatusCode]] to set diff --git a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/TracerMacro.scala b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/TracerMacro.scala index 014169f6f..b154b24b9 100644 --- a/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/TracerMacro.scala +++ b/core/trace/src/main/scala-2/org/typelevel/otel4s/trace/TracerMacro.scala @@ -22,17 +22,15 @@ import scala.collection.immutable private[otel4s] trait TracerMacro[F[_]] { self: Tracer[F] => - /** Creates a new child span. The span is automatically attached to a parent - * span (based on the scope). + /** Creates a new child span. The span is automatically attached to a parent span (based on the scope). * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. * - * To attach span to a specific parent, use [[childScope]] or - * [[SpanBuilder.withParent]]. + * To attach span to a specific parent, use [[childScope]] or [[SpanBuilder.withParent]]. * * @example * attaching span to a specific parent @@ -57,17 +55,15 @@ private[otel4s] trait TracerMacro[F[_]] { def span(name: String, attributes: Attribute[_]*): SpanOps[F] = macro TracerMacro.span - /** Creates a new child span. The span is automatically attached to a parent - * span (based on the scope). + /** Creates a new child span. The span is automatically attached to a parent span (based on the scope). * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. * - * To attach span to a specific parent, use [[childScope]] or - * [[SpanBuilder.withParent]]. + * To attach span to a specific parent, use [[childScope]] or [[SpanBuilder.withParent]]. * * @example * attaching span to a specific parent @@ -95,11 +91,10 @@ private[otel4s] trait TracerMacro[F[_]] { ): SpanOps[F] = macro TracerMacro.spanColl - /** Creates a new root span. Even if a parent span is available in the scope, - * the span is created without a parent. + /** Creates a new root span. Even if a parent span is available in the scope, the span is created without a parent. * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. @@ -113,11 +108,10 @@ private[otel4s] trait TracerMacro[F[_]] { def rootSpan(name: String, attributes: Attribute[_]*): SpanOps[F] = macro TracerMacro.rootSpan - /** Creates a new root span. Even if a parent span is available in the scope, - * the span is created without a parent. + /** Creates a new root span. Even if a parent span is available in the scope, the span is created without a parent. * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. diff --git a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanBuilderMacro.scala b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanBuilderMacro.scala index 5248b8313..48d76ab4d 100644 --- a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanBuilderMacro.scala +++ b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanBuilderMacro.scala @@ -23,9 +23,8 @@ import scala.quoted.* private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => - /** Adds an attribute to the newly created span. If [[SpanBuilder]] previously - * contained a mapping for the key, the old value is replaced by the - * specified value. + /** Adds an attribute to the newly created span. If [[SpanBuilder]] previously contained a mapping for the key, the + * old value is replaced by the specified value. * * @param attribute * the attribute to associate with the span @@ -33,9 +32,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => inline def addAttribute[A](inline attribute: Attribute[A]): SpanBuilder[F] = ${ SpanBuilderMacro.addAttribute('self, 'attribute) } - /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously - * contained a mapping for any of the keys, the old values are replaced by - * the specified values. + /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously contained a mapping for any of the keys, the + * old values are replaced by the specified values. * * @param attributes * the set of attributes to associate with the span @@ -43,9 +41,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => inline def addAttributes(inline attributes: Attribute[_]*): SpanBuilder[F] = ${ SpanBuilderMacro.addAttributes('self, 'attributes) } - /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously - * contained a mapping for any of the keys, the old values are replaced by - * the specified values. + /** Adds attributes to the [[SpanBuilder]]. If the SpanBuilder previously contained a mapping for any of the keys, the + * old values are replaced by the specified values. * * @param attributes * the set of attributes to associate with the span @@ -57,9 +54,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Adds a link to the newly created span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -75,9 +71,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Adds a link to the newly created span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -105,8 +100,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => ): SpanBuilder[F] = ${ SpanBuilderMacro.withFinalizationStrategy('self, 'strategy) } - /** Sets the [[SpanKind]] for the newly created span. If not called, the - * implementation will provide a default value [[SpanKind.Internal]]. + /** Sets the [[SpanKind]] for the newly created span. If not called, the implementation will provide a default value + * [[SpanKind.Internal]]. * * @param spanKind * the kind of the newly created span @@ -116,13 +111,11 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => /** Sets an explicit start timestamp for the newly created span. * - * Use this method to specify an explicit start timestamp. If not called, the - * implementation will use the timestamp value from the method called on - * [[build]], which should be the default case. + * Use this method to specify an explicit start timestamp. If not called, the implementation will use the timestamp + * value from the method called on [[build]], which should be the default case. * * @note - * the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to a missing span. + * the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to a missing span. * * @param timestamp * the explicit start timestamp from the epoch @@ -132,8 +125,8 @@ private[otel4s] trait SpanBuilderMacro[F[_]] { self: SpanBuilder[F] => ): SpanBuilder[F] = ${ SpanBuilderMacro.withStartTimestamp('self, 'timestamp) } - /** Sets the parent to use from the specified [[SpanContext]]. If not set, the - * span that is currently available in the scope will be used as parent. + /** Sets the parent to use from the specified [[SpanContext]]. If not set, the span that is currently available in the + * scope will be used as parent. * * @note * if called multiple times, only the last specified value will be used. diff --git a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanMacro.scala b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanMacro.scala index 26d4b9cfc..0b274d0e5 100644 --- a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanMacro.scala +++ b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/SpanMacro.scala @@ -24,8 +24,8 @@ import scala.quoted.* private[otel4s] trait SpanMacro[F[_]] { self: Span[F] => - /** Adds an attribute to the span. If the span previously contained a mapping - * for the key, the old value is replaced by the specified value. + /** Adds an attribute to the span. If the span previously contained a mapping for the key, the old value is replaced + * by the specified value. * * @param attribute * the attribute to add to the span @@ -33,8 +33,8 @@ private[otel4s] trait SpanMacro[F[_]] { inline def addAttribute[A](inline attribute: Attribute[A]): F[Unit] = ${ SpanMacro.addAttribute('self, 'attribute) } - /** Adds attributes to the span. If the span previously contained a mapping - * for any of the keys, the old values are replaced by the specified values. + /** Adds attributes to the span. If the span previously contained a mapping for any of the keys, the old values are + * replaced by the specified values. * * @param attributes * the set of attributes to add to the span @@ -42,8 +42,8 @@ private[otel4s] trait SpanMacro[F[_]] { inline def addAttributes(inline attributes: Attribute[_]*): F[Unit] = ${ SpanMacro.addAttributes('self, 'attributes) } - /** Adds attributes to the span. If the span previously contained a mapping - * for any of the keys, the old values are replaced by the specified values. + /** Adds attributes to the span. If the span previously contained a mapping for any of the keys, the old values are + * replaced by the specified values. * * @param attributes * the set of attributes to add to the span @@ -53,8 +53,7 @@ private[otel4s] trait SpanMacro[F[_]] { ): F[Unit] = ${ SpanMacro.addAttributes('self, 'attributes) } - /** Adds an event to the span with the given attributes. The timestamp of the - * event will be the current time. + /** Adds an event to the span with the given attributes. The timestamp of the event will be the current time. * * @param name * the name of the event @@ -68,8 +67,7 @@ private[otel4s] trait SpanMacro[F[_]] { ): F[Unit] = ${ SpanMacro.addEvent('self, 'name, 'attributes) } - /** Adds an event to the span with the given attributes. The timestamp of the - * event will be the current time. + /** Adds an event to the span with the given attributes. The timestamp of the event will be the current time. * * @param name * the name of the event @@ -85,8 +83,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds an event to the span with the given attributes and timestamp. * - * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to an incorrect data. + * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to an + * incorrect data. * * @param name * the name of the event @@ -106,8 +104,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds an event to the span with the given attributes and timestamp. * - * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to an incorrect data. + * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to an + * incorrect data. * * @param name * the name of the event @@ -127,9 +125,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds a link to the span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -145,9 +142,8 @@ private[otel4s] trait SpanMacro[F[_]] { /** Adds a link to the span. * - * Links are used to link spans in different traces. Used (for example) in - * batching operations, where a single batch handler processes multiple - * requests from different traces or the same trace. + * Links are used to link spans in different traces. Used (for example) in batching operations, where a single batch + * handler processes multiple requests from different traces or the same trace. * * @param spanContext * the context of the linked span @@ -191,8 +187,7 @@ private[otel4s] trait SpanMacro[F[_]] { /** Sets the status to the span. * - * Only the value of the last call will be recorded, and implementations are - * free to ignore previous calls. + * Only the value of the last call will be recorded, and implementations are free to ignore previous calls. * * @param status * the [[StatusCode]] to set @@ -202,8 +197,7 @@ private[otel4s] trait SpanMacro[F[_]] { /** Sets the status to the span. * - * Only the value of the last call will be recorded, and implementations are - * free to ignore previous calls. + * Only the value of the last call will be recorded, and implementations are free to ignore previous calls. * * @param status * the [[StatusCode]] to set diff --git a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/TracerMacro.scala b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/TracerMacro.scala index ae92fa08d..d39ba1dbe 100644 --- a/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/TracerMacro.scala +++ b/core/trace/src/main/scala-3/org/typelevel/otel4s/trace/TracerMacro.scala @@ -22,17 +22,15 @@ import scala.collection.immutable private[otel4s] trait TracerMacro[F[_]] { self: Tracer[F] => - /** Creates a new child span. The span is automatically attached to a parent - * span (based on the scope). + /** Creates a new child span. The span is automatically attached to a parent span (based on the scope). * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. * - * To attach span to a specific parent, use [[childScope]] or - * [[SpanBuilder.withParent]]. + * To attach span to a specific parent, use [[childScope]] or [[SpanBuilder.withParent]]. * * @example * attaching span to a specific parent @@ -60,17 +58,15 @@ private[otel4s] trait TracerMacro[F[_]] { ): SpanOps[F] = spanBuilder(name).addAttributes(attributes).build - /** Creates a new child span. The span is automatically attached to a parent - * span (based on the scope). + /** Creates a new child span. The span is automatically attached to a parent span (based on the scope). * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. * - * To attach span to a specific parent, use [[childScope]] or - * [[SpanBuilder.withParent]]. + * To attach span to a specific parent, use [[childScope]] or [[SpanBuilder.withParent]]. * * @example * attaching span to a specific parent @@ -98,11 +94,10 @@ private[otel4s] trait TracerMacro[F[_]] { ): SpanOps[F] = spanBuilder(name).addAttributes(attributes).build - /** Creates a new root span. Even if a parent span is available in the scope, - * the span is created without a parent. + /** Creates a new root span. Even if a parent span is available in the scope, the span is created without a parent. * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. @@ -119,11 +114,10 @@ private[otel4s] trait TracerMacro[F[_]] { ): SpanOps[F] = spanBuilder(name).addAttributes(attributes).root.build - /** Creates a new root span. Even if a parent span is available in the scope, - * the span is created without a parent. + /** Creates a new root span. Even if a parent span is available in the scope, the span is created without a parent. * - * The lifecycle of the span is managed automatically. That means the span is - * ended upon the finalization of a resource. + * The lifecycle of the span is managed automatically. That means the span is ended upon the finalization of a + * resource. * * The abnormal termination (error, cancelation) is recorded by * [[SpanFinalizer.Strategy.reportAbnormal default finalization strategy]]. diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/Span.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/Span.scala index 5f19a5cb4..1d8f35f81 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/Span.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/Span.scala @@ -29,9 +29,8 @@ import scala.concurrent.duration.FiniteDuration * There are two types of span lifecycle managements: manual and auto. * * ==Manual== - * A manual span requires to be ended '''explicitly''' by invoking `end`. This - * strategy can be used when it's necessary to end a span outside of the scope - * (e.g. async callback). Make sure the span is ended properly. + * A manual span requires to be ended '''explicitly''' by invoking `end`. This strategy can be used when it's necessary + * to end a span outside of the scope (e.g. async callback). Make sure the span is ended properly. * * Leaked span: * {{{ @@ -52,9 +51,8 @@ import scala.concurrent.duration.FiniteDuration * }}} * * ==Auto== - * Unlike the manual one, the auto strategy has a fully managed lifecycle. That - * means the span is started upon resource allocation and ended upon - * finalization. + * Unlike the manual one, the auto strategy has a fully managed lifecycle. That means the span is started upon resource + * allocation and ended upon finalization. * * Automatically ended span: * {{{ @@ -75,11 +73,9 @@ trait Span[F[_]] extends SpanMacro[F] { /** Updates the name of the [[Span]]. * - * '''Note''': if used, this will override the name provided via the - * [[SpanBuilder]]. + * '''Note''': if used, this will override the name provided via the [[SpanBuilder]]. * - * '''Caution''': upon this update, any sampling behavior based on span's - * name will depend on the implementation. + * '''Caution''': upon this update, any sampling behavior based on span's name will depend on the implementation. * * @param name * the new name of the span @@ -89,8 +85,7 @@ trait Span[F[_]] extends SpanMacro[F] { /** Marks the end of [[Span]] execution. * - * Only the timing of the first end call for a given span will be recorded, - * the subsequent calls will be ignored. + * Only the timing of the first end call for a given span will be recorded, the subsequent calls will be ignored. * * The end timestamp is based on the `Clock[F].realTime`. */ @@ -99,11 +94,10 @@ trait Span[F[_]] extends SpanMacro[F] { /** Marks the end of [[Span]] execution with the specified timestamp. * - * Only the timing of the first end call for a given span will be recorded, - * the subsequent calls will be ignored. + * Only the timing of the first end call for a given span will be recorded, the subsequent calls will be ignored. * - * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to a missing span. + * '''Note''': the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to a missing + * span. * * @param timestamp * the explicit timestamp from the epoch @@ -114,8 +108,7 @@ trait Span[F[_]] extends SpanMacro[F] { /** Modify the context `F` using the transformation `f`. */ def mapK[G[_]](f: F ~> G): Span[G] = Span.fromBackend(backend.mapK(f)) - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ final def mapK[G[_]](implicit kt: KindTransformer[F, G]): Span[G] = mapK(kt.liftK) @@ -160,8 +153,7 @@ object Span { /** Modify the context `F` using the transformation `f`. */ def mapK[G[_]](f: F ~> G): Backend[G] = new Backend.MappedK(this)(f) - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ final def mapK[G[_]](implicit kt: KindTransformer[F, G]): Backend[G] = mapK(kt.liftK) @@ -169,9 +161,8 @@ object Span { object Backend { - /** Returns a non-recording backend that holds the provided [[SpanContext]] - * but all operations have no effect. The span will not be exported and all - * tracing operations are no-op, but it can be used to propagate a valid + /** Returns a non-recording backend that holds the provided [[SpanContext]] but all operations have no effect. The + * span will not be exported and all tracing operations are no-op, but it can be used to propagate a valid * [[SpanContext]] downstream. * * @param context @@ -229,8 +220,7 @@ object Span { } /** Implementation for [[Backend.mapK]]. */ - private class MappedK[F[_], G[_]](backend: Backend[F])(f: F ~> G) - extends Backend[G] { + private class MappedK[F[_], G[_]](backend: Backend[F])(f: F ~> G) extends Backend[G] { def meta: InstrumentMeta[G] = backend.meta.mapK(f) def context: SpanContext = backend.context diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanBuilder.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanBuilder.scala index 7265d4576..8086612d7 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanBuilder.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanBuilder.scala @@ -41,8 +41,7 @@ trait SpanBuilder[F[_]] extends SpanBuilderMacro[F] { */ def modifyState(f: State => State): SpanBuilder[F] - /** Indicates that the span should be the root one and the scope parent should - * be ignored. + /** Indicates that the span should be the root one and the scope parent should be ignored. */ def root: SpanBuilder[F] = modifyState(_.withParent(SpanBuilder.Parent.Root)) @@ -51,8 +50,7 @@ trait SpanBuilder[F[_]] extends SpanBuilderMacro[F] { */ def build: SpanOps[F] - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]: MonadCancelThrow](implicit F: MonadCancelThrow[F], @@ -68,8 +66,7 @@ object SpanBuilder { sealed trait Parent object Parent { - /** Use the span context that is currently available in the scope as a - * parent (if any). + /** Use the span context that is currently available in the scope as a parent (if any). */ def propagate: Parent = Propagate @@ -86,8 +83,7 @@ object SpanBuilder { private[otel4s] case object Propagate extends Parent private[otel4s] case object Root extends Parent - private[otel4s] final case class Explicit(parent: SpanContext) - extends Parent + private[otel4s] final case class Explicit(parent: SpanContext) extends Parent } /** The state of the [[SpanBuilder]]. @@ -121,8 +117,7 @@ object SpanBuilder { /** Adds the given attribute to the state. * * @note - * if the state previously contained a mapping for the key, the old value - * is replaced by the specified value + * if the state previously contained a mapping for the key, the old value is replaced by the specified value * * @param attribute * the attribute to add @@ -132,8 +127,8 @@ object SpanBuilder { /** Adds attributes to the state. * * @note - * if the state previously contained a mapping for any of the keys, the - * old values are replaced by the specified values + * if the state previously contained a mapping for any of the keys, the old values are replaced by the specified + * values * * @param attributes * the set of attributes to add @@ -170,8 +165,7 @@ object SpanBuilder { /** Sets an explicit start timestamp. * * @note - * the timestamp should be based on `Clock[F].realTime`. Using - * `Clock[F].monotonic` may lead to a missing span + * the timestamp should be based on `Clock[F].realTime`. Using `Clock[F].monotonic` may lead to a missing span * * @param timestamp * the explicit start timestamp from the epoch diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanContext.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanContext.scala index 7c49c5468..5d0510d96 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanContext.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanContext.scala @@ -21,40 +21,33 @@ import cats.Show import cats.syntax.show._ import scodec.bits.ByteVector -/** A span context contains the state that must propagate to child spans and - * across process boundaries. +/** A span context contains the state that must propagate to child spans and across process boundaries. * - * It contains the identifiers (a `trace_id` and `span_id`) associated with the - * span and a set of flags (currently only whether the context is sampled or - * not), as well as the remote flag. + * It contains the identifiers (a `trace_id` and `span_id`) associated with the span and a set of flags (currently only + * whether the context is sampled or not), as well as the remote flag. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/api/#spancontext]] */ sealed trait SpanContext { - /** Returns the trace identifier associated with this [[SpanContext]] as - * 16-byte vector. + /** Returns the trace identifier associated with this [[SpanContext]] as 16-byte vector. */ def traceId: ByteVector - /** Returns the trace identifier associated with this [[SpanContext]] as 32 - * character lowercase hex String. + /** Returns the trace identifier associated with this [[SpanContext]] as 32 character lowercase hex String. */ def traceIdHex: String - /** Returns the span identifier associated with this [[SpanContext]] as 8-byte - * vector. + /** Returns the span identifier associated with this [[SpanContext]] as 8-byte vector. */ def spanId: ByteVector - /** Returns the span identifier associated with this [[SpanContext]] as 16 - * character lowercase hex String. + /** Returns the span identifier associated with this [[SpanContext]] as 16 character lowercase hex String. */ def spanIdHex: String - /** Returns details about the trace associated with this [[SpanContext]] as an - * 8-bit field. + /** Returns details about the trace associated with this [[SpanContext]] as an 8-bit field. */ def traceFlags: TraceFlags @@ -71,8 +64,7 @@ sealed trait SpanContext { */ def isValid: Boolean - /** Returns `true` if this [[SpanContext]] was propagated from a remote - * parent. + /** Returns `true` if this [[SpanContext]] was propagated from a remote parent. */ def isRemote: Boolean @@ -149,9 +141,8 @@ object SpanContext { /** Creates a new [[SpanContext]] with the given identifiers and options. * - * If the `traceId` or the `spanId` are invalid (ie. do not conform to the - * requirements for hexadecimal ids of the appropriate lengths), both will be - * replaced with the standard "invalid" versions (i.e. all '0's). + * If the `traceId` or the `spanId` are invalid (ie. do not conform to the requirements for hexadecimal ids of the + * appropriate lengths), both will be replaced with the standard "invalid" versions (i.e. all '0's). * * @param traceId * the trace identifier of the span context @@ -223,13 +214,11 @@ object SpanContext { /** Creates a new [[SpanContext]] with the given identifiers and options. * - * If the id validation isn't skipped and the `traceId` or the `spanId` are - * invalid (ie. do not conform to the requirements for hexadecimal ids of the - * appropriate lengths), both will be replaced with the standard "invalid" + * If the id validation isn't skipped and the `traceId` or the `spanId` are invalid (ie. do not conform to the + * requirements for hexadecimal ids of the appropriate lengths), both will be replaced with the standard "invalid" * versions (i.e. all '0's). * - * '''Note''': the method is for the internal use only. It is not supposed to - * be publicly available. + * '''Note''': the method is for the internal use only. It is not supposed to be publicly available. * * @see * [[apply]] diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanKind.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanKind.scala index f0b4cdc7a..63b0be81d 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanKind.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanKind.scala @@ -20,8 +20,8 @@ package trace import cats.Hash import cats.Show -/** Type of [[Span]]. Can be used to specify additional relationships between - * spans in addition to a parent/child relationship. +/** Type of [[Span]]. Can be used to specify additional relationships between spans in addition to a parent/child + * relationship. */ sealed trait SpanKind extends Product with Serializable @@ -30,25 +30,21 @@ object SpanKind { /** Default value. Indicates that the span is used internally. */ case object Internal extends SpanKind - /** Indicates that the span covers server-side handling of an RPC or other - * remote request. + /** Indicates that the span covers server-side handling of an RPC or other remote request. */ case object Server extends SpanKind - /** Indicates that the span covers the client-side wrapper around an RPC or - * other remote request. + /** Indicates that the span covers the client-side wrapper around an RPC or other remote request. */ case object Client extends SpanKind - /** Indicates that the span describes producer sending a message to a broker. - * Unlike client and server, there is no direct critical path latency - * relationship between producer and consumer spans. + /** Indicates that the span describes producer sending a message to a broker. Unlike client and server, there is no + * direct critical path latency relationship between producer and consumer spans. */ case object Producer extends SpanKind - /** Indicates that the span describes consumer receiving a message from a - * broker. Unlike client and server, there is no direct critical path latency - * relationship between producer and consumer spans. + /** Indicates that the span describes consumer receiving a message from a broker. Unlike client and server, there is + * no direct critical path latency relationship between producer and consumer spans. */ case object Consumer extends SpanKind diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanOps.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanOps.scala index c447b1f0e..2e28a6cef 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanOps.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/SpanOps.scala @@ -24,14 +24,13 @@ import cats.~> trait SpanOps[F[_]] { - /** Creates a [[Span]]. The span requires to be ended '''explicitly''' by - * invoking `end`. + /** Creates a [[Span]]. The span requires to be ended '''explicitly''' by invoking `end`. * - * This strategy can be used when it's necessary to end a span outside of the - * scope (e.g. async callback). Make sure the span is ended properly. + * This strategy can be used when it's necessary to end a span outside of the scope (e.g. async callback). Make sure + * the span is ended properly. * - * If the start timestamp is not configured explicitly in a builder, the - * `Clock[F].realTime` is used to determine the timestamp. + * If the start timestamp is not configured explicitly in a builder, the `Clock[F].realTime` is used to determine the + * timestamp. * * Leaked span: * {{{ @@ -56,15 +55,14 @@ trait SpanOps[F[_]] { */ def startUnmanaged: F[Span[F]] - /** Creates a [[Span]] and a [[cats.effect.kernel.Resource Resource]] for - * using it. Unlike [[startUnmanaged]], the lifecycle of the span is fully - * managed. + /** Creates a [[Span]] and a [[cats.effect.kernel.Resource Resource]] for using it. Unlike [[startUnmanaged]], the + * lifecycle of the span is fully managed. * - * The finalization strategy is determined by [[SpanFinalizer.Strategy]]. By - * default, the abnormal termination (error, cancelation) is recorded. + * The finalization strategy is determined by [[SpanFinalizer.Strategy]]. By default, the abnormal termination + * (error, cancelation) is recorded. * - * If the start timestamp is not configured explicitly in a builder, the - * `Clock[F].realTime` is used to determine the timestamp. + * If the start timestamp is not configured explicitly in a builder, the `Clock[F].realTime` is used to determine the + * timestamp. * * `Clock[F].realTime` is always used as the end timestamp. * @@ -89,15 +87,14 @@ trait SpanOps[F[_]] { */ def resource: Resource[F, SpanOps.Res[F]] - /** Creates and uses a [[Span]]. Unlike [[startUnmanaged]], the lifecycle of - * the span is fully managed. The span is started and passed to `f` to - * produce the effect, and ended when the effect completes. + /** Creates and uses a [[Span]]. Unlike [[startUnmanaged]], the lifecycle of the span is fully managed. The span is + * started and passed to `f` to produce the effect, and ended when the effect completes. * - * The finalization strategy is determined by [[SpanFinalizer.Strategy]]. By - * default, the abnormal termination (error, cancelation) is recorded. + * The finalization strategy is determined by [[SpanFinalizer.Strategy]]. By default, the abnormal termination + * (error, cancelation) is recorded. * - * If the start timestamp is not configured explicitly in a builder, the - * `Clock[F].realTime` is used to determine the timestamp. + * If the start timestamp is not configured explicitly in a builder, the `Clock[F].realTime` is used to determine the + * timestamp. * * `Clock[F].realTime` is always used as the end timestamp. * @@ -128,8 +125,7 @@ trait SpanOps[F[_]] { */ def use_ : F[Unit] - /** Starts a span, runs `fa` and ends the span once `fa` terminates, fails or - * gets interrupted. + /** Starts a span, runs `fa` and ends the span once `fa` terminates, fails or gets interrupted. * * A shortcut for: * {{{ @@ -143,8 +139,7 @@ trait SpanOps[F[_]] { */ final def surround[A](fa: F[A]): F[A] = use(_ => fa) - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]: MonadCancelThrow](implicit F: MonadCancelThrow[F], @@ -155,34 +150,29 @@ trait SpanOps[F[_]] { object SpanOps { - /** The span and associated natural transformation [[`trace`]] provided and - * managed by a call to [[SpanOps.resource]]. In order to trace something in - * the span, it must be applied to [[`trace`]]. + /** The span and associated natural transformation [[`trace`]] provided and managed by a call to [[SpanOps.resource]]. + * In order to trace something in the span, it must be applied to [[`trace`]]. */ sealed trait Res[F[_]] { /** The managed span. */ def span: Span[F] - /** A natural transformation that traces everything applied to it in the - * span. Note: anything not applied to this + /** A natural transformation that traces everything applied to it in the span. Note: anything not applied to this * [[cats.arrow.FunctionK FunctionK]] will not be traced. */ def trace: F ~> F - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]](implicit kt: KindTransformer[F, G]): Res[G] = Res(span.mapK[G], kt.liftFunctionK(trace)) } object Res { - private[this] final case class Impl[F[_]](span: Span[F], trace: F ~> F) - extends Res[F] + private[this] final case class Impl[F[_]](span: Span[F], trace: F ~> F) extends Res[F] - /** Creates a [[Res]] from a managed span and a natural transformation for - * tracing operations in the span. + /** Creates a [[Res]] from a managed span and a natural transformation for tracing operations in the span. */ def apply[F[_]](span: Span[F], trace: F ~> F): Res[F] = Impl(span, trace) diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/StatusCode.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/StatusCode.scala index 619f7a9b4..335e43118 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/StatusCode.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/StatusCode.scala @@ -28,8 +28,7 @@ object StatusCode { /** The default status. */ case object Unset extends StatusCode - /** The operation has been validated by an Application developers or Operator - * to have completed successfully. + /** The operation has been validated by an Application developers or Operator to have completed successfully. */ case object Ok extends StatusCode diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceFlags.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceFlags.scala index 7766b10bb..e13831360 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceFlags.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceFlags.scala @@ -22,8 +22,7 @@ import scodec.bits.ByteVector /** A valid trace flags is a byte or 2 character lowercase hex (base16) String. * - * These options are propagated to all child spans. These determine features - * such as whether a Span should be traced. + * These options are propagated to all child spans. These determine features such as whether a Span should be traced. */ sealed trait TraceFlags { @@ -83,8 +82,7 @@ object TraceFlags { def toByte: Byte = byte def toHex: String = ByteVector.fromByte(byte).toHex - /** If set, the least significant bit denotes the caller may have recorded - * trace data. + /** If set, the least significant bit denotes the caller may have recorded trace data. */ def isSampled: Boolean = (byte & TraceFlags.SampledMask) == TraceFlags.SampledMask diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceScope.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceScope.scala index 3d2f61506..5d367caa7 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceScope.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceScope.scala @@ -24,8 +24,7 @@ import org.typelevel.otel4s.context.Contextual * * The implementation uses [[Local]] to propagate [[Ctx]] within the fibers. * - * The [[Ctx]] is a type-safe key-value storage. It may carry [[SpanContext]], - * baggage attributes, and so on. + * The [[Ctx]] is a type-safe key-value storage. It may carry [[SpanContext]], baggage attributes, and so on. * * In terms of the span propagation, there can be 3 scenarios: * - the [[SpanContext]] is missing in the context @@ -41,16 +40,14 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { */ def current: F[Option[SpanContext]] - /** Creates a new scope using the given `spanContext` context if the - * requirement are met. + /** Creates a new scope using the given `spanContext` context if the requirement are met. * * ==The propagation logic== * - * The propagation is based on the presence and the validity of the - * [[SpanContext]]. + * The propagation is based on the presence and the validity of the [[SpanContext]]. * - * All context values except for the [[SpanContext]] remains intact. To - * demonstrate that values remain intact, the context has some baggage data. + * All context values except for the [[SpanContext]] remains intact. To demonstrate that values remain intact, the + * context has some baggage data. * * ===The [[SpanContext]] is missing=== * @@ -71,8 +68,7 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { * * ===The [[SpanContext]] is valid=== * - * We override the existing span context with the given one. The baggage data - * remains. + * We override the existing span context with the given one. The baggage data remains. * * {{{ * ┌──────────────────────────────────────────────┐ ┌──────────────────────────────────────────────┐ @@ -89,8 +85,7 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { * * ===The [[SpanContext]] is invalid=== * - * The propagation logic is no-op. We keep the context as is. The baggage - * data remains. + * The propagation logic is no-op. We keep the context as is. The baggage data remains. * * {{{ * ┌──────────────────────────────────────────────┐ ┌──────────────────────────────────────────────┐ @@ -110,17 +105,14 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { */ def childScope(spanContext: SpanContext): F[F ~> F] - /** Creates a root scope. The difference with the [[childScope]] is that we - * override the whole [[Ctx]], rather then only a [[SpanContext]] within the - * context. + /** Creates a root scope. The difference with the [[childScope]] is that we override the whole [[Ctx]], rather then + * only a [[SpanContext]] within the context. * * ==The propagation logic== * - * The propagation is based on the presence and the validity of the - * [[SpanContext]]. + * The propagation is based on the presence and the validity of the [[SpanContext]]. * - * To demonstrate that the whole context may be replaced, the context has - * some baggage data. + * To demonstrate that the whole context may be replaced, the context has some baggage data. * * ===The [[SpanContext]] is missing=== * @@ -158,8 +150,7 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { * * ===The [[SpanContext]] is invalid=== * - * The current propagation strategy is no-op, so we keep the context as is. - * The baggage data remains. + * The current propagation strategy is no-op, so we keep the context as is. The baggage data remains. * * {{{ * ┌──────────────────────────────────────────────┐ ┌──────────────────────────────────────────────┐ @@ -178,23 +169,21 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { /** Creates a no-op scope. * - * No-op scope means the tracing operations are no-op and the spans created - * within this scope will not be exported anywhere. + * No-op scope means the tracing operations are no-op and the spans created within this scope will not be exported + * anywhere. * - * We use [[SpanContext.invalid]] as a mark that the propagation logic is - * no-op. + * We use [[SpanContext.invalid]] as a mark that the propagation logic is no-op. * * A shortcut for `childScope(SpanContext.invalid)`. * * ==The propagation logic== * - * All context values except for the [[SpanContext]] remains intact. To - * demonstrate that values remain intact, the context has some baggage data. + * All context values except for the [[SpanContext]] remains intact. To demonstrate that values remain intact, the + * context has some baggage data. * * ===The [[SpanContext]] is missing=== * - * The scope is already root, so we keep the context as is. The baggage data - * remains. + * The scope is already root, so we keep the context as is. The baggage data remains. * * {{{ * ┌───────────────────────┐ ┌──────────────────────────────────────────────┐ @@ -211,8 +200,7 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { * * ===The [[SpanContext]] is valid=== * - * There is a valid span, we forcefully use [[SpanContext.invalid]]. The - * baggage data remains. + * There is a valid span, we forcefully use [[SpanContext.invalid]]. The baggage data remains. * * {{{ * ┌──────────────────────────────────────────────┐ ┌──────────────────────────────────────────────┐ @@ -229,8 +217,7 @@ private[otel4s] sealed trait TraceScope[F[_], Ctx] { * * ===The [[SpanContext]] is invalid=== * - * The current propagation strategy is already no-op, so we keep the context - * as is. The baggage data remains. + * The current propagation strategy is already no-op, so we keep the context as is. The baggage data remains. * * {{{ * ┌──────────────────────────────────────────────┐ ┌──────────────────────────────────────────────┐ diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceState.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceState.scala index e3c2f9709..a54ac5066 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceState.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TraceState.scala @@ -22,18 +22,15 @@ import cats.kernel.Hash import scala.collection.immutable.ListMap import scala.collection.immutable.SeqMap -/** An '''immutable''' representation of the key-value pairs defined by the W3C - * Trace Context specification. +/** An '''immutable''' representation of the key-value pairs defined by the W3C Trace Context specification. * - * Trace state allows different vendors propagate additional information and - * interoperate with their legacy Id formats. + * Trace state allows different vendors propagate additional information and interoperate with their legacy Id formats. * - * - Key is opaque string up to 256 characters printable. It MUST begin with - * a lowercase letter, and can only contain lowercase letters a-z, digits - * 0-9, underscores _, dashes -, asterisks *, and forward slashes /. + * - Key is opaque string up to 256 characters printable. It MUST begin with a lowercase letter, and can only contain + * lowercase letters a-z, digits 0-9, underscores _, dashes -, asterisks *, and forward slashes /. * - * - Value is opaque string up to 256 characters printable ASCII RFC0020 - * characters (i.e., the range 0x20 to 0x7E) except comma , and =. + * - Value is opaque string up to 256 characters printable ASCII RFC0020 characters (i.e., the range 0x20 to 0x7E) + * except comma , and =. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/api/#tracestate]] @@ -42,31 +39,26 @@ import scala.collection.immutable.SeqMap */ sealed trait TraceState { - /** Returns the value to which the specified key is mapped, or `None` if this - * map contains no mapping for the key. + /** Returns the value to which the specified key is mapped, or `None` if this map contains no mapping for the key. * * @param key * with which the specified value is to be associated */ def get(key: String): Option[String] - /** Adds or updates the entry that has the given `key` if it is present. If - * either the key or the value is invalid, the entry will not be added. + /** Adds or updates the entry that has the given `key` if it is present. If either the key or the value is invalid, + * the entry will not be added. * * @param key - * the key for the entry to be added. Key is an opaque string up to 256 - * characters printable. It MUST begin with a lowercase letter, and can - * only contain lowercase letters a-z, digits 0-9, underscores _, dashes -, - * asterisks *, and forward slashes /. For multi-tenant vendor scenarios, - * an at sign (@) can be used to prefix the vendor name. The tenant id - * (before the '@') is limited to 240 characters and the vendor id is - * limited to 13 characters. If in the multi-tenant vendor format, then the - * first character may additionally be numeric. + * the key for the entry to be added. Key is an opaque string up to 256 characters printable. It MUST begin with a + * lowercase letter, and can only contain lowercase letters a-z, digits 0-9, underscores _, dashes -, asterisks *, + * and forward slashes /. For multi-tenant vendor scenarios, an at sign (@) can be used to prefix the vendor name. + * The tenant id (before the '@') is limited to 240 characters and the vendor id is limited to 13 characters. If in + * the multi-tenant vendor format, then the first character may additionally be numeric. * * @param value - * the value for the entry to be added. Value is opaque string up to 256 - * characters printable ASCII RFC0020 characters (i.e., the range 0x20 to - * 0x7E) except comma , and =. + * the value for the entry to be added. Value is opaque string up to 256 characters printable ASCII RFC0020 + * characters (i.e., the range 0x20 to 0x7E) except comma , and =. * * @return * a new instance of [[TraceState]] with added entry @@ -126,9 +118,8 @@ object TraceState { /** Creates [[TraceState]] from the given map. * - * '''Important''': the map entries will not be validated. Use this method - * when you 100% sure the entries are valid. For example, when you wrap - * OpenTelemetry Java trace state. + * '''Important''': the map entries will not be validated. Use this method when you 100% sure the entries are valid. + * For example, when you wrap OpenTelemetry Java trace state. */ private[otel4s] def fromVectorUnsafe( entries: Vector[(String, String)] @@ -172,14 +163,11 @@ object TraceState { private final val TenantIdMaxSize = 240 private final val VendorIdSize = 13 - /** Key is an opaque string up to 256 characters printable. It MUST begin - * with a lowercase letter, and can only contain lowercase letters a-z, - * digits 0-9, underscores _, dashes -, asterisks *, and forward slashes /. - * For multi-tenant vendor scenarios, an at sign (@) can be used to prefix - * the vendor name. The tenant id (before the '@') is limited to 240 - * characters and the vendor id is limited to 13 characters. If in the - * multi-tenant vendor format, then the first character may additionally be - * numeric. + /** Key is an opaque string up to 256 characters printable. It MUST begin with a lowercase letter, and can only + * contain lowercase letters a-z, digits 0-9, underscores _, dashes -, asterisks *, and forward slashes /. For + * multi-tenant vendor scenarios, an at sign (@) can be used to prefix the vendor name. The tenant id (before the + * '@') is limited to 240 characters and the vendor id is limited to 13 characters. If in the multi-tenant vendor + * format, then the first character may additionally be numeric. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/api/#tracestate]] @@ -242,8 +230,8 @@ object TraceState { char == '*' || char == '/' - /** Value is opaque string up to 256 characters printable ASCII RFC0020 - * characters (i.e., the range 0x20 to 0x7E) except comma , and =. + /** Value is opaque string up to 256 characters printable ASCII RFC0020 characters (i.e., the range 0x20 to 0x7E) + * except comma , and =. */ @inline def isValueValid(value: String): Boolean = { val length = value.length diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/Tracer.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/Tracer.scala index d9bd0672c..9468d69b2 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/Tracer.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/Tracer.scala @@ -42,41 +42,37 @@ tracerProvider """) trait Tracer[F[_]] extends TracerMacro[F] { - /** The instrument's metadata. Indicates whether instrumentation is enabled or - * not. + /** The instrument's metadata. Indicates whether instrumentation is enabled or not. */ def meta: InstrumentMeta[F] - /** Returns the context of the current span when a span that is not no-op - * exists in the local scope. + /** Returns the context of the current span when a span that is not no-op exists in the local scope. */ def currentSpanContext: F[Option[SpanContext]] /** @return - * the current span if one exists in the local scope, or a no-op span - * otherwise + * the current span if one exists in the local scope, or a no-op span otherwise */ def currentSpanOrNoop: F[Span[F]] /** @return - * the current span if one exists in the local scope (even if it's a no-op - * span), or raises an error in `F` otherwise + * the current span if one exists in the local scope (even if it's a no-op span), or raises an error in `F` + * otherwise * * @throws java.lang.IllegalStateException * when called while not inside a span, indicating programmer error */ def currentSpanOrThrow: F[Span[F]] - /** Creates a new [[SpanBuilder]]. The builder can be used to make a fully - * customized [[Span]]. + /** Creates a new [[SpanBuilder]]. The builder can be used to make a fully customized [[Span]]. * * @param name * the name of the span */ def spanBuilder(name: String): SpanBuilder[F] - /** Creates a new tracing scope with a custom parent. A newly created non-root - * span will be a child of the given `parent`. + /** Creates a new tracing scope with a custom parent. A newly created non-root span will be a child of the given + * `parent`. * * @example * {{{ @@ -93,8 +89,8 @@ trait Tracer[F[_]] extends TracerMacro[F] { */ def childScope[A](parent: SpanContext)(fa: F[A]): F[A] - /** Creates a new tracing scope if the given `parent` is defined. A newly - * created non-root span will be a child of the given `parent`. + /** Creates a new tracing scope if the given `parent` is defined. A newly created non-root span will be a child of the + * given `parent`. * * @see * [[childScope]] @@ -110,16 +106,14 @@ trait Tracer[F[_]] extends TracerMacro[F] { fa } - /** Creates a new tracing scope if a parent can be extracted from the given - * `carrier`. A newly created non-root span will be a child of the extracted - * parent. + /** Creates a new tracing scope if a parent can be extracted from the given `carrier`. A newly created non-root span + * will be a child of the extracted parent. * - * If the context cannot be extracted from the `carrier`, the given effect - * `fa` will be executed within the '''root''' span. + * If the context cannot be extracted from the `carrier`, the given effect `fa` will be executed within the + * '''root''' span. * - * To make the propagation and extraction work, you need to configure the - * OpenTelemetry SDK. For example, you can use `OTEL_PROPAGATORS` environment - * variable. See the official + * To make the propagation and extraction work, you need to configure the OpenTelemetry SDK. For example, you can use + * `OTEL_PROPAGATORS` environment variable. See the official * [[https://opentelemetry.io/docs/reference/specification/sdk-environment-variables/#general-sdk-configuration SDK configuration guide]]. * * ==Examples== @@ -151,11 +145,10 @@ trait Tracer[F[_]] extends TracerMacro[F] { */ def joinOrRoot[A, C: TextMapGetter](carrier: C)(fa: F[A]): F[A] - /** Creates a new root tracing scope. The parent span will not be available - * inside. Thus, a span created inside of the scope will be a root one. + /** Creates a new root tracing scope. The parent span will not be available inside. Thus, a span created inside of the + * scope will be a root one. * - * Can be useful, when an effect needs to be executed in the background and - * the parent tracing info is not needed. + * Can be useful, when an effect needs to be executed in the background and the parent tracing info is not needed. * * @example * the parent is not propagated: @@ -173,8 +166,7 @@ trait Tracer[F[_]] extends TracerMacro[F] { */ def rootScope[A](fa: F[A]): F[A] - /** Creates a no-op tracing scope. The tracing operations inside of the scope - * are no-op. + /** Creates a no-op tracing scope. The tracing operations inside of the scope are no-op. * * @example * the parent is not propagated: @@ -199,15 +191,13 @@ trait Tracer[F[_]] extends TracerMacro[F] { * @tparam C * the type of the carrier * @return - * a copy of the immutable carrier with this tracer's context appended to - * it + * a copy of the immutable carrier with this tracer's context appended to it * @see * [[org.typelevel.otel4s.context.propagation.TextMapPropagator.inject TextMapPropagator#inject]] */ def propagate[C: TextMapUpdater](carrier: C): F[C] - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]: MonadCancelThrow](implicit F: MonadCancelThrow[F], diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerBuilder.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerBuilder.scala index 213229cdd..414b5f870 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerBuilder.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerBuilder.scala @@ -41,8 +41,7 @@ trait TracerBuilder[F[_]] { */ def get: F[Tracer[F]] - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]: MonadCancelThrow](implicit F: MonadCancelThrow[F], diff --git a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerProvider.scala b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerProvider.scala index 64062ed6b..f9e219bcb 100644 --- a/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerProvider.scala +++ b/core/trace/src/main/scala/org/typelevel/otel4s/trace/TracerProvider.scala @@ -34,8 +34,8 @@ trait TracerProvider[F[_]] { * }}} * * @param name - * the name of the instrumentation scope, such as the instrumentation - * library, package, or fully qualified class name + * the name of the instrumentation scope, such as the instrumentation library, package, or fully qualified class + * name */ def get(name: String): F[Tracer[F]] = tracer(name).get @@ -53,13 +53,12 @@ trait TracerProvider[F[_]] { * }}} * * @param name - * the name of the instrumentation scope, such as the instrumentation - * library, package, or fully qualified class name + * the name of the instrumentation scope, such as the instrumentation library, package, or fully qualified class + * name */ def tracer(name: String): TracerBuilder[F] - /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to - * `G`. + /** Modify the context `F` using an implicit [[KindTransformer]] from `F` to `G`. */ def mapK[G[_]: MonadCancelThrow](implicit F: MonadCancelThrow[F], diff --git a/core/trace/src/test/scala/org/typelevel/otel4s/trace/TraceStateSuite.scala b/core/trace/src/test/scala/org/typelevel/otel4s/trace/TraceStateSuite.scala index c025be567..2c48863be 100644 --- a/core/trace/src/test/scala/org/typelevel/otel4s/trace/TraceStateSuite.scala +++ b/core/trace/src/test/scala/org/typelevel/otel4s/trace/TraceStateSuite.scala @@ -48,8 +48,8 @@ class TraceStateSuite extends DisciplineSuite { rest <- Gen.stringOfN(StrMaxSize - 1, keyAllowedChars) } yield first +: rest - /** Value is opaque string up to 256 characters printable ASCII RFC0020 - * characters (i.e., the range 0x20 to 0x7E) except comma , and =. + /** Value is opaque string up to 256 characters printable ASCII RFC0020 characters (i.e., the range 0x20 to 0x7E) + * except comma , and =. */ private val valueGen: Gen[String] = { val comma = ','.toInt @@ -71,9 +71,7 @@ class TraceStateSuite extends DisciplineSuite { Arbitrary( for { entries <- Gen.listOfN(5, keyValueGen) - } yield entries.foldLeft(TraceState.empty)((b, v) => - b.updated(v._1, v._2) - ) + } yield entries.foldLeft(TraceState.empty)((b, v) => b.updated(v._1, v._2)) ) private implicit val traceStateCogen: Cogen[TraceState] = @@ -116,8 +114,8 @@ class TraceStateSuite extends DisciplineSuite { test("ignore 'put' once the limit of entries is reached") { Prop.forAll(Gen.listOfN(50, keyValueGen)) { entries => - val state = entries.foldLeft(TraceState.empty) { - case (builder, (key, value)) => builder.updated(key, value) + val state = entries.foldLeft(TraceState.empty) { case (builder, (key, value)) => + builder.updated(key, value) } assertEquals(state.asMap, entries.take(MaxEntries).toMap) @@ -197,8 +195,8 @@ class TraceStateSuite extends DisciplineSuite { test("Show[TraceState]") { Prop.forAll(Gen.listOfN(5, keyValueGen)) { entries => - val state = entries.foldLeft(TraceState.empty) { - case (builder, (key, value)) => builder.updated(key, value) + val state = entries.foldLeft(TraceState.empty) { case (builder, (key, value)) => + builder.updated(key, value) } val entriesString = entries.reverse diff --git a/examples/src/main/scala/KleisliExample.scala b/examples/src/main/scala/KleisliExample.scala index b94cda5e7..58e8c0c08 100644 --- a/examples/src/main/scala/KleisliExample.scala +++ b/examples/src/main/scala/KleisliExample.scala @@ -29,8 +29,7 @@ object KleisliExample extends IOApp.Simple { def work[F[_]: Async: Tracer]: F[Unit] = Tracer[F].span("work").surround(Async[F].delay(println("I'm working"))) - private def tracerResource[F[_]: Async: LocalContext] - : Resource[F, Tracer[F]] = + private def tracerResource[F[_]: Async: LocalContext]: Resource[F, Tracer[F]] = Resource .eval(Async[F].delay(GlobalOpenTelemetry.get)) .map(OtelJava.local[F]) diff --git a/examples/src/main/scala/PekkoHttpExample.scala b/examples/src/main/scala/PekkoHttpExample.scala index 277239db8..400965f8c 100644 --- a/examples/src/main/scala/PekkoHttpExample.scala +++ b/examples/src/main/scala/PekkoHttpExample.scala @@ -45,8 +45,7 @@ import org.typelevel.otel4s.trace.Tracer import scala.concurrent.Future import scala.concurrent.duration._ -/** This example relies on the OpenTelemetry Java agent. To make it work, add - * the following settings to your build: +/** This example relies on the OpenTelemetry Java agent. To make it work, add the following settings to your build: * * add `sbt-javaagent` dependency to the `plugins.sbt`: * @@ -81,25 +80,22 @@ object PekkoHttpExample extends IOApp.Simple { implicit val local: Local[IO, Context] = localForIOLocal val otelJava: OtelJava[IO] = OtelJava.local(GlobalOpenTelemetry.get()) - otelJava.tracerProvider.get("com.example").flatMap { - implicit tracer: Tracer[IO] => - createSystem.use { implicit actorSystem: ActorSystem => - def bind: Future[Http.ServerBinding] = - Http().newServerAt("127.0.0.1", 9000).bindFlow(routes) + otelJava.tracerProvider.get("com.example").flatMap { implicit tracer: Tracer[IO] => + createSystem.use { implicit actorSystem: ActorSystem => + def bind: Future[Http.ServerBinding] = + Http().newServerAt("127.0.0.1", 9000).bindFlow(routes) - Resource - .make(IO.fromFuture(IO.delay(bind))) { b => - IO.fromFuture(IO.delay(b.unbind())).void - } - .use(_ => IO.never) - } + Resource + .make(IO.fromFuture(IO.delay(bind))) { b => + IO.fromFuture(IO.delay(b.unbind())).void + } + .use(_ => IO.never) + } } } private def createSystem: Resource[IO, ActorSystem] = - Resource.make(IO.delay(ActorSystem()))(system => - IO.fromFuture(IO.delay(system.terminate())).void - ) + Resource.make(IO.delay(ActorSystem()))(system => IO.fromFuture(IO.delay(system.terminate())).void) private def routes(implicit T: Tracer[IO], diff --git a/examples/src/main/scala/SdkTracingExample.scala b/examples/src/main/scala/SdkTracingExample.scala index b03e3095a..2c2ffc62a 100644 --- a/examples/src/main/scala/SdkTracingExample.scala +++ b/examples/src/main/scala/SdkTracingExample.scala @@ -25,8 +25,7 @@ import org.typelevel.otel4s.trace.Tracer import scala.concurrent.duration._ -/** This example relies on the otel4s tracing SDK. The SDK dependency is - * available for all platforms: JVM, Native, JS. +/** This example relies on the otel4s tracing SDK. The SDK dependency is available for all platforms: JVM, Native, JS. * * Update definition of a project in the `build.sbt`: * diff --git a/examples/src/main/scala/TraceExample.scala b/examples/src/main/scala/TraceExample.scala index e3f70bfe1..c58e0867b 100644 --- a/examples/src/main/scala/TraceExample.scala +++ b/examples/src/main/scala/TraceExample.scala @@ -37,8 +37,7 @@ trait InstitutionServiceClient[F[_]] { def getUserIds(institutionId: String): F[List[String]] } -/** An interface to compose the getUserIds and readUser methods to get all Users - * from a single institution. +/** An interface to compose the getUserIds and readUser methods to get all Users from a single institution. */ trait UsersAlg[F[_]] { def getAllUsersForInstitution(institutionId: String): F[List[User]] @@ -46,11 +45,10 @@ trait UsersAlg[F[_]] { /** User Database Mock * - * This database implementation returns a single user out while waiting 30 - * milliseconds to simulate some time passing. The Tracer[F].span is used to - * span over the simulated database call. Note that `span.addAttribute` is used - * inside of the `.use` to add another attribute to the span with a value that - * we only know at the time of running the database read. + * This database implementation returns a single user out while waiting 30 milliseconds to simulate some time passing. + * The Tracer[F].span is used to span over the simulated database call. Note that `span.addAttribute` is used inside of + * the `.use` to add another attribute to the span with a value that we only know at the time of running the database + * read. */ object UserDatabase { def mockDBQuery[F[_]: Temporal]: F[User] = @@ -58,21 +56,19 @@ object UserDatabase { def apply[F[_]: Tracer: Temporal]: UserDatabase[F] = new UserDatabase[F] { def readUser(userId: String): F[User] = - Tracer[F].span("Read User from DB", Attribute("userId", userId)).use { - span => - mockDBQuery[F].flatTap { user => - span - .addAttribute(Attribute("User", user.name)) - } + Tracer[F].span("Read User from DB", Attribute("userId", userId)).use { span => + mockDBQuery[F].flatTap { user => + span + .addAttribute(Attribute("User", user.name)) + } } } } /** Institution Service Client (Mock Http) * - * This client implementation returns a list of ids out while waiting 110 - * milliseconds to simulate some time passing. The Tracer[F].span is used to - * span over the http client call. + * This client implementation returns a list of ids out while waiting 110 milliseconds to simulate some time passing. + * The Tracer[F].span is used to span over the http client call. */ object InstitutionServiceClient { @@ -96,11 +92,10 @@ object InstitutionServiceClient { /** UserIds Algebra * - * This implementation composes our two methods from the separate traits into a - * method that gives us the list of users for an institution. Note that in this - * we will have a list of the same user repeated because of how the mocking - * above works. The end result of this is we have a span named "Get users for - * institution" that has 3 children spans (one for each id in getUserIds). + * This implementation composes our two methods from the separate traits into a method that gives us the list of users + * for an institution. Note that in this we will have a list of the same user repeated because of how the mocking above + * works. The end result of this is we have a span named "Get users for institution" that has 3 children spans (one for + * each id in getUserIds). */ object UserIdsAlg { def apply[F[_]: Tracer: Temporal]( @@ -120,36 +115,34 @@ object TraceExample extends IOApp.Simple { /** Run Method * - * This run methods creates a span over the resource taking 50 milliseconds - * to acquire and then 100 to shutdown, but in the middle are the child spans - * from our UserIdsAlg. + * This run methods creates a span over the resource taking 50 milliseconds to acquire and then 100 to shutdown, but + * in the middle are the child spans from our UserIdsAlg. */ def run: IO[Unit] = OtelJava .autoConfigured[IO]() .evalMap { (otel4s: Otel4s[IO]) => - otel4s.tracerProvider.tracer("TraceExample").get.flatMap { - implicit tracer: Tracer[IO] => - val userIdAlg = UserIdsAlg.apply[IO]( - InstitutionServiceClient.apply[IO], - UserDatabase.apply[IO] - ) - tracer - .span("Start up") - .use { span => - for { - _ <- tracer.span("acquire").surround(IO.sleep(50.millis)) - _ <- span.addEvent("event") - _ <- tracer.span("use").surround { - userIdAlg - .getAllUsersForInstitution( - "9902181e-1d8d-4e00-913d-51532b493f1b" - ) - .flatMap(IO.println) - } - _ <- tracer.span("release").surround(IO.sleep(100.millis)) - } yield () - } + otel4s.tracerProvider.tracer("TraceExample").get.flatMap { implicit tracer: Tracer[IO] => + val userIdAlg = UserIdsAlg.apply[IO]( + InstitutionServiceClient.apply[IO], + UserDatabase.apply[IO] + ) + tracer + .span("Start up") + .use { span => + for { + _ <- tracer.span("acquire").surround(IO.sleep(50.millis)) + _ <- span.addEvent("event") + _ <- tracer.span("use").surround { + userIdAlg + .getAllUsersForInstitution( + "9902181e-1d8d-4e00-913d-51532b493f1b" + ) + .flatMap(IO.println) + } + _ <- tracer.span("release").surround(IO.sleep(100.millis)) + } yield () + } } } .use_ diff --git a/examples/src/main/scala/TracingExample.scala b/examples/src/main/scala/TracingExample.scala index 59ad42ae8..83736a165 100644 --- a/examples/src/main/scala/TracingExample.scala +++ b/examples/src/main/scala/TracingExample.scala @@ -62,30 +62,29 @@ object TracingExample extends IOApp.Simple { OtelJava .autoConfigured[IO]() .evalMap { (otel4s: Otel4s[IO]) => - otel4s.tracerProvider.get("example").flatMap { - implicit tracer: Tracer[IO] => - tracer - .span("resource") - .resource - .use { case SpanOps.Res(span, trace) => - trace { - for { - _ <- tracer.span("acquire").surround(IO.sleep(50.millis)) - _ <- tracer.span("use").surround { - Work[IO].request( - Map( - "X-B3-TraceId" -> "80f198ee56343ba864fe8b2a57d3eff7", - "X-B3-ParentSpanId" -> "05e3ac9a4f6e3b90", - "X-B3-SpanId" -> "e457b5a2e4d86bd1", - "X-B3-Sampled" -> "1" - ) + otel4s.tracerProvider.get("example").flatMap { implicit tracer: Tracer[IO] => + tracer + .span("resource") + .resource + .use { case SpanOps.Res(span, trace) => + trace { + for { + _ <- tracer.span("acquire").surround(IO.sleep(50.millis)) + _ <- tracer.span("use").surround { + Work[IO].request( + Map( + "X-B3-TraceId" -> "80f198ee56343ba864fe8b2a57d3eff7", + "X-B3-ParentSpanId" -> "05e3ac9a4f6e3b90", + "X-B3-SpanId" -> "e457b5a2e4d86bd1", + "X-B3-Sampled" -> "1" ) - } - _ <- span.addEvent("event") - _ <- tracer.span("release").surround(IO.sleep(100.millis)) - } yield () - } + ) + } + _ <- span.addEvent("event") + _ <- tracer.span("release").surround(IO.sleep(100.millis)) + } yield () } + } } } .use_ diff --git a/oteljava/all/src/main/scala/org/typelevel/otel4s/oteljava/OtelJava.scala b/oteljava/all/src/main/scala/org/typelevel/otel4s/oteljava/OtelJava.scala index 2d617e828..d9066ba2c 100644 --- a/oteljava/all/src/main/scala/org/typelevel/otel4s/oteljava/OtelJava.scala +++ b/oteljava/all/src/main/scala/org/typelevel/otel4s/oteljava/OtelJava.scala @@ -24,12 +24,8 @@ import cats.syntax.all._ import io.opentelemetry.api.{OpenTelemetry => JOpenTelemetry} import io.opentelemetry.api.GlobalOpenTelemetry import io.opentelemetry.sdk.{OpenTelemetrySdk => JOpenTelemetrySdk} -import io.opentelemetry.sdk.autoconfigure.{ - AutoConfiguredOpenTelemetrySdk => AutoConfigOtelSdk -} -import io.opentelemetry.sdk.autoconfigure.{ - AutoConfiguredOpenTelemetrySdkBuilder => AutoConfigOtelSdkBuilder -} +import io.opentelemetry.sdk.autoconfigure.{AutoConfiguredOpenTelemetrySdk => AutoConfigOtelSdk} +import io.opentelemetry.sdk.autoconfigure.{AutoConfiguredOpenTelemetrySdkBuilder => AutoConfigOtelSdkBuilder} import io.opentelemetry.sdk.common.CompletableResultCode import org.typelevel.otel4s.Otel4s import org.typelevel.otel4s.context.LocalProvider @@ -57,12 +53,11 @@ final class OtelJava[F[_]] private ( object OtelJava { - /** Creates an [[org.typelevel.otel4s.Otel4s]] from a Java OpenTelemetry - * instance. + /** Creates an [[org.typelevel.otel4s.Otel4s]] from a Java OpenTelemetry instance. * * @param jOtel - * A Java OpenTelemetry instance. It is the caller's responsibility to shut - * this down. Failure to do so may result in lost metrics and traces. + * A Java OpenTelemetry instance. It is the caller's responsibility to shut this down. Failure to do so may result + * in lost metrics and traces. * * @return * An effect of an [[org.typelevel.otel4s.Otel4s]] resource. @@ -113,21 +108,18 @@ object OtelJava { acquire: F[JOpenTelemetrySdk] ): Resource[F, OtelJava[F]] = Resource - .make(acquire)(sdk => - asyncFromCompletableResultCode(Sync[F].delay(sdk.shutdown())) - ) + .make(acquire)(sdk => asyncFromCompletableResultCode(Sync[F].delay(sdk.shutdown()))) .evalMap(forAsync[F]) - /** Creates a [[cats.effect.Resource `Resource`]] of the automatic - * configuration of a Java `OpenTelemetrySdk` instance. + /** Creates a [[cats.effect.Resource `Resource`]] of the automatic configuration of a Java `OpenTelemetrySdk` + * instance. * * If you rely on - * [[https://opentelemetry.io/docs/instrumentation/java/automatic/ automatic instrumentation via Java agent]], - * you MUST NOT use this method and MUST use [[global]] instead. + * [[https://opentelemetry.io/docs/instrumentation/java/automatic/ automatic instrumentation via Java agent]], you + * MUST NOT use this method and MUST use [[global]] instead. * * @param customize - * A function for customizing the auto-configured SDK builder. This - * function MUST NOT call `setResultAsGlobal`. + * A function for customizing the auto-configured SDK builder. This function MUST NOT call `setResultAsGlobal`. * @return * An [[org.typelevel.otel4s.Otel4s]] resource. * @see @@ -145,8 +137,7 @@ object OtelJava { } } - /** Creates an [[org.typelevel.otel4s.Otel4s]] from the global Java - * OpenTelemetry instance. + /** Creates an [[org.typelevel.otel4s.Otel4s]] from the global Java OpenTelemetry instance. * * @see * [[autoConfigured]] diff --git a/oteljava/common-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/InstrumentationScope.scala b/oteljava/common-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/InstrumentationScope.scala index 6cfcd1b86..5147b77c9 100644 --- a/oteljava/common-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/InstrumentationScope.scala +++ b/oteljava/common-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/InstrumentationScope.scala @@ -19,14 +19,11 @@ package org.typelevel.otel4s.oteljava.testkit import cats.Hash import cats.Show import cats.syntax.show._ -import io.opentelemetry.sdk.common.{ - InstrumentationScopeInfo => JInstrumentationScopeInfo -} +import io.opentelemetry.sdk.common.{InstrumentationScopeInfo => JInstrumentationScopeInfo} import org.typelevel.otel4s.Attributes import org.typelevel.otel4s.oteljava.AttributeConverters._ -/** A representation of the - * `io.opentelemetry.sdk.common.InstrumentationScopeInfo`. +/** A representation of the `io.opentelemetry.sdk.common.InstrumentationScopeInfo`. */ sealed trait InstrumentationScope { diff --git a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/AttributeConverters.scala b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/AttributeConverters.scala index 7e999b504..0078f70a2 100644 --- a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/AttributeConverters.scala +++ b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/AttributeConverters.scala @@ -34,9 +34,8 @@ import java.{util => ju} import scala.collection.immutable import scala.jdk.CollectionConverters._ -/** This object provides extension methods that convert between Scala and Java - * `AttributeKey`s and `Attributes` using `toScala` and `toJava` extension - * methods, as well as a `toJavaAttributes` extension method that converts +/** This object provides extension methods that convert between Scala and Java `AttributeKey`s and `Attributes` using + * `toScala` and `toJava` extension methods, as well as a `toJavaAttributes` extension method that converts * `immutable.Iterable[Attribute[_]]` to Java `Attributes`. * * {{{ @@ -55,15 +54,13 @@ import scala.jdk.CollectionConverters._ */ object AttributeConverters { - implicit final class AttributeKeyHasToJava(private val key: AttributeKey[_]) - extends AnyVal { + implicit final class AttributeKeyHasToJava(private val key: AttributeKey[_]) extends AnyVal { /** Converts a Scala `AttributeKey` to a Java `AttributeKey`. */ def toJava: JAttributeKey[_] = Explicit.toJava(key) } - implicit final class AttributesHasToJava(private val attributes: Attributes) - extends AnyVal { + implicit final class AttributesHasToJava(private val attributes: Attributes) extends AnyVal { /** Converts Scala `Attributes` to Java `Attributes`. */ def toJava: JAttributes = Explicit.toJava(attributes) @@ -73,21 +70,18 @@ object AttributeConverters { private val attributes: immutable.Iterable[Attribute[_]] ) extends AnyVal { - /** Converts an immutable collection of Scala `Attribute`s to Java - * `Attributes`. + /** Converts an immutable collection of Scala `Attribute`s to Java `Attributes`. */ def toJavaAttributes: JAttributes = Explicit.toJavaAttributes(attributes) } - implicit final class AttributeKeyHasToScala(private val key: JAttributeKey[_]) - extends AnyVal { + implicit final class AttributeKeyHasToScala(private val key: JAttributeKey[_]) extends AnyVal { /** Converts a Java `AttributeKey` to a Scala `AttributeKey`. */ def toScala: AttributeKey[_] = Explicit.toScala(key) } - implicit final class AttributesHasToScala(private val attributes: JAttributes) - extends AnyVal { + implicit final class AttributesHasToScala(private val attributes: JAttributes) extends AnyVal { /** Converts Scala `Attributes` to Java `Attributes`. */ def toScala: Attributes = Explicit.toScala(attributes) diff --git a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/Context.scala b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/Context.scala index aba7b3a21..3fe81518c 100644 --- a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/Context.scala +++ b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/Context.scala @@ -21,27 +21,25 @@ import cats.effect.Sync import io.opentelemetry.context.{Context => JContext} import io.opentelemetry.context.ContextKey -/** A context wrapping a context from the Java open telemetry library (referred - * to in further documentation as a "Java context"). +/** A context wrapping a context from the Java open telemetry library (referred to in further documentation as a "Java + * context"). */ sealed trait Context { /** The underlying Java context. */ def underlying: JContext - /** Retrieves the value associated with the given key from the context, if - * such a value exists. + /** Retrieves the value associated with the given key from the context, if such a value exists. */ def get[A](key: Context.Key[A]): Option[A] - /** Retrieves the value associated with the given key from the context, if - * such a value exists; otherwise, returns the provided default value. + /** Retrieves the value associated with the given key from the context, if such a value exists; otherwise, returns the + * provided default value. */ final def getOrElse[A](key: Context.Key[A], default: => A): A = get(key).getOrElse(default) - /** Creates a copy of this context with the given value associated with the - * given key. + /** Creates a copy of this context with the given value associated with the given key. */ def updated[A](key: Context.Key[A], value: A): Context @@ -63,9 +61,7 @@ object Context { } /** A key for use with a [[`Context`]] */ - final class Key[A] private (val name: String) - extends context.Key[A] - with ContextKey[A] + final class Key[A] private (val name: String) extends context.Key[A] with ContextKey[A] object Key { diff --git a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/JavaPropagatorWrappers.scala b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/JavaPropagatorWrappers.scala index 20d93da23..80384dd8e 100644 --- a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/JavaPropagatorWrappers.scala +++ b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/JavaPropagatorWrappers.scala @@ -19,9 +19,7 @@ package propagation import io.opentelemetry.context.{Context => JContext} import io.opentelemetry.context.propagation.{TextMapGetter => JTextMapGetter} -import io.opentelemetry.context.propagation.{ - TextMapPropagator => JTextMapPropagator -} +import io.opentelemetry.context.propagation.{TextMapPropagator => JTextMapPropagator} import io.opentelemetry.context.propagation.{TextMapSetter => JTextMapSetter} import org.typelevel.otel4s.context.propagation.TextMapGetter import org.typelevel.otel4s.context.propagation.TextMapPropagator @@ -32,8 +30,7 @@ import java.{util => ju} import scala.jdk.CollectionConverters._ private[propagation] object JavaPropagatorWrappers { - class TextMapGetterWrapper[C](val underlying: TextMapGetter[C]) - extends JTextMapGetter[C] { + class TextMapGetterWrapper[C](val underlying: TextMapGetter[C]) extends JTextMapGetter[C] { def keys(carrier: C): jl.Iterable[String] = underlying.keys(carrier).asJava def get(carrier: C /* may be `null` */, key: String): String = @@ -42,16 +39,14 @@ private[propagation] object JavaPropagatorWrappers { .orNull } - class JTextMapGetterWrapper[C](val underlying: JTextMapGetter[C]) - extends TextMapGetter[C] { + class JTextMapGetterWrapper[C](val underlying: JTextMapGetter[C]) extends TextMapGetter[C] { def get(carrier: C, key: String): Option[String] = Option(underlying.get(carrier, key) /* may return `null` */ ) def keys(carrier: C): Iterable[String] = underlying.keys(carrier).asScala } - class TextMapPropagatorWrapper(val underlying: TextMapPropagator[Context]) - extends JTextMapPropagator { + class TextMapPropagatorWrapper(val underlying: TextMapPropagator[Context]) extends JTextMapPropagator { def fields(): ju.Collection[String] = underlying.fields.asJavaCollection def inject[C]( @@ -78,8 +73,7 @@ private[propagation] object JavaPropagatorWrappers { override def toString: String = s"TextMapPropagatorWrapper{$underlying}" } - class JTextMapPropagatorWrapper(val underlying: JTextMapPropagator) - extends TextMapPropagator[Context] { + class JTextMapPropagatorWrapper(val underlying: JTextMapPropagator) extends TextMapPropagator[Context] { def fields: Iterable[String] = underlying.fields().asScala def extract[A](ctx: Context, carrier: A)(implicit diff --git a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConverters.scala b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConverters.scala index 0f0a71d07..4a74e1a50 100644 --- a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConverters.scala +++ b/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConverters.scala @@ -23,22 +23,17 @@ package org.typelevel.otel4s.oteljava.context package propagation -import io.opentelemetry.context.propagation.{ - ContextPropagators => JContextPropagators -} +import io.opentelemetry.context.propagation.{ContextPropagators => JContextPropagators} import io.opentelemetry.context.propagation.{TextMapGetter => JTextMapGetter} -import io.opentelemetry.context.propagation.{ - TextMapPropagator => JTextMapPropagator -} +import io.opentelemetry.context.propagation.{TextMapPropagator => JTextMapPropagator} import org.typelevel.otel4s.context.propagation.ContextPropagators import org.typelevel.otel4s.context.propagation.TextMapGetter import org.typelevel.otel4s.context.propagation.TextMapPropagator import scala.{unchecked => uc} -/** This object provides `asScala` and `asJava` extension methods that convert - * between Scala and Java `TextMapGetter`s, `TextMapPropagator`s, and - * `ContextPropagators`. +/** This object provides `asScala` and `asJava` extension methods that convert between Scala and Java `TextMapGetter`s, + * `TextMapPropagator`s, and `ContextPropagators`. * * {{{ * import io.opentelemetry.api.trace.propagation.W3CTraceContextPropagator @@ -49,9 +44,8 @@ import scala.{unchecked => uc} * val propagator: TextMapPropagator[Context] = W3CTraceContextPropagator.getInstance().asScala * }}} * - * The conversions return wrappers for the TextMap operators, and converting - * from a source type to a target type and back again will return the original - * source object. For example: + * The conversions return wrappers for the TextMap operators, and converting from a source type to a target type and + * back again will return the original source object. For example: * * {{{ * import io.opentelemetry.api.trace.propagation.W3CTraceContextPropagator @@ -65,10 +59,9 @@ import scala.{unchecked => uc} * assert(source eq other) * }}} * - * Currently, `ContextPropagators` for both Java and Scala are simple wrappers - * around a `TextMapPropagator` instance of the corresponding type. - * Consequently, conversions between `ContextPropagators` convert the - * `TextMapPropagator` and do not use a custom wrapper. + * Currently, `ContextPropagators` for both Java and Scala are simple wrappers around a `TextMapPropagator` instance of + * the corresponding type. Consequently, conversions between `ContextPropagators` convert the `TextMapPropagator` and + * do not use a custom wrapper. */ object PropagatorConverters { @@ -78,9 +71,8 @@ object PropagatorConverters { /** Converts a Scala `TextMapGetter` to a Java `TextMapGetter`. * - * The returned Java `TextMapGetter` is backed by the provided Scala - * `TextMapGetter` unless the Scala `TextMapGetter` was previously obtained - * from an implicit or explicit call of `asScala`, in which case the + * The returned Java `TextMapGetter` is backed by the provided Scala `TextMapGetter` unless the Scala + * `TextMapGetter` was previously obtained from an implicit or explicit call of `asScala`, in which case the * original Java `TextMapGetter` will be returned. */ def asJava: JTextMapGetter[A] = Explicit.asJava(getter) @@ -92,10 +84,9 @@ object PropagatorConverters { /** Converts a Scala `TextMapPropagator` to a Java `TextMapPropagator`. * - * The returned Java `TextMapPropagator` is backed by the provided Scala - * `TextMapPropagator`unless the Scala `TextMapPropagator` was previously - * obtained from an implicit or explicit call of `asScala`, in which case - * the original Java `TextMapPropagator` will be returned. + * The returned Java `TextMapPropagator` is backed by the provided Scala `TextMapPropagator`unless the Scala + * `TextMapPropagator` was previously obtained from an implicit or explicit call of `asScala`, in which case the + * original Java `TextMapPropagator` will be returned. */ def asJava: JTextMapPropagator = Explicit.asJava(prop) } @@ -114,9 +105,8 @@ object PropagatorConverters { /** Converts a Java `TextMapGetter` to a Scala `TextMapGetter`. * - * The returned Scala `TextMapGetter` is backed by the provided Java - * `TextMapGetter` unless the Java `TextMapGetter` was previously obtained - * from an implicit or explicit call of `asJava`, in which case the + * The returned Scala `TextMapGetter` is backed by the provided Java `TextMapGetter` unless the Java + * `TextMapGetter` was previously obtained from an implicit or explicit call of `asJava`, in which case the * original Scala `TextMapGetter` will be returned. */ def asScala: TextMapGetter[A] = Explicit.asScala(getter) @@ -128,10 +118,9 @@ object PropagatorConverters { /** Converts a Java `TextMapPropagator` to a Scala `TextMapPropagator`. * - * The returned Scala `TextMapPropagator` is backed by the provided Java - * `TextMapPropagator` unless the Java `TextMapPropagator` was previously - * obtained from an implicit or explicit call of `asJava`, in which case - * the original Scala `TextMapPropagator` will be returned. + * The returned Scala `TextMapPropagator` is backed by the provided Java `TextMapPropagator` unless the Java + * `TextMapPropagator` was previously obtained from an implicit or explicit call of `asJava`, in which case the + * original Scala `TextMapPropagator` will be returned. */ def asScala: TextMapPropagator[Context] = Explicit.asScala(propagator) } @@ -150,14 +139,14 @@ object PropagatorConverters { def asJava[A](getter: TextMapGetter[A]): JTextMapGetter[A] = getter match { case null => null case wrapper: JTextMapGetterWrapper[A @uc] => wrapper.underlying - case _ => new TextMapGetterWrapper(getter) + case _ => new TextMapGetterWrapper(getter) } def asJava(propagator: TextMapPropagator[Context]): JTextMapPropagator = propagator match { case null => null case wrapper: JTextMapPropagatorWrapper => wrapper.underlying - case _ => new TextMapPropagatorWrapper(propagator) + case _ => new TextMapPropagatorWrapper(propagator) } def asJava(propagators: ContextPropagators[Context]): JContextPropagators = @@ -166,14 +155,14 @@ object PropagatorConverters { def asScala[A](getter: JTextMapGetter[A]): TextMapGetter[A] = getter match { case null => null case wrapper: TextMapGetterWrapper[A @uc] => wrapper.underlying - case _ => new JTextMapGetterWrapper(getter) + case _ => new JTextMapGetterWrapper(getter) } def asScala(propagator: JTextMapPropagator): TextMapPropagator[Context] = propagator match { case null => null case wrapper: TextMapPropagatorWrapper => wrapper.underlying - case _ => new JTextMapPropagatorWrapper(propagator) + case _ => new JTextMapPropagatorWrapper(propagator) } def asScala(propagators: JContextPropagators): ContextPropagators[Context] = diff --git a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersProps.scala b/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersProps.scala index 255c8bcc1..f230d2a72 100644 --- a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersProps.scala +++ b/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersProps.scala @@ -17,16 +17,10 @@ package org.typelevel.otel4s.oteljava.context package propagation -import io.opentelemetry.api.incubator.propagation.{ - PassThroughPropagator => JPassThroughPropagator -} -import io.opentelemetry.context.propagation.{ - ContextPropagators => JContextPropagators -} +import io.opentelemetry.api.incubator.propagation.{PassThroughPropagator => JPassThroughPropagator} +import io.opentelemetry.context.propagation.{ContextPropagators => JContextPropagators} import io.opentelemetry.context.propagation.{TextMapGetter => JTextMapGetter} -import io.opentelemetry.context.propagation.{ - TextMapPropagator => JTextMapPropagator -} +import io.opentelemetry.context.propagation.{TextMapPropagator => JTextMapPropagator} import munit.ScalaCheckSuite import org.scalacheck.Arbitrary import org.scalacheck.Gen @@ -147,124 +141,120 @@ class PropagatorConvertersProps extends ScalaCheckSuite { } property("Java TextMapPropagator and wrapper behavior equivalence") { - forAll { - (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => - val tmp = - JPassThroughPropagator.create((entries.keySet ++ extraFields).asJava) - val wrapper = tmp.asScala - assertEquals(wrapper.fields.toSeq, tmp.fields().asScala.toSeq) - val toSkip = unpropagated.view - .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) - .toMap - val extracted = - tmp.extract(Context.root.underlying, entries ++ toSkip, mkJTMG) - val wrapperExtracted = - wrapper.extract(Context.root, entries ++ toSkip) - var injected = Map.empty[String, String] - tmp.inject[Carrier]( - extracted, - null, - (_, k, v) => injected = injected.updated(k, v) - ) - val wrapperInjected = - wrapper.inject(wrapperExtracted, Map.empty[String, String]) - assertEquals(wrapperInjected, injected) + forAll { (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => + val tmp = + JPassThroughPropagator.create((entries.keySet ++ extraFields).asJava) + val wrapper = tmp.asScala + assertEquals(wrapper.fields.toSeq, tmp.fields().asScala.toSeq) + val toSkip = unpropagated.view + .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) + .toMap + val extracted = + tmp.extract(Context.root.underlying, entries ++ toSkip, mkJTMG) + val wrapperExtracted = + wrapper.extract(Context.root, entries ++ toSkip) + var injected = Map.empty[String, String] + tmp.inject[Carrier]( + extracted, + null, + (_, k, v) => injected = injected.updated(k, v) + ) + val wrapperInjected = + wrapper.inject(wrapperExtracted, Map.empty[String, String]) + assertEquals(wrapperInjected, injected) } } property("Scala TextMapPropagator and wrapper behavior equivalence") { - forAll { - (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => - val tmp: TextMapPropagator[Context] = - PassThroughPropagator(entries.keySet ++ extraFields) - val wrapper = tmp.asJava - assertEquals(wrapper.fields().asScala.toSeq, tmp.fields.toSeq) - val toSkip = unpropagated.view - .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) - .toMap - val extracted = - tmp.extract(Context.root, entries ++ toSkip) - val wrapperExtracted = - wrapper.extract(Context.root.underlying, entries ++ toSkip, mkJTMG) - val injected = tmp.inject(extracted, Map.empty[String, String]) - var wrapperInjected = Map.empty[String, String] - wrapper.inject[Carrier]( - wrapperExtracted, - null, - (_, k, v) => wrapperInjected = wrapperInjected.updated(k, v) - ) - assertEquals(wrapperInjected, injected) + forAll { (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => + val tmp: TextMapPropagator[Context] = + PassThroughPropagator(entries.keySet ++ extraFields) + val wrapper = tmp.asJava + assertEquals(wrapper.fields().asScala.toSeq, tmp.fields.toSeq) + val toSkip = unpropagated.view + .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) + .toMap + val extracted = + tmp.extract(Context.root, entries ++ toSkip) + val wrapperExtracted = + wrapper.extract(Context.root.underlying, entries ++ toSkip, mkJTMG) + val injected = tmp.inject(extracted, Map.empty[String, String]) + var wrapperInjected = Map.empty[String, String] + wrapper.inject[Carrier]( + wrapperExtracted, + null, + (_, k, v) => wrapperInjected = wrapperInjected.updated(k, v) + ) + assertEquals(wrapperInjected, injected) } } property("Java ContextPropagators and wrapper behavior equivalence") { - forAll { - (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => - val cp = JContextPropagators.create( - JPassThroughPropagator.create((entries.keySet ++ extraFields).asJava) - ) - val wrapper = cp.asScala - assertEquals( - wrapper.textMapPropagator.fields.toSeq, - cp.getTextMapPropagator.fields().asScala.toSeq + forAll { (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => + val cp = JContextPropagators.create( + JPassThroughPropagator.create((entries.keySet ++ extraFields).asJava) + ) + val wrapper = cp.asScala + assertEquals( + wrapper.textMapPropagator.fields.toSeq, + cp.getTextMapPropagator.fields().asScala.toSeq + ) + val toSkip = unpropagated.view + .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) + .toMap + val extracted = + cp.getTextMapPropagator.extract( + Context.root.underlying, + entries ++ toSkip, + mkJTMG ) - val toSkip = unpropagated.view - .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) - .toMap - val extracted = - cp.getTextMapPropagator.extract( - Context.root.underlying, - entries ++ toSkip, - mkJTMG - ) - val wrapperExtracted = - wrapper.textMapPropagator.extract(Context.root, entries ++ toSkip) - var injected = Map.empty[String, String] - cp.getTextMapPropagator.inject[Carrier]( - extracted, - null, - (_, k, v) => injected = injected.updated(k, v) + val wrapperExtracted = + wrapper.textMapPropagator.extract(Context.root, entries ++ toSkip) + var injected = Map.empty[String, String] + cp.getTextMapPropagator.inject[Carrier]( + extracted, + null, + (_, k, v) => injected = injected.updated(k, v) + ) + val wrapperInjected = + wrapper.textMapPropagator.inject( + wrapperExtracted, + Map.empty[String, String] ) - val wrapperInjected = - wrapper.textMapPropagator.inject( - wrapperExtracted, - Map.empty[String, String] - ) - assertEquals(wrapperInjected, injected) + assertEquals(wrapperInjected, injected) } } property("Scala ContextPropagators and wrapper behavior equivalence") { - forAll { - (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => - val cp = ContextPropagators.of( - PassThroughPropagator[Context, Context.Key]( - entries.keySet ++ extraFields - ) - ) - val wrapper = cp.asJava - assertEquals( - wrapper.getTextMapPropagator.fields().asScala.toSeq, - cp.textMapPropagator.fields.toSeq + forAll { (entries: Carrier, extraFields: Set[String], unpropagated: Carrier) => + val cp = ContextPropagators.of( + PassThroughPropagator[Context, Context.Key]( + entries.keySet ++ extraFields ) - val toSkip = unpropagated.view - .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) - .toMap - val extracted = - cp.textMapPropagator.extract(Context.root, entries ++ toSkip) - val wrapperExtracted = - wrapper.getTextMapPropagator.extract( - Context.root.underlying, - entries ++ toSkip, - mkJTMG - ) - val injected = - cp.textMapPropagator.inject(extracted, Map.empty[String, String]) - var wrapperInjected = Map.empty[String, String] - wrapper.getTextMapPropagator.inject[Carrier]( - wrapperExtracted, - null, - (_, k, v) => wrapperInjected = wrapperInjected.updated(k, v) + ) + val wrapper = cp.asJava + assertEquals( + wrapper.getTextMapPropagator.fields().asScala.toSeq, + cp.textMapPropagator.fields.toSeq + ) + val toSkip = unpropagated.view + .filterKeys(k => !entries.contains(k) && !extraFields.contains(k)) + .toMap + val extracted = + cp.textMapPropagator.extract(Context.root, entries ++ toSkip) + val wrapperExtracted = + wrapper.getTextMapPropagator.extract( + Context.root.underlying, + entries ++ toSkip, + mkJTMG ) - assertEquals(wrapperInjected, injected) + val injected = + cp.textMapPropagator.inject(extracted, Map.empty[String, String]) + var wrapperInjected = Map.empty[String, String] + wrapper.getTextMapPropagator.inject[Carrier]( + wrapperExtracted, + null, + (_, k, v) => wrapperInjected = wrapperInjected.updated(k, v) + ) + assertEquals(wrapperInjected, injected) } } } diff --git a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersSuite.scala b/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersSuite.scala index 55e33b11a..1b33baa2c 100644 --- a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersSuite.scala +++ b/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/context/propagation/PropagatorConvertersSuite.scala @@ -16,9 +16,7 @@ package org.typelevel.otel4s.oteljava.context.propagation -import io.opentelemetry.api.incubator.propagation.{ - PassThroughPropagator => JPassThroughPropagator -} +import io.opentelemetry.api.incubator.propagation.{PassThroughPropagator => JPassThroughPropagator} import munit.FunSuite import org.typelevel.otel4s.context.propagation.PassThroughPropagator import org.typelevel.otel4s.oteljava.context.Context diff --git a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/MetricsTestkit.scala b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/MetricsTestkit.scala index f33a7e4f3..24adc7507 100644 --- a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/MetricsTestkit.scala +++ b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/MetricsTestkit.scala @@ -58,8 +58,7 @@ object MetricsTestkit { /** Creates [[MetricsTestkit]] that keeps metrics in-memory. * * @note - * the implementation does not record exemplars. Use `OtelJavaTestkit` if - * you need to record exemplars. + * the implementation does not record exemplars. Use `OtelJavaTestkit` if you need to record exemplars. * * @param customize * the customization of the builder diff --git a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/HistogramPointData.scala b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/HistogramPointData.scala index a48f7e6a2..2321cf49d 100644 --- a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/HistogramPointData.scala +++ b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/HistogramPointData.scala @@ -19,14 +19,11 @@ package org.typelevel.otel4s.oteljava.testkit.metrics.data import cats.Hash import cats.Show import cats.syntax.show._ -import io.opentelemetry.sdk.metrics.data.{ - HistogramPointData => JHistogramPointData -} +import io.opentelemetry.sdk.metrics.data.{HistogramPointData => JHistogramPointData} import scala.jdk.CollectionConverters._ -/** A representation of the - * `io.opentelemetry.sdk.metrics.data.HistogramPointData`. +/** A representation of the `io.opentelemetry.sdk.metrics.data.HistogramPointData`. */ sealed trait HistogramPointData { @@ -76,9 +73,7 @@ object HistogramPointData { Hash.by(p => (p.sum, p.count, p.boundaries, p.counts)) implicit val histogramPointDataShow: Show[HistogramPointData] = - Show.show(p => - show"HistogramPointData(${p.sum}, ${p.count}, ${p.boundaries}, ${p.counts})" - ) + Show.show(p => show"HistogramPointData(${p.sum}, ${p.count}, ${p.boundaries}, ${p.counts})") final case class Impl( sum: Double, diff --git a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/Metric.scala b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/Metric.scala index 5278e9e2f..f0eff6640 100644 --- a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/Metric.scala +++ b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/Metric.scala @@ -21,9 +21,7 @@ import cats.Hash import cats.Show import cats.syntax.show._ import io.opentelemetry.sdk.metrics.data.{Data => JData} -import io.opentelemetry.sdk.metrics.data.{ - HistogramPointData => JHistogramPointData -} +import io.opentelemetry.sdk.metrics.data.{HistogramPointData => JHistogramPointData} import io.opentelemetry.sdk.metrics.data.{MetricData => JMetricData} import io.opentelemetry.sdk.metrics.data.{PointData => JPointData} import io.opentelemetry.sdk.metrics.data.{SummaryPointData => JSummaryPointData} @@ -154,9 +152,7 @@ object Metric { Hash.by(p => (p.name, p.description, p.unit, p.scope, p.resource, p.data)) implicit val metricShow: Show[Metric] = - Show.show(p => - show"Metric(${p.name}, ${p.description}, ${p.unit}, ${p.scope}, ${p.resource}, ${p.data})" - ) + Show.show(p => show"Metric(${p.name}, ${p.description}, ${p.unit}, ${p.scope}, ${p.resource}, ${p.data})") final case class Impl( name: String, diff --git a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/MetricData.scala b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/MetricData.scala index b9e5f0906..65ef61522 100644 --- a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/MetricData.scala +++ b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/MetricData.scala @@ -43,18 +43,15 @@ object MetricData { final case class LongGauge(points: List[PointData[Long]]) extends MetricData - final case class DoubleGauge(points: List[PointData[Double]]) - extends MetricData + final case class DoubleGauge(points: List[PointData[Double]]) extends MetricData final case class LongSum(points: List[PointData[Long]]) extends MetricData final case class DoubleSum(points: List[PointData[Double]]) extends MetricData - final case class Summary(points: List[PointData[SummaryPointData]]) - extends MetricData + final case class Summary(points: List[PointData[SummaryPointData]]) extends MetricData - final case class Histogram(points: List[PointData[HistogramPointData]]) - extends MetricData + final case class Histogram(points: List[PointData[HistogramPointData]]) extends MetricData final case class ExponentialHistogram( points: List[PointData[HistogramPointData]] diff --git a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/SummaryPointData.scala b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/SummaryPointData.scala index 3c9286e31..15b7e4ba1 100644 --- a/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/SummaryPointData.scala +++ b/oteljava/metrics-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/metrics/data/SummaryPointData.scala @@ -23,8 +23,7 @@ import io.opentelemetry.sdk.metrics.data.{SummaryPointData => JSummaryPointData} import scala.jdk.CollectionConverters._ -/** A representation of the - * `io.opentelemetry.sdk.metrics.data.SummaryPointData`. +/** A representation of the `io.opentelemetry.sdk.metrics.data.SummaryPointData`. */ sealed trait SummaryPointData { diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/BatchCallbackImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/BatchCallbackImpl.scala index 5e37a85e3..c826331e5 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/BatchCallbackImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/BatchCallbackImpl.scala @@ -33,8 +33,8 @@ private final class BatchCallbackImpl[F[_]: Async]( observable: ObservableMeasurement[F, _], rest: ObservableMeasurement[F, _]* ): Resource[F, Unit] = { - val all = (observable +: rest.view).collect { - case o: ObservableMeasurementImpl[F, _] => o.jObservableMeasurement + val all = (observable +: rest.view).collect { case o: ObservableMeasurementImpl[F, _] => + o.jObservableMeasurement }.toList all match { diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/MeterImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/MeterImpl.scala index 69dbe4355..ade0a8812 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/MeterImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/MeterImpl.scala @@ -23,8 +23,7 @@ import io.opentelemetry.api.metrics.{Meter => JMeter} import org.typelevel.otel4s.metrics._ import org.typelevel.otel4s.oteljava.context.AskContext -private[oteljava] class MeterImpl[F[_]: Async: AskContext](jMeter: JMeter) - extends Meter[F] { +private[oteljava] class MeterImpl[F[_]: Async: AskContext](jMeter: JMeter) extends Meter[F] { def counter[A: MeasurementValue](name: String): Counter.Builder[F, A] = CounterBuilderImpl(jMeter, name) diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableCounterBuilderImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableCounterBuilderImpl.scala index a2d39b99e..f6b3c523f 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableCounterBuilderImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableCounterBuilderImpl.scala @@ -23,9 +23,7 @@ import cats.effect.kernel.Resource import cats.effect.std.Dispatcher import cats.syntax.all._ import io.opentelemetry.api.metrics.{Meter => JMeter} -import io.opentelemetry.api.metrics.{ - ObservableMeasurement => JObservableMeasurement -} +import io.opentelemetry.api.metrics.{ObservableMeasurement => JObservableMeasurement} import io.opentelemetry.api.metrics.LongCounterBuilder import io.opentelemetry.api.metrics.ObservableDoubleMeasurement import io.opentelemetry.api.metrics.ObservableLongMeasurement diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableGaugeBuilderImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableGaugeBuilderImpl.scala index 7515927c8..98d7d2988 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableGaugeBuilderImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableGaugeBuilderImpl.scala @@ -23,9 +23,7 @@ import cats.effect.kernel.Resource import cats.effect.std.Dispatcher import cats.syntax.all._ import io.opentelemetry.api.metrics.{Meter => JMeter} -import io.opentelemetry.api.metrics.{ - ObservableMeasurement => JObservableMeasurement -} +import io.opentelemetry.api.metrics.{ObservableMeasurement => JObservableMeasurement} import io.opentelemetry.api.metrics.DoubleGaugeBuilder import io.opentelemetry.api.metrics.ObservableDoubleMeasurement import io.opentelemetry.api.metrics.ObservableLongMeasurement diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableMeasurementImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableMeasurementImpl.scala index fa93850c7..acc1269a0 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableMeasurementImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableMeasurementImpl.scala @@ -17,9 +17,7 @@ package org.typelevel.otel4s.oteljava.metrics import cats.effect.kernel.Sync -import io.opentelemetry.api.metrics.{ - ObservableMeasurement => JObservableMeasurement -} +import io.opentelemetry.api.metrics.{ObservableMeasurement => JObservableMeasurement} import io.opentelemetry.api.metrics.ObservableDoubleMeasurement import io.opentelemetry.api.metrics.ObservableLongMeasurement import org.typelevel.otel4s.Attributes diff --git a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableUpDownCounterBuilderImpl.scala b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableUpDownCounterBuilderImpl.scala index ebcb7060f..7d8852fe3 100644 --- a/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableUpDownCounterBuilderImpl.scala +++ b/oteljava/metrics/src/main/scala/org/typelevel/otel4s/oteljava/metrics/ObservableUpDownCounterBuilderImpl.scala @@ -23,9 +23,7 @@ import cats.effect.kernel.Resource import cats.effect.std.Dispatcher import cats.syntax.all._ import io.opentelemetry.api.metrics.{Meter => JMeter} -import io.opentelemetry.api.metrics.{ - ObservableMeasurement => JObservableMeasurement -} +import io.opentelemetry.api.metrics.{ObservableMeasurement => JObservableMeasurement} import io.opentelemetry.api.metrics.LongUpDownCounterBuilder import io.opentelemetry.api.metrics.ObservableDoubleMeasurement import io.opentelemetry.api.metrics.ObservableLongMeasurement diff --git a/oteljava/testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/OtelJavaTestkit.scala b/oteljava/testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/OtelJavaTestkit.scala index de916d388..c1c9f22e5 100644 --- a/oteljava/testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/OtelJavaTestkit.scala +++ b/oteljava/testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/OtelJavaTestkit.scala @@ -19,9 +19,7 @@ package oteljava.testkit import cats.effect.Async import cats.effect.Resource -import io.opentelemetry.context.propagation.{ - TextMapPropagator => JTextMapPropagator -} +import io.opentelemetry.context.propagation.{TextMapPropagator => JTextMapPropagator} import io.opentelemetry.sdk.metrics.SdkMeterProviderBuilder import io.opentelemetry.sdk.trace.SdkTracerProviderBuilder import org.typelevel.otel4s.context.LocalProvider @@ -62,10 +60,8 @@ object OtelJavaTestkit { * the propagators to use */ def inMemory[F[_]: Async: LocalContextProvider]( - customizeMeterProviderBuilder: SdkMeterProviderBuilder => SdkMeterProviderBuilder = - identity, - customizeTracerProviderBuilder: SdkTracerProviderBuilder => SdkTracerProviderBuilder = - identity, + customizeMeterProviderBuilder: SdkMeterProviderBuilder => SdkMeterProviderBuilder = identity, + customizeTracerProviderBuilder: SdkTracerProviderBuilder => SdkTracerProviderBuilder = identity, textMapPropagators: Iterable[JTextMapPropagator] = Nil ): Resource[F, OtelJavaTestkit[F]] = Resource.eval(LocalProvider[F, Context].local).flatMap { implicit local => diff --git a/oteljava/trace-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/trace/TracesTestkit.scala b/oteljava/trace-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/trace/TracesTestkit.scala index 46230707d..f11aeeb3b 100644 --- a/oteljava/trace-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/trace/TracesTestkit.scala +++ b/oteljava/trace-testkit/src/main/scala/org/typelevel/otel4s/oteljava/testkit/trace/TracesTestkit.scala @@ -21,9 +21,7 @@ import cats.effect.Async import cats.effect.Resource import cats.syntax.flatMap._ import cats.syntax.functor._ -import io.opentelemetry.context.propagation.{ - TextMapPropagator => JTextMapPropagator -} +import io.opentelemetry.context.propagation.{TextMapPropagator => JTextMapPropagator} import io.opentelemetry.sdk.testing.exporter.InMemorySpanExporter import io.opentelemetry.sdk.trace.SdkTracerProvider import io.opentelemetry.sdk.trace.SdkTracerProviderBuilder @@ -62,13 +60,12 @@ trait TracesTestkit[F[_]] { */ def finishedSpans[A: FromSpanData]: F[List[A]] - /** The propagators used by the - * [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. + /** The propagators used by the [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. */ def propagators: ContextPropagators[Context] - /** The [[org.typelevel.otel4s.oteljava.context.LocalContext LocalContext]] - * used by the [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. + /** The [[org.typelevel.otel4s.oteljava.context.LocalContext LocalContext]] used by the + * [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. */ def localContext: LocalContext[F] } @@ -84,8 +81,7 @@ object TracesTestkit { * the propagators to use */ def inMemory[F[_]: Async: LocalContextProvider]( - customize: SdkTracerProviderBuilder => SdkTracerProviderBuilder = - identity, + customize: SdkTracerProviderBuilder => SdkTracerProviderBuilder = identity, textMapPropagators: Iterable[JTextMapPropagator] = Nil ): Resource[F, TracesTestkit[F]] = { def createSpanExporter = diff --git a/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/TracerImpl.scala b/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/TracerImpl.scala index aba750bb6..f1a32b7e5 100644 --- a/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/TracerImpl.scala +++ b/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/TracerImpl.scala @@ -83,7 +83,5 @@ private[oteljava] class TracerImpl[F[_]]( } def propagate[C: TextMapUpdater](carrier: C): F[C] = - traceScope.contextReader(ctx => - propagators.textMapPropagator.inject(ctx, carrier) - ) + traceScope.contextReader(ctx => propagators.textMapPropagator.inject(ctx, carrier)) } diff --git a/scalafix/rules/src/main/scala/org/typelevel/otel4s/scalafix/V0_5_0Rewrites.scala b/scalafix/rules/src/main/scala/org/typelevel/otel4s/scalafix/V0_5_0Rewrites.scala index 2988d4430..c316f231c 100644 --- a/scalafix/rules/src/main/scala/org/typelevel/otel4s/scalafix/V0_5_0Rewrites.scala +++ b/scalafix/rules/src/main/scala/org/typelevel/otel4s/scalafix/V0_5_0Rewrites.scala @@ -30,9 +30,8 @@ class V0_5_0Rewrites extends SemanticRule("V0_5_0Rewrites") { make("org" :: "typelevel" :: "otel4s" :: packages.toList: _*) def make(packages: String*): Term.Ref = - packages.tail.foldLeft(Term.Name(packages.head): Term.Ref) { - case (selector, pkg) => - Term.Select(selector, Term.Name(pkg)) + packages.tail.foldLeft(Term.Name(packages.head): Term.Ref) { case (selector, pkg) => + Term.Select(selector, Term.Name(pkg)) } } @@ -134,8 +133,7 @@ class V0_5_0Rewrites extends SemanticRule("V0_5_0Rewrites") { object UpDownCounter extends MeterOpMatcher("upDownCounter", "Long") object ObservableGauge extends MeterOpMatcher("observableGauge", "Double") object ObservableCounter extends MeterOpMatcher("observableCounter", "Long") - object ObservableUpDownCounter - extends MeterOpMatcher("observableUpDownCounter", "Long") + object ObservableUpDownCounter extends MeterOpMatcher("observableUpDownCounter", "Long") } } diff --git a/sdk-contrib/aws/resource/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/resource/AWSLambdaDetector.scala b/sdk-contrib/aws/resource/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/resource/AWSLambdaDetector.scala index 0c5b18a6e..91a9d6758 100644 --- a/sdk-contrib/aws/resource/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/resource/AWSLambdaDetector.scala +++ b/sdk-contrib/aws/resource/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/resource/AWSLambdaDetector.scala @@ -26,8 +26,7 @@ import org.typelevel.otel4s.sdk.TelemetryResource import org.typelevel.otel4s.sdk.resource.TelemetryResourceDetector import org.typelevel.otel4s.semconv.SchemaUrls -private class AWSLambdaDetector[F[_]: Env: Monad] - extends TelemetryResourceDetector[F] { +private class AWSLambdaDetector[F[_]: Env: Monad] extends TelemetryResourceDetector[F] { import AWSLambdaDetector.Const import AWSLambdaDetector.Keys @@ -76,12 +75,10 @@ object AWSLambdaDetector { val FaasVersion: AttributeKey[String] = AttributeKey("faas.version") } - /** The detector relies on the `AWS_REGION`, `AWS_LAMBDA_FUNCTION_NAME`, and - * `AWS_LAMBDA_FUNCTION_VERSION` environment variables to configure the - * telemetry resource. + /** The detector relies on the `AWS_REGION`, `AWS_LAMBDA_FUNCTION_NAME`, and `AWS_LAMBDA_FUNCTION_VERSION` environment + * variables to configure the telemetry resource. * - * Either `AWS_LAMBDA_FUNCTION_NAME` or `AWS_LAMBDA_FUNCTION_VERSION` must be - * present. + * Either `AWS_LAMBDA_FUNCTION_NAME` or `AWS_LAMBDA_FUNCTION_VERSION` must be present. * * @example * {{{ diff --git a/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayLambdaPropagator.scala b/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayLambdaPropagator.scala index 9950c6d90..41533f116 100644 --- a/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayLambdaPropagator.scala +++ b/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayLambdaPropagator.scala @@ -28,9 +28,8 @@ import org.typelevel.otel4s.sdk.trace.SdkContextKeys * X-Amzn-Trace-Id: Root=1-5759e988-bd862e3fe1be46a994272793;Parent=53995c3f42cd8ad8;Sampled=1 * }}} * - * If the header is missing, the Lambda's `com.amazonaws.xray.traceHeader` - * system property or `_X_AMZN_TRACE_ID` environment variable will be used as a - * fallback. + * If the header is missing, the Lambda's `com.amazonaws.xray.traceHeader` system property or `_X_AMZN_TRACE_ID` + * environment variable will be used as a fallback. * * @see * [[https://docs.aws.amazon.com/xray/latest/devguide/xray-concepts.html#xray-concepts-tracingheader]] @@ -92,12 +91,10 @@ object AWSXRayLambdaPropagator { /** Returns an instance of the AWSXRayLambdaPropagator. * - * The propagator utilizes `X-Amzn-Trace-Id` header to extract and inject - * tracing details. + * The propagator utilizes `X-Amzn-Trace-Id` header to extract and inject tracing details. * - * If the header is missing, the Lambda's `com.amazonaws.xray.traceHeader` - * system property or `_X_AMZN_TRACE_ID` environment variable will be used as - * a fallback. + * If the header is missing, the Lambda's `com.amazonaws.xray.traceHeader` system property or `_X_AMZN_TRACE_ID` + * environment variable will be used as a fallback. * * An example of the AWS X-Ray Tracing Header: * {{{ @@ -115,9 +112,8 @@ object AWSXRayLambdaPropagator { */ def apply(): TextMapPropagator[Context] = Propagator - /** Returns the named configurer `xray-lambda`. You can use it to dynamically - * enable AWS X-Ray lambda propagator via environment variable or system - * properties. + /** Returns the named configurer `xray-lambda`. You can use it to dynamically enable AWS X-Ray lambda propagator via + * environment variable or system properties. * * @example * {{{ diff --git a/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayPropagator.scala b/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayPropagator.scala index c398fd08f..8f5f00d71 100644 --- a/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayPropagator.scala +++ b/sdk-contrib/aws/xray-propagator/src/main/scala/org/typelevel/otel4s/sdk/contrib/aws/context/propagation/AWSXRayPropagator.scala @@ -178,8 +178,7 @@ object AWSXRayPropagator { /** Returns an instance of the AWSXRayPropagator. * - * The propagator utilizes `X-Amzn-Trace-Id` header to extract and inject - * tracing details. + * The propagator utilizes `X-Amzn-Trace-Id` header to extract and inject tracing details. * * An example of the AWS X-Ray Tracing Header: * {{{ @@ -198,8 +197,8 @@ object AWSXRayPropagator { */ def apply(): TextMapPropagator[Context] = Propagator - /** Returns the named configurer `xray`. You can use it to dynamically enable - * AWS X-Ray propagator via environment variable or system properties. + /** Returns the named configurer `xray`. You can use it to dynamically enable AWS X-Ray propagator via environment + * variable or system properties. * * @example * {{{ diff --git a/sdk-exporter/all/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpExportersAutoConfigure.scala b/sdk-exporter/all/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpExportersAutoConfigure.scala index ebc5c9c13..5f03d97ff 100644 --- a/sdk-exporter/all/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpExportersAutoConfigure.scala +++ b/sdk-exporter/all/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpExportersAutoConfigure.scala @@ -27,9 +27,8 @@ import org.typelevel.otel4s.sdk.exporter.otlp.trace.autoconfigure.OtlpSpanExport object OtlpExportersAutoConfigure { - /** An OTLP configurers of - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] - * and [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. + /** An OTLP configurers of [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] and + * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. */ def apply[ F[_]: Async: Network: Compression: Console @@ -39,13 +38,11 @@ object OtlpExportersAutoConfigure { OtlpSpanExporterAutoConfigure[F] ) - /** An OTLP configurers of - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] - * and [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. + /** An OTLP configurers of [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] and + * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. * * @note - * the 'timeout' and 'tlsContext' settings will be ignored. You must - * preconfigure the client manually. + * the 'timeout' and 'tlsContext' settings will be ignored. You must preconfigure the client manually. * * @example * {{{ diff --git a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/ProtoEncoder.scala b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/ProtoEncoder.scala index 2ee345c39..0d79fc677 100644 --- a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/ProtoEncoder.scala +++ b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/ProtoEncoder.scala @@ -19,9 +19,7 @@ package sdk package exporter.otlp import io.circe.Json -import io.opentelemetry.proto.common.v1.common.{ - InstrumentationScope => ScopeProto -} +import io.opentelemetry.proto.common.v1.common.{InstrumentationScope => ScopeProto} import io.opentelemetry.proto.common.v1.common.AnyValue import io.opentelemetry.proto.common.v1.common.ArrayValue import io.opentelemetry.proto.common.v1.common.KeyValue @@ -76,10 +74,10 @@ private[otlp] object ProtoEncoder { } val value = att.key.`type` match { - case AttributeType.Boolean => primitive[Boolean](Value.BoolValue.apply) - case AttributeType.Double => primitive[Double](Value.DoubleValue.apply) - case AttributeType.String => primitive[String](Value.StringValue.apply) - case AttributeType.Long => primitive[Long](Value.IntValue.apply) + case AttributeType.Boolean => primitive[Boolean](Value.BoolValue.apply) + case AttributeType.Double => primitive[Double](Value.DoubleValue.apply) + case AttributeType.String => primitive[String](Value.StringValue.apply) + case AttributeType.Long => primitive[Long](Value.IntValue.apply) case AttributeType.BooleanSeq => seq[Boolean](Value.BoolValue.apply) case AttributeType.DoubleSeq => seq[Double](Value.DoubleValue.apply) case AttributeType.StringSeq => seq[String](Value.StringValue.apply) @@ -89,17 +87,15 @@ private[otlp] object ProtoEncoder { KeyValue(att.key.name, Some(AnyValue(value))) } - implicit val attributesEncoder: ProtoEncoder[Attributes, Seq[KeyValue]] = { - attr => attr.toSeq.map(a => encode[Attribute[_], KeyValue](a)) + implicit val attributesEncoder: ProtoEncoder[Attributes, Seq[KeyValue]] = { attr => + attr.toSeq.map(a => encode[Attribute[_], KeyValue](a)) } - implicit val telemetryResourceEncoder - : ProtoEncoder[TelemetryResource, ResourceProto] = { resource => + implicit val telemetryResourceEncoder: ProtoEncoder[TelemetryResource, ResourceProto] = { resource => ResourceProto(attributes = encode(resource.attributes)) } - implicit val instrumentationScopeEncoder - : ProtoEncoder[InstrumentationScope, ScopeProto] = { scope => + implicit val instrumentationScopeEncoder: ProtoEncoder[InstrumentationScope, ScopeProto] = { scope => ScopeProto( name = scope.name, version = scope.version.getOrElse(""), diff --git a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigure.scala b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigure.scala index 1d35d9e29..8515b0221 100644 --- a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigure.scala +++ b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigure.scala @@ -39,8 +39,7 @@ import scala.concurrent.duration.FiniteDuration /** Autoconfigures [[OtlpHttpClient]]. * - * Target-specific properties are prioritized. E.g. - * `otel.exporter.otlp.traces.endpoint` is prioritized over + * Target-specific properties are prioritized. E.g. `otel.exporter.otlp.traces.endpoint` is prioritized over * `otel.exporter.otlp.endpoint`. * * The general configuration options: @@ -205,12 +204,10 @@ private[exporter] object OtlpHttpClientAutoConfigure { } } - /** Autoconfigures [[OtlpHttpClient]] using `otel.exporter.otlp.metrics.{x}` - * and `otel.exporter.otlp.{x}` properties. + /** Autoconfigures [[OtlpHttpClient]] using `otel.exporter.otlp.metrics.{x}` and `otel.exporter.otlp.{x}` properties. * * @param defaults - * the default values to use as a fallback when property is missing in the - * config + * the default values to use as a fallback when property is missing in the config */ def metrics[F[_]: Async: Network: Compression: Console, A]( defaults: Defaults, @@ -226,12 +223,10 @@ private[exporter] object OtlpHttpClientAutoConfigure { ConfigKeys.General.All ++ ConfigKeys.Metrics.All ) - /** Autoconfigures [[OtlpHttpClient]] using `otel.exporter.otlp.traces.{x}` - * and `otel.exporter.otlp.{x}` properties. + /** Autoconfigures [[OtlpHttpClient]] using `otel.exporter.otlp.traces.{x}` and `otel.exporter.otlp.{x}` properties. * * @param defaults - * the default values to use as a fallback when property is missing in the - * config + * the default values to use as a fallback when property is missing in the config */ def traces[F[_]: Async: Network: Compression: Console, A]( defaults: Defaults, diff --git a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/ProtocolAutoConfigure.scala b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/ProtocolAutoConfigure.scala index 7ab47132c..ba626b792 100644 --- a/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/ProtocolAutoConfigure.scala +++ b/sdk-exporter/common/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/ProtocolAutoConfigure.scala @@ -23,8 +23,7 @@ import org.typelevel.otel4s.sdk.autoconfigure.AutoConfigure import org.typelevel.otel4s.sdk.autoconfigure.Config import org.typelevel.otel4s.sdk.autoconfigure.ConfigurationError -/** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. +/** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. * * The general configuration options: * {{{ @@ -110,8 +109,7 @@ private[exporter] object ProtocolAutoConfigure { val OtlpProtocol: Protocol = Protocol.Http(HttpPayloadEncoding.Protobuf) } - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. * * The general configuration options: * {{{ @@ -133,8 +131,7 @@ private[exporter] object ProtocolAutoConfigure { def metrics[F[_]: MonadThrow]: AutoConfigure[F, Protocol] = new ProtocolAutoConfigure[F](ConfigKeys.MetricsProtocol) - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.exporter.otlp.Protocol Protocol]]. * * The general configuration options: * {{{ diff --git a/sdk-exporter/common/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigureSuite.scala b/sdk-exporter/common/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigureSuite.scala index 8b3a59c64..29268b533 100644 --- a/sdk-exporter/common/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigureSuite.scala +++ b/sdk-exporter/common/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/autoconfigure/OtlpHttpClientAutoConfigureSuite.scala @@ -31,9 +31,7 @@ import scalapb_circe.Printer import scala.concurrent.duration._ -class OtlpHttpClientAutoConfigureSuite - extends CatsEffectSuite - with SuiteRuntimePlatform { +class OtlpHttpClientAutoConfigureSuite extends CatsEffectSuite with SuiteRuntimePlatform { import OtlpHttpClientAutoConfigure.Defaults diff --git a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsProtoEncoder.scala b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsProtoEncoder.scala index 9ed7caebc..0fc8a242d 100644 --- a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsProtoEncoder.scala +++ b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsProtoEncoder.scala @@ -43,11 +43,9 @@ private object MetricsProtoEncoder { implicit val jsonPrinter: Printer = new ProtoEncoder.JsonPrinter { private val EncodeAsHex = Set("trace_id", "span_id") - /** The `traceId` and `spanId` byte arrays are represented as - * case-insensitive hex-encoded strings; they are not base64-encoded as is - * defined in the standard Protobuf JSON Mapping. Hex encoding is used for - * traceId and spanId fields in all OTLP Protobuf messages, e.g., the Span, - * Link, LogRecord, etc. messages. + /** The `traceId` and `spanId` byte arrays are represented as case-insensitive hex-encoded strings; they are not + * base64-encoded as is defined in the standard Protobuf JSON Mapping. Hex encoding is used for traceId and spanId + * fields in all OTLP Protobuf messages, e.g., the Span, Link, LogRecord, etc. messages. * * @see * [[https://github.com/open-telemetry/opentelemetry-proto/blob/v1.2.0/docs/specification.md#json-protobuf-encoding]] diff --git a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporter.scala b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporter.scala index 811cff30d..fec73c1df 100644 --- a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporter.scala +++ b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporter.scala @@ -73,15 +73,13 @@ object OtlpHttpMetricExporter { /** Sets the OTLP endpoint to connect to. * - * The endpoint must start with either `http://` or `https://`, and include - * the full HTTP path. + * The endpoint must start with either `http://` or `https://`, and include the full HTTP path. * * Default value is `http://localhost:4318/v1/metrics`. */ def withEndpoint(endpoint: Uri): Builder[F] - /** Sets the maximum time to wait for the collector to process an exported - * batch of spans. + /** Sets the maximum time to wait for the collector to process an exported batch of spans. * * Default value is `10 seconds`. */ @@ -126,8 +124,7 @@ object OtlpHttpMetricExporter { /** Sets the default aggregation selector to use. * - * If no views are configured for a metric instrument, an aggregation - * provided by the selector will be used. + * If no views are configured for a metric instrument, an aggregation provided by the selector will be used. * * Default selector is * [[org.typelevel.otel4s.sdk.metrics.exporter.AggregationSelector.default AggregationSelector.default]]. @@ -138,8 +135,7 @@ object OtlpHttpMetricExporter { /** Sets the default cardinality limit selector to use. * - * If no views are configured for a metric instrument, a limit provided by - * the selector will be used. + * If no views are configured for a metric instrument, a limit provided by the selector will be used. * * Default selector is * [[org.typelevel.otel4s.sdk.metrics.exporter.CardinalityLimitSelector.default CardinalityLimitSelector.default]]. @@ -151,27 +147,23 @@ object OtlpHttpMetricExporter { /** Configures the exporter to use the given client. * * @note - * the 'timeout' and 'tlsContext' settings will be ignored. You must - * preconfigure the client manually. + * the 'timeout' and 'tlsContext' settings will be ignored. You must preconfigure the client manually. * * @param client * the custom http4s client to use */ def withClient(client: Client[F]): Builder[F] - /** Creates a [[OtlpHttpMetricExporter]] using the configuration of this - * builder. + /** Creates a [[OtlpHttpMetricExporter]] using the configuration of this builder. */ def build: Resource[F, MetricExporter.Push[F]] } - /** Creates a [[Builder]] of [[OtlpHttpMetricExporter]] with the default - * configuration: + /** Creates a [[Builder]] of [[OtlpHttpMetricExporter]] with the default configuration: * - encoding: `Protobuf` * - endpoint: `http://localhost:4318/v1/metrics` * - timeout: `10 seconds` - * - retry policy: 5 exponential attempts, initial backoff is `1 second`, - * max backoff is `5 seconds` + * - retry policy: 5 exponential attempts, initial backoff is `1 second`, max backoff is `5 seconds` */ def builder[F[_]: Async: Network: Compression: Console]: Builder[F] = BuilderImpl( @@ -181,8 +173,7 @@ object OtlpHttpMetricExporter { timeout = Defaults.Timeout, headers = Headers.empty, retryPolicy = RetryPolicy.default, - aggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, + aggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, defaultAggregationSelector = AggregationSelector.default, defaultCardinalityLimitSelector = CardinalityLimitSelector.default, tlsContext = None, diff --git a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigure.scala b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigure.scala index 95b2f31a0..4f15f88df 100644 --- a/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigure.scala +++ b/sdk-exporter/metrics/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigure.scala @@ -36,8 +36,7 @@ import org.typelevel.otel4s.sdk.metrics.exporter.AggregationTemporalitySelector import org.typelevel.otel4s.sdk.metrics.exporter.CardinalityLimitSelector import org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter -/** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. +/** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. * * @see * [[ProtocolAutoConfigure]] for OTLP protocol configuration @@ -60,69 +59,61 @@ private final class OtlpMetricExporterAutoConfigure[ def name: String = "otlp" protected def fromConfig(config: Config): Resource[F, MetricExporter[F]] = - ProtocolAutoConfigure.metrics[F].configure(config).flatMap { - case Protocol.Http(encoding) => - import MetricsProtoEncoder.exportMetricsRequest - import MetricsProtoEncoder.jsonPrinter + ProtocolAutoConfigure.metrics[F].configure(config).flatMap { case Protocol.Http(encoding) => + import MetricsProtoEncoder.exportMetricsRequest + import MetricsProtoEncoder.jsonPrinter - val defaults = OtlpHttpClientAutoConfigure.Defaults( - OtlpHttpMetricExporter.Defaults.Endpoint, - OtlpHttpMetricExporter.Defaults.Endpoint.path.toString, - Headers.empty, - OtlpHttpMetricExporter.Defaults.Timeout, - encoding - ) + val defaults = OtlpHttpClientAutoConfigure.Defaults( + OtlpHttpMetricExporter.Defaults.Endpoint, + OtlpHttpMetricExporter.Defaults.Endpoint.path.toString, + Headers.empty, + OtlpHttpMetricExporter.Defaults.Timeout, + encoding + ) - OtlpHttpClientAutoConfigure - .metrics[F, MetricData](defaults, customClient) - .configure(config) - .map { client => - new OtlpHttpMetricExporter[F]( - client, - AggregationTemporalitySelector.alwaysCumulative, - AggregationSelector.default, - CardinalityLimitSelector.default - ) - } + OtlpHttpClientAutoConfigure + .metrics[F, MetricData](defaults, customClient) + .configure(config) + .map { client => + new OtlpHttpMetricExporter[F]( + client, + AggregationTemporalitySelector.alwaysCumulative, + AggregationSelector.default, + CardinalityLimitSelector.default + ) + } } } object OtlpMetricExporterAutoConfigure { - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. * - * The configuration depends on the `otel.exporter.otlp.protocol` or - * `otel.exporter.otlp.metrics.protocol`. + * The configuration depends on the `otel.exporter.otlp.protocol` or `otel.exporter.otlp.metrics.protocol`. * * The supported protocols: `http/json`, `http/protobuf`. * * @see - * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP - * HTTP client + * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP HTTP client */ def apply[ F[_]: Async: Network: Compression: Console ]: AutoConfigure.Named[F, MetricExporter[F]] = new OtlpMetricExporterAutoConfigure[F](None) - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] - * using the given client. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]] using the given + * client. * - * The configuration depends on the `otel.exporter.otlp.protocol` or - * `otel.exporter.otlp.metrics.protocol`. + * The configuration depends on the `otel.exporter.otlp.protocol` or `otel.exporter.otlp.metrics.protocol`. * * The supported protocols: `http/json`, `http/protobuf`. * * @see - * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP - * HTTP client + * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP HTTP client * * @note - * the 'timeout' and 'tlsContext' settings will be ignored. You must - * preconfigure the client manually. + * the 'timeout' and 'tlsContext' settings will be ignored. You must preconfigure the client manually. * * @example * {{{ diff --git a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsJsonCodecs.scala b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsJsonCodecs.scala index 513d0eb89..fc9afed9a 100644 --- a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsJsonCodecs.scala +++ b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/MetricsJsonCodecs.scala @@ -32,8 +32,7 @@ import org.typelevel.otel4s.sdk.metrics.data.PointData // the instances mimic Protobuf encoding private object MetricsJsonCodecs extends JsonCodecs { - implicit val aggregationTemporalityJsonEncoder - : Encoder[AggregationTemporality] = + implicit val aggregationTemporalityJsonEncoder: Encoder[AggregationTemporality] = Encoder.instance { case AggregationTemporality.Delta => Json.fromInt(1) case AggregationTemporality.Cumulative => Json.fromInt(2) @@ -126,8 +125,7 @@ private object MetricsJsonCodecs extends JsonCodecs { .dropEmptyValues } - implicit val histogramMetricPointsJsonEncoder - : Encoder[MetricPoints.Histogram] = + implicit val histogramMetricPointsJsonEncoder: Encoder[MetricPoints.Histogram] = Encoder.instance { histogram => Json .obj( diff --git a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporterSuite.scala b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporterSuite.scala index 5b0cd6bf1..cd9d7ff82 100644 --- a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporterSuite.scala +++ b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/OtlpHttpMetricExporterSuite.scala @@ -45,10 +45,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Arbitraries._ import scala.concurrent.duration._ -class OtlpHttpMetricExporterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite - with SuiteRuntimePlatform { +class OtlpHttpMetricExporterSuite extends CatsEffectSuite with ScalaCheckEffectSuite with SuiteRuntimePlatform { import OtlpHttpMetricExporterSuite._ @@ -260,12 +257,11 @@ class OtlpHttpMetricExporterSuite attributes.map(a => attributeToPair(a)).toMap points.flatMap { point => - val all = point.boundaries.boundaries.zipWithIndex.map { - case (boundary, idx) => - PrometheusSeries( - const ++ attrs ++ Map("le" -> boundary.toString), - PrometheusValue(point.counts.take(idx + 1).sum.toString) - ) + val all = point.boundaries.boundaries.zipWithIndex.map { case (boundary, idx) => + PrometheusSeries( + const ++ attrs ++ Map("le" -> boundary.toString), + PrometheusValue(point.counts.take(idx + 1).sum.toString) + ) } val inf = PrometheusSeries( diff --git a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigureSuite.scala b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigureSuite.scala index 32cf30bcd..047019f53 100644 --- a/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigureSuite.scala +++ b/sdk-exporter/metrics/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/metrics/autoconfigure/OtlpMetricExporterAutoConfigureSuite.scala @@ -23,9 +23,7 @@ import munit.CatsEffectSuite import org.typelevel.otel4s.sdk.autoconfigure.Config import org.typelevel.otel4s.sdk.exporter.SuiteRuntimePlatform -class OtlpMetricExporterAutoConfigureSuite - extends CatsEffectSuite - with SuiteRuntimePlatform { +class OtlpMetricExporterAutoConfigureSuite extends CatsEffectSuite with SuiteRuntimePlatform { test("load from the config - empty config - load default") { val config = Config.ofProps(Map.empty) diff --git a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporter.scala b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporter.scala index ec8aaa924..dd8a8e218 100644 --- a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporter.scala +++ b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporter.scala @@ -67,15 +67,13 @@ object OtlpHttpSpanExporter { /** Sets the OTLP endpoint to connect to. * - * The endpoint must start with either `http://` or `https://`, and include - * the full HTTP path. + * The endpoint must start with either `http://` or `https://`, and include the full HTTP path. * * Default value is `http://localhost:4318/v1/traces`. */ def withEndpoint(endpoint: Uri): Builder[F] - /** Sets the maximum time to wait for the collector to process an exported - * batch of spans. + /** Sets the maximum time to wait for the collector to process an exported batch of spans. * * Default value is `10 seconds`. */ @@ -112,27 +110,23 @@ object OtlpHttpSpanExporter { /** Configures the exporter to use the given client. * * @note - * the 'timeout' and 'tlsContext' settings will be ignored. You must - * preconfigure the client manually. + * the 'timeout' and 'tlsContext' settings will be ignored. You must preconfigure the client manually. * * @param client * the custom http4s client to use */ def withClient(client: Client[F]): Builder[F] - /** Creates a [[OtlpHttpSpanExporter]] using the configuration of this - * builder. + /** Creates a [[OtlpHttpSpanExporter]] using the configuration of this builder. */ def build: Resource[F, SpanExporter[F]] } - /** Creates a [[Builder]] of [[OtlpHttpSpanExporter]] with the default - * configuration: + /** Creates a [[Builder]] of [[OtlpHttpSpanExporter]] with the default configuration: * - encoding: `Protobuf` * - endpoint: `http://localhost:4318/v1/traces` * - timeout: `10 seconds` - * - retry policy: 5 exponential attempts, initial backoff is `1 second`, - * max backoff is `5 seconds` + * - retry policy: 5 exponential attempts, initial backoff is `1 second`, max backoff is `5 seconds` */ def builder[F[_]: Async: Network: Compression: Console]: Builder[F] = BuilderImpl( diff --git a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/SpansProtoEncoder.scala b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/SpansProtoEncoder.scala index 3658bb6df..4fa0d7d77 100644 --- a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/SpansProtoEncoder.scala +++ b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/SpansProtoEncoder.scala @@ -46,11 +46,9 @@ private object SpansProtoEncoder { implicit val jsonPrinter: Printer = new ProtoEncoder.JsonPrinter { private val EncodeAsHex = Set("trace_id", "span_id", "parent_span_id") - /** The `traceId` and `spanId` byte arrays are represented as - * case-insensitive hex-encoded strings; they are not base64-encoded as is - * defined in the standard Protobuf JSON Mapping. Hex encoding is used for - * traceId and spanId fields in all OTLP Protobuf messages, e.g., the Span, - * Link, LogRecord, etc. messages. + /** The `traceId` and `spanId` byte arrays are represented as case-insensitive hex-encoded strings; they are not + * base64-encoded as is defined in the standard Protobuf JSON Mapping. Hex encoding is used for traceId and spanId + * fields in all OTLP Protobuf messages, e.g., the Span, Link, LogRecord, etc. messages. * * @see * [[https://github.com/open-telemetry/opentelemetry-proto/blob/v1.0.0/docs/specification.md#json-protobuf-encoding]] @@ -86,38 +84,35 @@ private object SpansProtoEncoder { case SpanKind.Consumer => SpanProto.SpanKind.SPAN_KIND_CONSUMER } - implicit val statusDataEncoder: ProtoEncoder[StatusData, StatusProto] = { - data => - StatusProto( - message = data.description.getOrElse(""), - code = ProtoEncoder.encode(data.status) - ) + implicit val statusDataEncoder: ProtoEncoder[StatusData, StatusProto] = { data => + StatusProto( + message = data.description.getOrElse(""), + code = ProtoEncoder.encode(data.status) + ) } - implicit val eventDataEncoder: ProtoEncoder[EventData, SpanProto.Event] = { - data => - SpanProto.Event( - timeUnixNano = data.timestamp.toNanos, - name = data.name, - attributes = ProtoEncoder.encode(data.attributes.elements), - droppedAttributesCount = data.attributes.dropped - ) + implicit val eventDataEncoder: ProtoEncoder[EventData, SpanProto.Event] = { data => + SpanProto.Event( + timeUnixNano = data.timestamp.toNanos, + name = data.name, + attributes = ProtoEncoder.encode(data.attributes.elements), + droppedAttributesCount = data.attributes.dropped + ) } - implicit val linkDataEncoder: ProtoEncoder[LinkData, SpanProto.Link] = { - data => - val traceState = data.spanContext.traceState.asMap - .map { case (key, value) => s"$key=$value" } - .mkString(",") - - SpanProto.Link( - traceId = ByteString.copyFrom(data.spanContext.traceId.toArray), - spanId = ByteString.copyFrom(data.spanContext.spanId.toArray), - traceState = traceState, - attributes = ProtoEncoder.encode(data.attributes.elements), - droppedAttributesCount = data.attributes.dropped, - flags = data.spanContext.traceFlags.toByte.toInt - ) + implicit val linkDataEncoder: ProtoEncoder[LinkData, SpanProto.Link] = { data => + val traceState = data.spanContext.traceState.asMap + .map { case (key, value) => s"$key=$value" } + .mkString(",") + + SpanProto.Link( + traceId = ByteString.copyFrom(data.spanContext.traceId.toArray), + spanId = ByteString.copyFrom(data.spanContext.spanId.toArray), + traceState = traceState, + attributes = ProtoEncoder.encode(data.attributes.elements), + droppedAttributesCount = data.attributes.dropped, + flags = data.spanContext.traceFlags.toByte.toInt + ) } implicit val spanDataEncoder: ProtoEncoder[SpanData, SpanProto] = { span => @@ -147,8 +142,7 @@ private object SpansProtoEncoder { ) } - implicit val spanDataToRequest - : ProtoEncoder[List[SpanData], ExportTraceServiceRequest] = { spans => + implicit val spanDataToRequest: ProtoEncoder[List[SpanData], ExportTraceServiceRequest] = { spans => val resourceSpans = spans .groupBy(_.resource) diff --git a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigure.scala b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigure.scala index 608cade2d..4045ed786 100644 --- a/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigure.scala +++ b/sdk-exporter/trace/src/main/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigure.scala @@ -32,8 +32,7 @@ import org.typelevel.otel4s.sdk.exporter.otlp.autoconfigure.ProtocolAutoConfigur import org.typelevel.otel4s.sdk.trace.data.SpanData import org.typelevel.otel4s.sdk.trace.exporter.SpanExporter -/** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. +/** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. * * @see * [[ProtocolAutoConfigure]] for OTLP protocol configuration @@ -56,62 +55,53 @@ private final class OtlpSpanExporterAutoConfigure[ def name: String = "otlp" protected def fromConfig(config: Config): Resource[F, SpanExporter[F]] = - ProtocolAutoConfigure.traces[F].configure(config).flatMap { - case Protocol.Http(encoding) => - import SpansProtoEncoder.spanDataToRequest - import SpansProtoEncoder.jsonPrinter + ProtocolAutoConfigure.traces[F].configure(config).flatMap { case Protocol.Http(encoding) => + import SpansProtoEncoder.spanDataToRequest + import SpansProtoEncoder.jsonPrinter - val defaults = OtlpHttpClientAutoConfigure.Defaults( - OtlpHttpSpanExporter.Defaults.Endpoint, - OtlpHttpSpanExporter.Defaults.Endpoint.path.toString, - Headers.empty, - OtlpHttpSpanExporter.Defaults.Timeout, - encoding - ) + val defaults = OtlpHttpClientAutoConfigure.Defaults( + OtlpHttpSpanExporter.Defaults.Endpoint, + OtlpHttpSpanExporter.Defaults.Endpoint.path.toString, + Headers.empty, + OtlpHttpSpanExporter.Defaults.Timeout, + encoding + ) - OtlpHttpClientAutoConfigure - .traces[F, SpanData](defaults, customClient) - .configure(config) - .map(client => new OtlpHttpSpanExporter[F](client)) + OtlpHttpClientAutoConfigure + .traces[F, SpanData](defaults, customClient) + .configure(config) + .map(client => new OtlpHttpSpanExporter[F](client)) } } object OtlpSpanExporterAutoConfigure { - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. * - * The configuration depends on the `otel.exporter.otlp.protocol` or - * `otel.exporter.otlp.traces.protocol`. + * The configuration depends on the `otel.exporter.otlp.protocol` or `otel.exporter.otlp.traces.protocol`. * * The supported protocols: `http/json`, `http/protobuf`. * * @see - * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP - * HTTP client + * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP HTTP client */ def apply[ F[_]: Async: Network: Compression: Console ]: AutoConfigure.Named[F, SpanExporter[F]] = new OtlpSpanExporterAutoConfigure[F](None) - /** Autoconfigures OTLP - * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]] - * using the given client. + /** Autoconfigures OTLP [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]] using the given client. * - * The configuration depends on the `otel.exporter.otlp.protocol` or - * `otel.exporter.otlp.traces.protocol`. + * The configuration depends on the `otel.exporter.otlp.protocol` or `otel.exporter.otlp.traces.protocol`. * * The supported protocols: `http/json`, `http/protobuf`. * * @see - * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP - * HTTP client + * `OtlpHttpClientAutoConfigure` for the configuration details of the OTLP HTTP client * * @note - * the 'timeout' and 'tlsContext' settings will be ignored. You must - * preconfigure the client manually. + * the 'timeout' and 'tlsContext' settings will be ignored. You must preconfigure the client manually. * * @example * {{{ diff --git a/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporterSuite.scala b/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporterSuite.scala index f7826cd27..27a748789 100644 --- a/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporterSuite.scala +++ b/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/OtlpHttpSpanExporterSuite.scala @@ -43,10 +43,7 @@ import org.typelevel.otel4s.trace.StatusCode import java.util.Locale import scala.concurrent.duration._ -class OtlpHttpSpanExporterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite - with SuiteRuntimePlatform { +class OtlpHttpSpanExporterSuite extends CatsEffectSuite with ScalaCheckEffectSuite with SuiteRuntimePlatform { import OtlpHttpSpanExporterSuite._ diff --git a/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigureSuite.scala b/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigureSuite.scala index 99e0bc027..d4f55610d 100644 --- a/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigureSuite.scala +++ b/sdk-exporter/trace/src/test/scala/org/typelevel/otel4s/sdk/exporter/otlp/trace/autoconfigure/OtlpSpanExporterAutoConfigureSuite.scala @@ -23,9 +23,7 @@ import cats.syntax.foldable._ import munit.CatsEffectSuite import org.typelevel.otel4s.sdk.autoconfigure.Config -class OtlpSpanExporterAutoConfigureSuite - extends CatsEffectSuite - with SuiteRuntimePlatform { +class OtlpSpanExporterAutoConfigureSuite extends CatsEffectSuite with SuiteRuntimePlatform { test("load from the config - empty config - load default") { val config = Config.ofProps(Map.empty) diff --git a/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdk.scala b/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdk.scala index 4c3e26e5d..b661616c5 100644 --- a/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdk.scala +++ b/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdk.scala @@ -70,8 +70,8 @@ object OpenTelemetrySdk { /** Autoconfigures [[OpenTelemetrySdk]] using [[AutoConfigured.Builder]]. * * @note - * the external components (e.g. OTLP exporter) must be registered - * manually. Add the `otel4s-sdk-exporter` dependency to the sbt file: + * the external components (e.g. OTLP exporter) must be registered manually. Add the `otel4s-sdk-exporter` + * dependency to the sbt file: * {{{ * libraryDependencies += "org.typelevel" %%% "otel4s-sdk-exporter" % "x.x.x" * }}} @@ -87,8 +87,7 @@ object OpenTelemetrySdk { * a function for customizing the auto-configured SDK builder */ def autoConfigured[F[_]: Async: Parallel: Console: LocalContextProvider]( - customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = - (a: AutoConfigured.Builder[F]) => a + customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = (a: AutoConfigured.Builder[F]) => a ): Resource[F, AutoConfigured[F]] = customize(AutoConfigured.builder[F]).build @@ -135,25 +134,24 @@ object OpenTelemetrySdk { /** Sets the given config to use when resolving properties. * * @note - * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no - * effect if the custom config is provided. + * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no effect if the custom config is + * provided. * * @param config * the config to use */ def withConfig(config: Config): Builder[F] - /** Adds the properties loader. Multiple loaders will be added. The loaded - * properties will be merged with the default config. Loaded properties - * take precedence over the default ones. + /** Adds the properties loader. Multiple loaders will be added. The loaded properties will be merged with the + * default config. Loaded properties take precedence over the default ones. * * @param loader * the additional loader to add */ def addPropertiesLoader(loader: F[Map[String, String]]): Builder[F] - /** Adds the properties customizer. Multiple customizers can be added, and - * they will be applied in the order they were added. + /** Adds the properties customizer. Multiple customizers can be added, and they will be applied in the order they + * were added. * * @param customizer * the customizer to add @@ -162,8 +160,8 @@ object OpenTelemetrySdk { customizer: Config => Map[String, String] ): Builder[F] - /** Adds the meter provider builder customizer. Multiple customizers can - * be added, and they will be applied in the order they were added. + /** Adds the meter provider builder customizer. Multiple customizers can be added, and they will be applied in the + * order they were added. * * @param customizer * the customizer to add @@ -172,8 +170,8 @@ object OpenTelemetrySdk { customizer: Customizer[SdkMeterProvider.Builder[F]] ): Builder[F] - /** Adds the tracer provider builder customizer. Multiple customizers can - * be added, and they will be applied in the order they were added. + /** Adds the tracer provider builder customizer. Multiple customizers can be added, and they will be applied in + * the order they were added. * * @param customizer * the customizer to add @@ -182,8 +180,8 @@ object OpenTelemetrySdk { customizer: Customizer[SdkTracerProvider.Builder[F]] ): Builder[F] - /** Adds the telemetry resource customizer. Multiple customizers can be - * added, and they will be applied in the order they were added. + /** Adds the telemetry resource customizer. Multiple customizers can be added, and they will be applied in the + * order they were added. * * @param customizer * the customizer to add @@ -192,17 +190,15 @@ object OpenTelemetrySdk { customizer: Customizer[TelemetryResource] ): Builder[F] - /** Adds the telemetry resource detector. Multiple detectors can be added, - * and the detected telemetry resources will be merged. + /** Adds the telemetry resource detector. Multiple detectors can be added, and the detected telemetry resources + * will be merged. * * By default, the following detectors are enabled: * - host: `host.arch`, `host.name` * - os: `os.type`, `os.description` - * - process: `process.command`, `process.command_args`, - * `process.command_line`, `process.executable.name`, + * - process: `process.command`, `process.command_args`, `process.command_line`, `process.executable.name`, * `process.executable.path`, `process.pid`, `process.owner` - * - process_runtime: `process.runtime.name`, - * `process.runtime.version`, `process.runtime.description` + * - process_runtime: `process.runtime.name`, `process.runtime.version`, `process.runtime.description` * * @param detector * the detector to add @@ -211,8 +207,8 @@ object OpenTelemetrySdk { detector: TelemetryResourceDetector[F] ): Builder[F] - /** Adds both metric and span exporter configurers. Can be used to - * register exporters that aren't included in the SDK. + /** Adds both metric and span exporter configurers. Can be used to register exporters that aren't included in the + * SDK. * * @example * Add the `otel4s-sdk-exporter` dependency to the build file: @@ -234,8 +230,7 @@ object OpenTelemetrySdk { configurer: ExportersAutoConfigure[F] ): Builder[F] - /** Adds the exporter configurer. Can be used to register exporters that - * aren't included in the SDK. + /** Adds the exporter configurer. Can be used to register exporters that aren't included in the SDK. * * @example * Add the `otel4s-sdk-exporter` dependency to the build file: @@ -257,8 +252,7 @@ object OpenTelemetrySdk { configurer: AutoConfigure.Named[F, MetricExporter[F]] ): Builder[F] - /** Adds the exporter configurer. Can be used to register exporters that - * aren't included in the SDK. + /** Adds the exporter configurer. Can be used to register exporters that aren't included in the SDK. * * @example * Add the `otel4s-sdk-exporter` dependency to the build file: @@ -280,8 +274,7 @@ object OpenTelemetrySdk { configurer: AutoConfigure.Named[F, SpanExporter[F]] ): Builder[F] - /** Adds the sampler configurer. Can be used to register samplers that - * aren't included in the SDK. + /** Adds the sampler configurer. Can be used to register samplers that aren't included in the SDK. * * @param configurer * the configurer to add @@ -290,8 +283,7 @@ object OpenTelemetrySdk { configurer: AutoConfigure.Named[F, Sampler] ): Builder[F] - /** Adds the text map propagator configurer. Can be used to register - * propagators that aren't included in the SDK. + /** Adds the text map propagator configurer. Can be used to register propagators that aren't included in the SDK. * * @param configurer * the configurer to add @@ -365,16 +357,12 @@ object OpenTelemetrySdk { def addMeterProviderCustomizer( customizer: Customizer[SdkMeterProvider.Builder[F]] ): Builder[F] = - copy(meterProviderCustomizer = - merge(this.meterProviderCustomizer, customizer) - ) + copy(meterProviderCustomizer = merge(this.meterProviderCustomizer, customizer)) def addTracerProviderCustomizer( customizer: Customizer[SdkTracerProvider.Builder[F]] ): Builder[F] = - copy(tracerProviderCustomizer = - merge(this.tracerProviderCustomizer, customizer) - ) + copy(tracerProviderCustomizer = merge(this.tracerProviderCustomizer, customizer)) def addResourceDetector( detector: TelemetryResourceDetector[F] @@ -385,10 +373,8 @@ object OpenTelemetrySdk { configurer: ExportersAutoConfigure[F] ): Builder[F] = copy( - metricExporterConfigurers = - metricExporterConfigurers + configurer.metricExporterAutoConfigure, - spanExporterConfigurers = - spanExporterConfigurers + configurer.spanExporterAutoConfigure + metricExporterConfigurers = metricExporterConfigurers + configurer.metricExporterAutoConfigure, + spanExporterConfigurers = spanExporterConfigurers + configurer.spanExporterAutoConfigure ) def addMetricExporterConfigurer( @@ -409,18 +395,14 @@ object OpenTelemetrySdk { def addTextMapPropagatorConfigurer( configurer: AutoConfigure.Named[F, TextMapPropagator[Context]] ): Builder[F] = - copy(textMapPropagatorConfigurers = - textMapPropagatorConfigurers + configurer - ) + copy(textMapPropagatorConfigurers = textMapPropagatorConfigurers + configurer) def build: Resource[F, AutoConfigured[F]] = { def loadConfig: F[Config] = for { props <- propertiesLoader config <- Config.load(props) - } yield propertiesCustomizers.foldLeft(config)((cfg, c) => - cfg.withOverrides(c(cfg)) - ) + } yield propertiesCustomizers.foldLeft(config)((cfg, c) => cfg.withOverrides(c(cfg))) def loadNoop(config: Config): Resource[F, AutoConfigured[F]] = Resource.eval( diff --git a/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/ExportersAutoConfigure.scala b/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/ExportersAutoConfigure.scala index 92c121450..8eddcca49 100644 --- a/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/ExportersAutoConfigure.scala +++ b/sdk/all/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/ExportersAutoConfigure.scala @@ -23,13 +23,11 @@ import org.typelevel.otel4s.sdk.trace.exporter.SpanExporter */ sealed trait ExportersAutoConfigure[F[_]] { - /** Configures - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. + /** Configures [[org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter MetricExporter]]. */ def metricExporterAutoConfigure: AutoConfigure.Named[F, MetricExporter[F]] - /** Configures - * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. + /** Configures [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter SpanExporter]]. */ def spanExporterAutoConfigure: AutoConfigure.Named[F, SpanExporter[F]] } diff --git a/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdkSuite.scala b/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdkSuite.scala index 9e9974c54..c31fb601e 100644 --- a/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdkSuite.scala +++ b/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/OpenTelemetrySdkSuite.scala @@ -135,9 +135,7 @@ class OpenTelemetrySdkSuite extends CatsEffectSuite { OpenTelemetrySdk .autoConfigured[IO]( - _.withConfig(config).addTracerProviderCustomizer((t, _) => - t.withSampler(sampler) - ) + _.withConfig(config).addTracerProviderCustomizer((t, _) => t.withSampler(sampler)) ) .use { traces => IO(assertEquals(traces.toString, sdkToString(sampler = sampler))) @@ -314,9 +312,7 @@ class OpenTelemetrySdkSuite extends CatsEffectSuite { OpenTelemetrySdk .autoConfigured[IO]( - _.withConfig(config).addMeterProviderCustomizer((t, _) => - t.registerView(selector, view) - ) + _.withConfig(config).addMeterProviderCustomizer((t, _) => t.registerView(selector, view)) ) .use { traces => IO( diff --git a/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTracerSuite.scala b/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTracerSuite.scala index 2e4c89933..f724fa772 100644 --- a/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTracerSuite.scala +++ b/sdk/all/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTracerSuite.scala @@ -82,9 +82,7 @@ class SdkTracerSuite extends BaseTracerSuite[Context, Context.Key] { } sdkTest("set error status on abnormal termination (exception)") { sdk => - final case class Err(reason: String) - extends RuntimeException(reason) - with NoStackTrace + final case class Err(reason: String) extends RuntimeException(reason) with NoStackTrace val exception = Err("error") diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/TelemetryResource.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/TelemetryResource.scala index e46d25dfb..2826746ad 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/TelemetryResource.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/TelemetryResource.scala @@ -24,9 +24,8 @@ import org.typelevel.otel4s.sdk.TelemetryResource.ResourceInitializationError import org.typelevel.otel4s.semconv.attributes.ServiceAttributes import org.typelevel.otel4s.semconv.attributes.TelemetryAttributes -/** [[TelemetryResource]] serves as a representation of a resource that captures - * essential identifying information regarding the entities associated with - * reported signals, such as statistics or traces. +/** [[TelemetryResource]] serves as a representation of a resource that captures essential identifying information + * regarding the entities associated with reported signals, such as statistics or traces. * * @see * [[https://opentelemetry.io/docs/specs/otel/overview/#resources]] @@ -47,21 +46,17 @@ sealed trait TelemetryResource { /** Merges [[TelemetryResource]] into another [[TelemetryResource]]. * * Schema URL merge outcomes: - * - if `this` resource's schema URL is empty then the `other` resource's - * schema URL will be selected + * - if `this` resource's schema URL is empty then the `other` resource's schema URL will be selected * - * - if `other` resource's schema URL is empty then `this` resource's - * schema URL will be selected + * - if `other` resource's schema URL is empty then `this` resource's schema URL will be selected * - * - if `this` and `other` resources have the same non-empty schema URL - * then this schema URL will be selected + * - if `this` and `other` resources have the same non-empty schema URL then this schema URL will be selected * - * - if `this` and `other` resources have different non-empty schema URLs - * then the result will be a merge error + * - if `this` and `other` resources have different non-empty schema URLs then the result will be a merge error * * @note - * if the same attribute exists in both resources, the attribute from the - * `other` [[TelemetryResource]] will be retained. + * if the same attribute exists in both resources, the attribute from the `other` [[TelemetryResource]] will be + * retained. * * @param other * the other [[TelemetryResource]] to merge with @@ -120,8 +115,7 @@ object TelemetryResource { case object SchemaUrlConflict extends ResourceInitializationError } - /** Creates a [[TelemetryResource]] with the given `attributes`. The - * `schemaUrl` will be `None.` + /** Creates a [[TelemetryResource]] with the given `attributes`. The `schemaUrl` will be `None.` * * @param attributes * the attributes to associate with the resource @@ -129,8 +123,7 @@ object TelemetryResource { def apply(attributes: Attributes): TelemetryResource = Impl(attributes, None) - /** Creates a [[TelemetryResource]] with the given `attributes` and - * `schemaUrl`. + /** Creates a [[TelemetryResource]] with the given `attributes` and `schemaUrl`. * * @param attributes * the attributes to associate with the resource @@ -145,19 +138,17 @@ object TelemetryResource { /** Returns an empty [[TelemetryResource]]. * - * It is strongly recommended to start with [[TelemetryResource.default]] - * instead of this method to include SDK required attributes. + * It is strongly recommended to start with [[TelemetryResource.default]] instead of this method to include SDK + * required attributes. */ def empty: TelemetryResource = Empty - /** Returns the default [[TelemetryResource]]. This resource contains the - * default attributes provided by the SDK. + /** Returns the default [[TelemetryResource]]. This resource contains the default attributes provided by the SDK. */ def default: TelemetryResource = Default implicit val showResource: Show[TelemetryResource] = - r => - show"TelemetryResource{attributes=${r.attributes}, schemaUrl=${r.schemaUrl}}" + r => show"TelemetryResource{attributes=${r.attributes}, schemaUrl=${r.schemaUrl}}" implicit val hashResource: Hash[TelemetryResource] = Hash.by(r => (r.attributes, r.schemaUrl)) diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigure.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigure.scala index 1b4c93d9f..093a95099 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigure.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigure.scala @@ -34,11 +34,9 @@ trait AutoConfigure[F[_], A] { object AutoConfigure { - /** A component that must be associated with a specific name. Can be used for - * ad-hoc loading. + /** A component that must be associated with a specific name. Can be used for ad-hoc loading. * - * See `PropagatorsAutoConfigure` and `SpanExportersAutoConfigure` for more - * examples. + * See `PropagatorsAutoConfigure` and `SpanExportersAutoConfigure` for more examples. * * @tparam F * the higher-kinded type of a polymorphic effect @@ -76,8 +74,8 @@ object AutoConfigure { } - /** If the component cannot be created due to an error, the meaningful debug - * information will be added to the exception. + /** If the component cannot be created due to an error, the meaningful debug information will be added to the + * exception. * * @param hint * the name of the component. For example: Sampler, TelemetryResource @@ -99,7 +97,7 @@ object AutoConfigure { final def configure(config: Config): Resource[F, A] = fromConfig(config).adaptError { case e: AutoConfigureError => e - case cause => AutoConfigureError(hint, cause, configKeys, config) + case cause => AutoConfigureError(hint, cause, configKeys, config) } protected def fromConfig(config: Config): Resource[F, A] diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureError.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureError.scala index 599da0a1f..158a528f1 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureError.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureError.scala @@ -40,9 +40,8 @@ object AutoConfigureError { cause ) - /** Creates an [[AutoConfigureError]] with the given `hint` and `cause`. The - * debug information associated with the `configKeys` will be added to the - * message. + /** Creates an [[AutoConfigureError]] with the given `hint` and `cause`. The debug information associated with the + * `configKeys` will be added to the message. * * @param hint * the name of the component diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/Config.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/Config.scala index ddbdac2d9..76c0996b2 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/Config.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/autoconfigure/Config.scala @@ -39,13 +39,11 @@ sealed trait Config { * the type of a value * * @return - * - `Left(ConfigurationError)` - when the key exists in the config but - * cannot be decoded as `A` + * - `Left(ConfigurationError)` - when the key exists in the config but cannot be decoded as `A` * * - `Right(None)` - when the key does not exist in the config * - * - `Right(Some(a))` - when the key exists in the config and successfully - * decoded as `A` + * - `Right(Some(a))` - when the key exists in the config and successfully decoded as `A` */ def get[A: Config.Reader](key: String): Either[ConfigurationError, Option[A]] @@ -75,13 +73,11 @@ sealed trait Config { * the type of a value * * @return - * - `Left(ConfigurationError)` - when the key exists in the config but - * cannot be decoded as `A` + * - `Left(ConfigurationError)` - when the key exists in the config but cannot be decoded as `A` * * - `Right(None)` - when the key does not exist in the config * - * - `Right(Some(a))` - when the key exists in the config and successfully - * decoded as `A` + * - `Right(Some(a))` - when the key exists in the config and successfully decoded as `A` */ final def get[A: Config.Reader]( key: Config.Key[A] @@ -236,8 +232,7 @@ object Config { } - /** Creates a [[Config]] with the given properties. The keys of the properties - * will be normalized. + /** Creates a [[Config]] with the given properties. The keys of the properties will be normalized. * * The priorities of the values: system properties > env variables > default. * @@ -270,8 +265,7 @@ object Config { Impl(default ++ env ++ props) } - /** Creates a [[Config]] with the given properties. The properties will be - * treated as the system props. + /** Creates a [[Config]] with the given properties. The properties will be treated as the system props. * * @param properties * the properties to use @@ -279,8 +273,7 @@ object Config { def ofProps(properties: Map[String, String]): Config = apply(properties, Map.empty, Map.empty) - /** Creates a [[Config]] by loading properties from the env variables and - * system props. + /** Creates a [[Config]] by loading properties from the env variables and system props. * * @param default * the default properties @@ -308,14 +301,12 @@ object Config { } - /** Normalizes a property key by converting to lower case and replacing "-" - * with ".". + /** Normalizes a property key by converting to lower case and replacing "-" with ".". */ private def normalizePropertyKey(key: String): String = key.toLowerCase.replace("-", "."); - /** Normalizes an env variable key by converting to lower case and replacing - * "_" with ".". + /** Normalizes an env variable key by converting to lower case and replacing "_" with ".". */ private def normalizeEnvVariableKey(key: String): String = key.toLowerCase.replace("_", ".") diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/common/InstrumentationScope.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/common/InstrumentationScope.scala index f6be95654..61287576f 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/common/InstrumentationScope.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/common/InstrumentationScope.scala @@ -24,11 +24,9 @@ import cats.syntax.show._ /** Holds information about instrumentation scope. * - * Instrumentation scope is a logical unit of the application code with which - * emitted telemetry is associated. The most common approach is to use the - * instrumentation library as the scope, however other scopes are also common, - * e.g. a module, a package, or a class may be chosen as the instrumentation - * scope. + * Instrumentation scope is a logical unit of the application code with which emitted telemetry is associated. The most + * common approach is to use the instrumentation library as the scope, however other scopes are also common, e.g. a + * module, a package, or a class may be chosen as the instrumentation scope. * * @see * [[https://opentelemetry.io/docs/specs/otel/glossary/#instrumentation-scope Instrumentation Scope spec]] @@ -39,13 +37,11 @@ sealed trait InstrumentationScope { */ def name: String - /** Returns the version of the instrumentation scope, or None if not - * available. + /** Returns the version of the instrumentation scope, or None if not available. */ def version: Option[String] - /** Returns the URL of the schema used by this instrumentation scope, or None - * if not available. + /** Returns the URL of the schema used by this instrumentation scope, or None if not available. */ def schemaUrl: Option[String] @@ -90,16 +86,14 @@ object InstrumentationScope { /** Assigns the attributes to the scope. * - * '''Note''': if called multiple times, only the last specified attributes - * will be used. + * '''Note''': if called multiple times, only the last specified attributes will be used. * * @param attributes * the attributes to assign */ def withAttributes(attributes: Attributes): Builder - /** Creates an [[InstrumentationScope]] with the configuration of this - * builder. + /** Creates an [[InstrumentationScope]] with the configuration of this builder. */ def build: InstrumentationScope } @@ -124,8 +118,7 @@ object InstrumentationScope { * the name of the instrumentation scope * * @param version - * the version of the instrumentation scope if the scope has a version - * (e.g. a library version) + * the version of the instrumentation scope if the scope has a version (e.g. a library version) * * @param schemaUrl * the Schema URL that should be recorded in the emitted telemetry diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/context/Context.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/context/Context.scala index 0be4d10b0..72842ca27 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/context/Context.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/context/Context.scala @@ -28,13 +28,11 @@ import cats.effect.kernel.Unique */ sealed trait Context { - /** Retrieves the value associated with the given `key` from the context, if - * such a value exists. + /** Retrieves the value associated with the given `key` from the context, if such a value exists. */ def get[A](key: Context.Key[A]): Option[A] - /** Creates a copy of this context with the given `value` associated with the - * given `key`. + /** Creates a copy of this context with the given `value` associated with the given `key`. */ def updated[A](key: Context.Key[A], value: A): Context diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/internal/ComponentRegistry.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/internal/ComponentRegistry.scala index 52c07a9b2..ca22f10ba 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/internal/ComponentRegistry.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/internal/ComponentRegistry.scala @@ -34,13 +34,12 @@ import org.typelevel.otel4s.sdk.common.InstrumentationScope */ private[sdk] sealed trait ComponentRegistry[F[_], A] { - /** Returns the component associated with the `name`, `version`, and - * `schemaUrl`. + /** Returns the component associated with the `name`, `version`, and `schemaUrl`. * * '''Note''': `attributes` are not part of component identity. * - * Behavior is undefined when different `attributes` are provided where - * `name`, `version`, and `schemaUrl` are identical. + * Behavior is undefined when different `attributes` are provided where `name`, `version`, and `schemaUrl` are + * identical. * * @param name * the name to associate with a component @@ -69,8 +68,8 @@ private[sdk] sealed trait ComponentRegistry[F[_], A] { private[sdk] object ComponentRegistry { - /** Creates a [[ComponentRegistry]] that uses `buildComponent` to build a - * component if it is not already present in the cache. + /** Creates a [[ComponentRegistry]] that uses `buildComponent` to build a component if it is not already present in + * the cache. * * @param buildComponent * how to build a component diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/ProcessDetector.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/ProcessDetector.scala index 6e150b110..11ed422c5 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/ProcessDetector.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/ProcessDetector.scala @@ -18,8 +18,7 @@ package org.typelevel.otel4s.sdk.resource import org.typelevel.otel4s.AttributeKey -/** Detects process-specific parameters such as executable name, executable - * path, PID, and so on. +/** Detects process-specific parameters such as executable name, executable path, PID, and so on. * * @see * [[https://opentelemetry.io/docs/specs/semconv/resource/process/]] diff --git a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/TelemetryResourceDetector.scala b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/TelemetryResourceDetector.scala index 880e307bd..531e42402 100644 --- a/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/TelemetryResourceDetector.scala +++ b/sdk/common/shared/src/main/scala/org/typelevel/otel4s/sdk/resource/TelemetryResourceDetector.scala @@ -20,13 +20,11 @@ package resource import cats.effect.Sync -/** A detector creates a resource with environment(platform)-specific - * attributes. +/** A detector creates a resource with environment(platform)-specific attributes. * * @note - * a detector that populates resource attributes according to OpenTelemetry - * semantic conventions MUST ensure that the resource has a Schema URL set to - * a value that matches the semantic conventions. + * a detector that populates resource attributes according to OpenTelemetry semantic conventions MUST ensure that the + * resource has a Schema URL set to a value that matches the semantic conventions. * * @see * [[https://opentelemetry.io/docs/specs/otel/resource/sdk/#detecting-resource-information-from-the-environment]] diff --git a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureSuite.scala b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureSuite.scala index 0132d8596..964e930ea 100644 --- a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureSuite.scala +++ b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/autoconfigure/AutoConfigureSuite.scala @@ -62,8 +62,6 @@ class AutoConfigureSuite extends CatsEffectSuite { } } - private object Err - extends RuntimeException("Something went wrong") - with NoStackTrace + private object Err extends RuntimeException("Something went wrong") with NoStackTrace } diff --git a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/context/ContextSuite.scala b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/context/ContextSuite.scala index 758953a6e..5e0ba935b 100644 --- a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/context/ContextSuite.scala +++ b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/context/ContextSuite.scala @@ -53,10 +53,9 @@ class ContextSuite extends DisciplineSuite { } test("override values in the context") { - Prop.forAll(keyGen[String], Gen.alphaNumStr, Gen.alphaNumStr) { - case (key, value1, value2) => - val ctx = Context.root.updated(key, value1).updated(key, value2) - assertEquals(ctx.get(key), Some(value2)) + Prop.forAll(keyGen[String], Gen.alphaNumStr, Gen.alphaNumStr) { case (key, value1, value2) => + val ctx = Context.root.updated(key, value1).updated(key, value2) + assertEquals(ctx.get(key), Some(value2)) } } diff --git a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/test/InMemoryConsole.scala b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/test/InMemoryConsole.scala index 279822882..f1101cb27 100644 --- a/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/test/InMemoryConsole.scala +++ b/sdk/common/shared/src/test/scala/org/typelevel/otel4s/sdk/test/InMemoryConsole.scala @@ -25,8 +25,7 @@ import cats.syntax.all._ import java.nio.charset.Charset -class InMemoryConsole[F[_]: Sync](queue: Queue[F, InMemoryConsole.Entry]) - extends Console[F] { +class InMemoryConsole[F[_]: Sync](queue: Queue[F, InMemoryConsole.Entry]) extends Console[F] { import InMemoryConsole.Entry import InMemoryConsole.Op diff --git a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricExporter.scala b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricExporter.scala index 265782d2f..84a2b61d3 100644 --- a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricExporter.scala +++ b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricExporter.scala @@ -61,23 +61,18 @@ object InMemoryMetricExporter { * the preferred aggregation for the given instrument type * * @param defaultAggregationSelector - * the preferred aggregation for the given instrument type. If no views are - * configured for a metric instrument, an aggregation provided by the - * selector will be used. + * the preferred aggregation for the given instrument type. If no views are configured for a metric instrument, an + * aggregation provided by the selector will be used. * * @param defaultCardinalityLimitSelector - * the preferred cardinality limit for the given instrument type. If no - * views are configured for a metric instrument, an aggregation provided by - * the selector will be used. + * the preferred cardinality limit for the given instrument type. If no views are configured for a metric + * instrument, an aggregation provided by the selector will be used. */ def create[F[_]: Concurrent]( capacity: Option[Int], - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, - defaultAggregationSelector: AggregationSelector = - AggregationSelector.default, - defaultCardinalityLimitSelector: CardinalityLimitSelector = - CardinalityLimitSelector.default + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, + defaultAggregationSelector: AggregationSelector = AggregationSelector.default, + defaultCardinalityLimitSelector: CardinalityLimitSelector = CardinalityLimitSelector.default ): F[InMemoryMetricExporter[F]] = for { queue <- capacity.fold(Queue.unbounded[F, MetricData])(Queue.bounded(_)) diff --git a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricReader.scala b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricReader.scala index 4783c138b..09189ca2a 100644 --- a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricReader.scala +++ b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/InMemoryMetricReader.scala @@ -57,22 +57,17 @@ object InMemoryMetricReader { * the preferred aggregation for the given instrument type * * @param defaultAggregationSelector - * the preferred aggregation for the given instrument type. If no views are - * configured for a metric instrument, an aggregation provided by the - * selector will be used. + * the preferred aggregation for the given instrument type. If no views are configured for a metric instrument, an + * aggregation provided by the selector will be used. * * @param defaultCardinalityLimitSelector - * the preferred cardinality limit for the given instrument type. If no - * views are configured for a metric instrument, an aggregation provided by - * the selector will be used. + * the preferred cardinality limit for the given instrument type. If no views are configured for a metric + * instrument, an aggregation provided by the selector will be used. */ def create[F[_]: Concurrent]( - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, - defaultAggregationSelector: AggregationSelector = - AggregationSelector.default, - defaultCardinalityLimitSelector: CardinalityLimitSelector = - CardinalityLimitSelector.default + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, + defaultAggregationSelector: AggregationSelector = AggregationSelector.default, + defaultCardinalityLimitSelector: CardinalityLimitSelector = CardinalityLimitSelector.default ): F[InMemoryMetricReader[F]] = for { producers <- Ref.empty[F, Vector[MetricProducer[F]]] diff --git a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/MetricsTestkit.scala b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/MetricsTestkit.scala index baaf5e443..7a498d97d 100644 --- a/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/MetricsTestkit.scala +++ b/sdk/metrics-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/metrics/MetricsTestkit.scala @@ -53,8 +53,7 @@ object MetricsTestkit { /** Creates [[MetricsTestkit]] that keeps metrics in-memory. * * @note - * the implementation does not record exemplars. Use - * `OpenTelemetrySdkTestkit` if you need to record exemplars. + * the implementation does not record exemplars. Use `OpenTelemetrySdkTestkit` if you need to record exemplars. * * @param customize * the customization of the builder @@ -63,24 +62,18 @@ object MetricsTestkit { * the preferred aggregation for the given instrument type * * @param defaultAggregationSelector - * the preferred aggregation for the given instrument type. If no views are - * configured for a metric instrument, an aggregation provided by the - * selector will be used + * the preferred aggregation for the given instrument type. If no views are configured for a metric instrument, an + * aggregation provided by the selector will be used * * @param defaultCardinalityLimitSelector - * the preferred cardinality limit for the given instrument type. If no - * views are configured for a metric instrument, a limit provided by the - * selector will be used + * the preferred cardinality limit for the given instrument type. If no views are configured for a metric + * instrument, a limit provided by the selector will be used */ def inMemory[F[_]: Async: Console]( - customize: SdkMeterProvider.Builder[F] => SdkMeterProvider.Builder[F] = - (b: SdkMeterProvider.Builder[F]) => b, - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, - defaultAggregationSelector: AggregationSelector = - AggregationSelector.default, - defaultCardinalityLimitSelector: CardinalityLimitSelector = - CardinalityLimitSelector.default + customize: SdkMeterProvider.Builder[F] => SdkMeterProvider.Builder[F] = (b: SdkMeterProvider.Builder[F]) => b, + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, + defaultAggregationSelector: AggregationSelector = AggregationSelector.default, + defaultCardinalityLimitSelector: CardinalityLimitSelector = CardinalityLimitSelector.default ): Resource[F, MetricsTestkit[F]] = { implicit val askContext: AskContext[F] = Ask.const(Context.root) diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/Aggregation.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/Aggregation.scala index dbb25eded..36f2abec4 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/Aggregation.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/Aggregation.scala @@ -44,8 +44,7 @@ object Aggregation { private[metrics] object Defaults { // See https://opentelemetry.io/docs/specs/otel/metrics/sdk/#explicit-bucket-histogram-aggregation val Boundaries: BucketBoundaries = BucketBoundaries( - 0d, 5d, 10d, 25d, 50d, 75d, 100d, 250d, 500d, 750d, 1000d, 2500d, 5000d, - 7500d, 10000d + 0d, 5d, 10d, 25d, 50d, 75d, 100d, 250d, 500d, 750d, 1000d, 2500d, 5000d, 7500d, 10000d ) } @@ -64,8 +63,7 @@ object Aggregation { */ def default: Aggregation = Default - /** Aggregates measurements into - * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Sum MetricPoints.Sum]]. + /** Aggregates measurements into [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Sum MetricPoints.Sum]]. * * Compatible instruments: * - [[org.typelevel.otel4s.metrics.Counter Counter]] @@ -76,9 +74,8 @@ object Aggregation { */ def sum: Aggregation = Sum - /** Aggregates measurements into - * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Gauge MetricPoints.Gauge]] - * using the last seen measurement. + /** Aggregates measurements into [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Gauge MetricPoints.Gauge]] using + * the last seen measurement. * * Compatible instruments: * - [[org.typelevel.otel4s.metrics.Gauge Gauge]] @@ -87,8 +84,8 @@ object Aggregation { def lastValue: Aggregation = LastValue /** Aggregates measurements into an explicit bucket - * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Histogram MetricPoints.Histogram]] - * using the default bucket boundaries. + * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Histogram MetricPoints.Histogram]] using the default bucket + * boundaries. * * Compatible instruments: * - [[org.typelevel.otel4s.metrics.Counter Counter]] @@ -98,8 +95,8 @@ object Aggregation { ExplicitBucketHistogram(Defaults.Boundaries) /** Aggregates measurements into an explicit bucket - * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Histogram MetricPoints.Histogram]] - * using the given bucket boundaries. + * [[org.typelevel.otel4s.sdk.metrics.data.MetricPoints.Histogram MetricPoints.Histogram]] using the given bucket + * boundaries. * * Compatible instruments: * - [[org.typelevel.otel4s.metrics.Counter Counter]] @@ -129,20 +126,11 @@ object Aggregation { private[metrics] case object Drop extends Aggregation(Compatability.Drop) - private[metrics] case object Default - extends Aggregation(Compatability.Default) - with Synchronous - with Asynchronous + private[metrics] case object Default extends Aggregation(Compatability.Default) with Synchronous with Asynchronous - private[metrics] case object Sum - extends Aggregation(Compatability.Sum) - with Synchronous - with Asynchronous + private[metrics] case object Sum extends Aggregation(Compatability.Sum) with Synchronous with Asynchronous - private[metrics] case object LastValue - extends Aggregation(Compatability.LastValue) - with Synchronous - with Asynchronous + private[metrics] case object LastValue extends Aggregation(Compatability.LastValue) with Synchronous with Asynchronous private[metrics] final case class ExplicitBucketHistogram( boundaries: BucketBoundaries diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/InstrumentType.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/InstrumentType.scala index 8ab68a81b..45feb287f 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/InstrumentType.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/InstrumentType.scala @@ -22,9 +22,8 @@ import cats.Show /** The type of an instrument. * * @note - * the terms synchronous and asynchronous have nothing to do with - * asynchronous programming. We follow naming according to the OpenTelemetry - * specification. + * the terms synchronous and asynchronous have nothing to do with asynchronous programming. We follow naming + * according to the OpenTelemetry specification. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/api/#synchronous-and-asynchronous-instruments]] @@ -33,29 +32,24 @@ sealed trait InstrumentType extends Product with Serializable object InstrumentType { - /** Synchronous instruments (e.g. - * [[org.typelevel.otel4s.metrics.Counter Counter]]) are meant to be invoked - * inline with application/business processing logic. + /** Synchronous instruments (e.g. [[org.typelevel.otel4s.metrics.Counter Counter]]) are meant to be invoked inline + * with application/business processing logic. * - * For instance, an HTTP client might utilize a counter to record the number - * of received bytes. + * For instance, an HTTP client might utilize a counter to record the number of received bytes. * - * The measurements captured by synchronous instruments can be linked with - * the tracing information (span id, trace id). + * The measurements captured by synchronous instruments can be linked with the tracing information (span id, trace + * id). */ sealed trait Synchronous extends InstrumentType - /** Asynchronous instruments (e.g. - * [[org.typelevel.otel4s.metrics.ObservableGauge ObservableGauge]]) offer - * users the ability to register callback functions, which are only triggered - * on demand. + /** Asynchronous instruments (e.g. [[org.typelevel.otel4s.metrics.ObservableGauge ObservableGauge]]) offer users the + * ability to register callback functions, which are only triggered on demand. * - * For example, an asynchronous gauge can be used to collect the temperature - * from a sensor every 15 seconds, which means the callback function will - * only be invoked every 15 seconds. + * For example, an asynchronous gauge can be used to collect the temperature from a sensor every 15 seconds, which + * means the callback function will only be invoked every 15 seconds. * - * Unlike synchronous instruments, the measurements captured by asynchronous - * instruments '''cannot''' be linked with the tracing information. + * Unlike synchronous instruments, the measurements captured by asynchronous instruments '''cannot''' be linked with + * the tracing information. */ sealed trait Asynchronous extends InstrumentType diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkHistogram.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkHistogram.scala index 985f1eb02..94fc5ba30 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkHistogram.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkHistogram.scala @@ -40,8 +40,7 @@ import org.typelevel.otel4s.sdk.metrics.internal.storage.MetricStorage import scala.collection.immutable import scala.concurrent.duration.TimeUnit -/** A synchronous instrument that can be used to report arbitrary values that - * are likely to be statistically meaningful. +/** A synchronous instrument that can be used to report arbitrary values that are likely to be statistically meaningful. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/api/#histogram]] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMeterProvider.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMeterProvider.scala index 0bb6f5090..6269b1dae 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMeterProvider.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMeterProvider.scala @@ -87,8 +87,7 @@ object SdkMeterProvider { * [[org.typelevel.otel4s.metrics.Meter Meter]]. * * @note - * on multiple subsequent calls, the resource from the last call will be - * retained. + * on multiple subsequent calls, the resource from the last call will be retained. * * @param resource * the [[TelemetryResource]] to use @@ -98,8 +97,7 @@ object SdkMeterProvider { /** Merges the given [[TelemetryResource]] with the current one. * * @note - * if both resources have different non-empty `schemaUrl`, the merge will - * fail. + * if both resources have different non-empty `schemaUrl`, the merge will fail. * * @see * [[TelemetryResource.mergeUnsafe]] @@ -109,69 +107,51 @@ object SdkMeterProvider { */ def addResource(resource: TelemetryResource): Builder[F] - /** Sets an - * [[org.typelevel.otel4s.sdk.metrics.exemplar.ExemplarFilter ExemplarFilter]] - * to be used by all metrics. + /** Sets an [[org.typelevel.otel4s.sdk.metrics.exemplar.ExemplarFilter ExemplarFilter]] to be used by all metrics. * * @param filter - * the - * [[org.typelevel.otel4s.sdk.metrics.exemplar.ExemplarFilter ExemplarFilter]] - * to register + * the [[org.typelevel.otel4s.sdk.metrics.exemplar.ExemplarFilter ExemplarFilter]] to register */ private[sdk] def withExemplarFilter(filter: ExemplarFilter): Builder[F] - /** Sets a - * [[org.typelevel.otel4s.sdk.metrics.exemplar.TraceContextLookup TraceContextLookup]] - * to be used by exemplars. + /** Sets a [[org.typelevel.otel4s.sdk.metrics.exemplar.TraceContextLookup TraceContextLookup]] to be used by + * exemplars. * * @param lookup - * the - * [[org.typelevel.otel4s.sdk.metrics.exemplar.TraceContextLookup TraceContextLookup]] - * to use + * the [[org.typelevel.otel4s.sdk.metrics.exemplar.TraceContextLookup TraceContextLookup]] to use */ private[sdk] def withTraceContextLookup( lookup: TraceContextLookup ): Builder[F] - /** Registers a [[org.typelevel.otel4s.sdk.metrics.view.View View]] for the - * given + /** Registers a [[org.typelevel.otel4s.sdk.metrics.view.View View]] for the given * [[org.typelevel.otel4s.sdk.metrics.view.InstrumentSelector InstrumentSelector]]. * - * `View` affects aggregation and export of the instruments that match the - * given `selector`. + * `View` affects aggregation and export of the instruments that match the given `selector`. * * @param selector - * the - * [[org.typelevel.otel4s.sdk.metrics.view.InstrumentSelector InstrumentSelector]] - * to filter instruments with + * the [[org.typelevel.otel4s.sdk.metrics.view.InstrumentSelector InstrumentSelector]] to filter instruments with * * @param view * the [[org.typelevel.otel4s.sdk.metrics.view.View View]] to register */ def registerView(selector: InstrumentSelector, view: View): Builder[F] - /** Registers a - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]. + /** Registers a [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]. * * @param reader - * the - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]] - * to register + * the [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]] to register */ private[sdk] def registerMetricReader(reader: MetricReader[F]): Builder[F] - /** Registers a - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricProducer MetricProducer]]. + /** Registers a [[org.typelevel.otel4s.sdk.metrics.exporter.MetricProducer MetricProducer]]. * * @param producer - * the - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricProducer MetricProducer]] - * to register + * the [[org.typelevel.otel4s.sdk.metrics.exporter.MetricProducer MetricProducer]] to register */ def registerMetricProducer(producer: MetricProducer[F]): Builder[F] - /** Creates [[org.typelevel.otel4s.metrics.MeterProvider MeterProvider]] - * with the configuration of this builder. + /** Creates [[org.typelevel.otel4s.metrics.MeterProvider MeterProvider]] with the configuration of this builder. */ def build: F[MeterProvider[F]] } diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMetrics.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMetrics.scala index 273801b32..5fa204d84 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMetrics.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkMetrics.scala @@ -54,8 +54,8 @@ object SdkMetrics { /** Autoconfigures [[SdkMetrics]] using [[AutoConfigured.Builder]]. * * @note - * the external components (e.g. OTLP exporter) must be registered - * manually. Add the `otel4s-sdk-exporter` dependency to the build file: + * the external components (e.g. OTLP exporter) must be registered manually. Add the `otel4s-sdk-exporter` + * dependency to the build file: * {{{ * libraryDependencies += "org.typelevel" %%% "otel4s-sdk-exporter" % "x.x.x" * }}} @@ -71,8 +71,7 @@ object SdkMetrics { * a function for customizing the auto-configured SDK builder */ def autoConfigured[F[_]: Async: Console]( - customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = - (a: AutoConfigured.Builder[F]) => a + customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = (a: AutoConfigured.Builder[F]) => a ): Resource[F, SdkMetrics[F]] = customize(AutoConfigured.builder[F]).build @@ -90,25 +89,24 @@ object SdkMetrics { /** Sets the given config to use when resolving properties. * * @note - * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no - * effect if the custom config is provided. + * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no effect if the custom config is + * provided. * * @param config * the config to use */ def withConfig(config: Config): Builder[F] - /** Adds the properties loader. Multiple loaders will be added. The loaded - * properties will be merged with the default config. Loaded properties - * take precedence over the default ones. + /** Adds the properties loader. Multiple loaders will be added. The loaded properties will be merged with the + * default config. Loaded properties take precedence over the default ones. * * @param loader * the additional loader to add */ def addPropertiesLoader(loader: F[Map[String, String]]): Builder[F] - /** Adds the properties customizer. Multiple customizers can be added, and - * they will be applied in the order they were added. + /** Adds the properties customizer. Multiple customizers can be added, and they will be applied in the order they + * were added. * * @param customizer * the customizer to add @@ -117,8 +115,8 @@ object SdkMetrics { customizer: Config => Map[String, String] ): Builder[F] - /** Adds the meter provider builder customizer. Multiple customizers can - * be added, and they will be applied in the order they were added. + /** Adds the meter provider builder customizer. Multiple customizers can be added, and they will be applied in the + * order they were added. * * @param customizer * the customizer to add @@ -127,8 +125,8 @@ object SdkMetrics { customizer: Customizer[SdkMeterProvider.Builder[F]] ): Builder[F] - /** Adds the telemetry resource customizer. Multiple customizers can be - * added, and they will be applied in the order they were added. + /** Adds the telemetry resource customizer. Multiple customizers can be added, and they will be applied in the + * order they were added. * * @param customizer * the customizer to add @@ -137,17 +135,15 @@ object SdkMetrics { customizer: Customizer[TelemetryResource] ): Builder[F] - /** Adds the telemetry resource detector. Multiple detectors can be added, - * and the detected telemetry resources will be merged. + /** Adds the telemetry resource detector. Multiple detectors can be added, and the detected telemetry resources + * will be merged. * * By default, the following detectors are enabled: * - host: `host.arch`, `host.name` * - os: `os.type`, `os.description` - * - process: `process.command`, `process.command_args`, - * `process.command_line`, `process.executable.name`, + * - process: `process.command`, `process.command_args`, `process.command_line`, `process.executable.name`, * `process.executable.path`, `process.pid`, `process.owner` - * - process_runtime: `process.runtime.name`, - * `process.runtime.version`, `process.runtime.description` + * - process_runtime: `process.runtime.name`, `process.runtime.version`, `process.runtime.description` * * @param detector * the detector to add @@ -156,8 +152,7 @@ object SdkMetrics { detector: TelemetryResourceDetector[F] ): Builder[F] - /** Adds the exporter configurer. Can be used to register exporters that - * aren't included in the SDK. + /** Adds the exporter configurer. Can be used to register exporters that aren't included in the SDK. * * @example * Add the `otel4s-sdk-exporter` dependency to the build file: @@ -228,9 +223,7 @@ object SdkMetrics { def addMeterProviderCustomizer( customizer: Customizer[SdkMeterProvider.Builder[F]] ): Builder[F] = - copy(meterProviderCustomizer = - merge(this.meterProviderCustomizer, customizer) - ) + copy(meterProviderCustomizer = merge(this.meterProviderCustomizer, customizer)) def addResourceDetector( detector: TelemetryResourceDetector[F] @@ -247,9 +240,7 @@ object SdkMetrics { for { props <- propertiesLoader config <- Config.load(props) - } yield propertiesCustomizers.foldLeft(config)((cfg, c) => - cfg.withOverrides(c(cfg)) - ) + } yield propertiesCustomizers.foldLeft(config)((cfg, c) => cfg.withOverrides(c(cfg))) def loadNoop: Resource[F, SdkMetrics[F]] = Resource.eval( diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounter.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounter.scala index 2d869d5f8..00dac74c0 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounter.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounter.scala @@ -34,8 +34,7 @@ import org.typelevel.otel4s.sdk.metrics.internal.CallbackRegistration import org.typelevel.otel4s.sdk.metrics.internal.InstrumentDescriptor import org.typelevel.otel4s.sdk.metrics.internal.MeterSharedState -/** An asynchronous instrument that reports monotonically increasing value(s) - * when the instrument is being observed. +/** An asynchronous instrument that reports monotonically increasing value(s) when the instrument is being observed. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/api/#asynchronous-counter]] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/Aggregator.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/Aggregator.scala index ef9cea965..33a854108 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/Aggregator.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/Aggregator.scala @@ -36,8 +36,7 @@ import org.typelevel.otel4s.sdk.metrics.internal.AsynchronousMeasurement import org.typelevel.otel4s.sdk.metrics.internal.InstrumentDescriptor import org.typelevel.otel4s.sdk.metrics.internal.MetricDescriptor -/** Aggregators are responsible for holding aggregated values and taking a - * snapshot of these values upon export. +/** Aggregators are responsible for holding aggregated values and taking a snapshot of these values upon export. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#aggregation]] @@ -102,8 +101,7 @@ private[metrics] object Aggregator { */ trait Asynchronous[F[_], A] { - /** Returns a new delta aggregation by comparing two cumulative - * measurements. + /** Returns a new delta aggregation by comparing two cumulative measurements. * * @param previous * the previously captured measurement @@ -142,8 +140,7 @@ private[metrics] object Aggregator { ): F[MetricData] } - /** Records incoming raw values (measurements) and aggregates them into the - * `P` (PointData). + /** Records incoming raw values (measurements) and aggregates them into the `P` (PointData). * * Used by the synchronous instruments. * diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregator.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregator.scala index 067b5a2b3..94915a399 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregator.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregator.scala @@ -33,8 +33,7 @@ import org.typelevel.otel4s.sdk.metrics.exemplar.ExemplarReservoir import org.typelevel.otel4s.sdk.metrics.exemplar.Reservoirs import org.typelevel.otel4s.sdk.metrics.internal.MetricDescriptor -/** The histogram aggregation that aggregates values into the corresponding - * buckets. +/** The histogram aggregation that aggregates values into the corresponding buckets. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#explicit-bucket-histogram-aggregation]] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregator.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregator.scala index ce4370b4c..ff2ed93c8 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregator.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregator.scala @@ -38,8 +38,7 @@ import org.typelevel.otel4s.sdk.metrics.internal.utils.Current private object LastValueAggregator { - /** Creates a last value aggregator for synchronous instruments. Retains the - * last seen measurement. + /** Creates a last value aggregator for synchronous instruments. Retains the last seen measurement. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#last-value-aggregation]] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/SumAggregator.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/SumAggregator.scala index 222ed3922..bb1953f87 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/SumAggregator.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/aggregation/SumAggregator.scala @@ -39,8 +39,7 @@ import org.typelevel.otel4s.sdk.metrics.internal.utils.Adder private object SumAggregator { - /** Creates a sum aggregator for synchronous instruments. Calculates the - * arithmetic sum of the measurement values. + /** Creates a sum aggregator for synchronous instruments. Calculates the arithmetic sum of the measurement values. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#sum-aggregation]] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/ExemplarFilterAutoConfigure.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/ExemplarFilterAutoConfigure.scala index 833cd0815..2c0eda1c6 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/ExemplarFilterAutoConfigure.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/ExemplarFilterAutoConfigure.scala @@ -116,8 +116,7 @@ private[sdk] object ExemplarFilterAutoConfigure { * [[https://opentelemetry.io/docs/languages/java/configuration/#exemplars]] * * @param traceContextLookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context */ def apply[F[_]: MonadThrow]( traceContextLookup: TraceContextLookup diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigure.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigure.scala index 155dbcc7b..60025e502 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigure.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigure.scala @@ -45,8 +45,7 @@ import org.typelevel.otel4s.sdk.metrics.exporter.MetricExporter * the resource to use * * @param traceContextLookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context * * @param customizer * the function to customize the builder @@ -101,8 +100,7 @@ private[sdk] object MeterProviderAutoConfigure { type Customizer[A] = (A, Config) => A - /** Autoconfigures - * [[org.typelevel.otel4s.metrics.MeterProvider MeterProvider]]. + /** Autoconfigures [[org.typelevel.otel4s.metrics.MeterProvider MeterProvider]]. * * @see * [[MetricReadersAutoConfigure]] @@ -117,8 +115,7 @@ private[sdk] object MeterProviderAutoConfigure { * the resource to use * * @param traceContextLookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context * * @param meterProviderBuilderCustomizer * the function to customize the builder diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MetricReadersAutoConfigure.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MetricReadersAutoConfigure.scala index 0581279da..64f908ea6 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MetricReadersAutoConfigure.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MetricReadersAutoConfigure.scala @@ -29,8 +29,7 @@ import org.typelevel.otel4s.sdk.metrics.exporter.MetricReader import scala.concurrent.duration._ -/** Autoconfigures - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]s. +/** Autoconfigures [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]s. * * The configuration options: * {{{ @@ -130,8 +129,7 @@ private[sdk] object MetricReadersAutoConfigure { val ExportTimeout: FiniteDuration = 30.seconds } - /** Autoconfigures - * [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]s. + /** Autoconfigures [[org.typelevel.otel4s.sdk.metrics.exporter.MetricReader MetricReader]]s. * * The configuration options: * {{{ diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/ExemplarData.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/ExemplarData.scala index 092d858ae..6d03427fc 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/ExemplarData.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/ExemplarData.scala @@ -24,8 +24,7 @@ import scodec.bits.ByteVector import scala.concurrent.duration.FiniteDuration -/** An exemplar is a recorded value that associates - * [[ExemplarData.TraceContext]] (extracted from the +/** An exemplar is a recorded value that associates [[ExemplarData.TraceContext]] (extracted from the * [[org.typelevel.otel4s.sdk.context.Context Context]]) to a metric event. * * It allows linking trace details with metrics. @@ -36,8 +35,7 @@ import scala.concurrent.duration.FiniteDuration sealed trait ExemplarData { type Value - /** A set of filtered attributes that provide additional insight about the - * measurement. + /** A set of filtered attributes that provide additional insight about the measurement. */ def filteredAttributes: Attributes @@ -74,8 +72,8 @@ object ExemplarData { /** The trace information. * - * [[TraceContext]] is a minimal version of SpanContext. That way, - * `sdk-metrics` does not need to depend on the `core-trace`. + * [[TraceContext]] is a minimal version of SpanContext. That way, `sdk-metrics` does not need to depend on the + * `core-trace`. */ sealed trait TraceContext { def traceId: ByteVector diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricData.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricData.scala index cf0117672..83dbd3a99 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricData.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricData.scala @@ -31,15 +31,13 @@ sealed trait MetricData { /** The name of the metric. * - * The name is typically the instrument name, but may be optionally - * overridden by a view. + * The name is typically the instrument name, but may be optionally overridden by a view. */ def name: String /** The description of the metric. * - * The metric name is typically the instrument description, but may be - * optionally overridden by a view. + * The metric name is typically the instrument description, but may be optionally overridden by a view. */ def description: Option[String] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricPoints.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricPoints.scala index 517e02c94..b4fd02ad4 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricPoints.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/MetricPoints.scala @@ -47,8 +47,8 @@ sealed trait MetricPoints { object MetricPoints { - /** Sum represents the type of a numeric double scalar metric that is - * calculated as a sum of all reported measurements over a time interval. + /** Sum represents the type of a numeric double scalar metric that is calculated as a sum of all reported measurements + * over a time interval. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/data-model/#sums]] @@ -58,8 +58,7 @@ object MetricPoints { def points: NonEmptyVector[Point] - /** Whether the points are monotonic. If true, it means the data points are - * nominally increasing. + /** Whether the points are monotonic. If true, it means the data points are nominally increasing. */ def monotonic: Boolean @@ -79,9 +78,8 @@ object MetricPoints { def points: NonEmptyVector[Point] } - /** Histogram represents the type of a metric that is calculated by - * aggregating as a histogram of all reported double measurements over a time - * interval. + /** Histogram represents the type of a metric that is calculated by aggregating as a histogram of all reported double + * measurements over a time interval. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/data-model/#histogram]] @@ -132,9 +130,7 @@ object MetricPoints { Hash.by(_.points.toVector: Vector[PointData]) val histogramHash: Hash[Histogram] = - Hash.by(h => - (h.points.toVector: Vector[PointData], h.aggregationTemporality) - ) + Hash.by(h => (h.points.toVector: Vector[PointData], h.aggregationTemporality)) new Hash[MetricPoints] { def hash(x: MetricPoints): Int = diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/PointData.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/PointData.scala index a426e8ff7..34efebf99 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/PointData.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/PointData.scala @@ -23,8 +23,8 @@ import org.typelevel.otel4s.metrics.BucketBoundaries /** A point in the metric data model. * - * A point represents the aggregation of measurements recorded with a - * particular set of [[Attributes]] over some time interval. + * A point represents the aggregation of measurements recorded with a particular set of [[Attributes]] over some time + * interval. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/data-model/#metric-points]] @@ -89,9 +89,8 @@ object PointData { type Value = Double } - /** A population of recorded measurements. A histogram bundles a set of events - * into divided populations with an overall event count and aggregate sum for - * all events. + /** A population of recorded measurements. A histogram bundles a set of events into divided populations with an + * overall event count and aggregate sum for all events. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/data-model/#histogram]] @@ -102,8 +101,7 @@ object PointData { */ def exemplars: Vector[ExemplarData.DoubleExemplar] - /** The [[Histogram.Stats]] of the current measurement. `None` means the - * histogram is empty. + /** The [[Histogram.Stats]] of the current measurement. `None` means the histogram is empty. */ def stats: Option[Histogram.Stats] diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/TimeWindow.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/TimeWindow.scala index f11f55ed7..d0afe5662 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/TimeWindow.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/data/TimeWindow.scala @@ -29,8 +29,7 @@ sealed trait TimeWindow { */ def start: FiniteDuration - /** The end of the time window. In most cases represents the sampling - * (collection) time. + /** The end of the time window. In most cases represents the sampling (collection) time. */ def end: FiniteDuration diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/CellSelector.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/CellSelector.scala index 0108defe7..5419a0a3e 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/CellSelector.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/CellSelector.scala @@ -24,8 +24,7 @@ import cats.syntax.functor._ import org.typelevel.otel4s.metrics.BucketBoundaries import org.typelevel.otel4s.sdk.metrics.internal.utils.Adder -/** Selects which [[ReservoirCell]] within the [[ExemplarReservoir]] should - * receive the measurements. +/** Selects which [[ReservoirCell]] within the [[ExemplarReservoir]] should receive the measurements. * * @tparam F * the higher-kinded type of a polymorphic effect diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarFilter.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarFilter.scala index e4b608948..f5974d79b 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarFilter.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarFilter.scala @@ -20,8 +20,7 @@ import org.typelevel.otel4s.Attributes import org.typelevel.otel4s.metrics.MeasurementValue import org.typelevel.otel4s.sdk.context.Context -/** Exemplar filters are used to pre-filter measurements before attempting to - * store them in a reservoir. +/** Exemplar filters are used to pre-filter measurements before attempting to store them in a reservoir. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#exemplarfilter]] @@ -49,8 +48,7 @@ object ExemplarFilter { */ def alwaysOff: ExemplarFilter = AlwaysOff - /** A filter that only accepts measurements where there is a span in a context - * that is being sampled. + /** A filter that only accepts measurements where there is a span in a context that is being sampled. */ def traceBased(lookup: TraceContextLookup): ExemplarFilter = TraceBased(lookup) diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoir.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoir.scala index 93fd2d87d..7ca46fad3 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoir.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoir.scala @@ -47,8 +47,7 @@ private[metrics] trait ExemplarReservoir[F[_], A] { */ def offer(value: A, attributes: Attributes, context: Context): F[Unit] - /** Returns an collection of [[Exemplar]] for exporting from the current - * reservoir. + /** Returns an collection of [[Exemplar]] for exporting from the current reservoir. * * Clears the reservoir for the next sampling period. */ @@ -57,8 +56,7 @@ private[metrics] trait ExemplarReservoir[F[_], A] { private[metrics] object ExemplarReservoir { - /** Creates a reservoir with fixed size that stores the given number of - * exemplars. + /** Creates a reservoir with fixed size that stores the given number of exemplars. * * @param size * the maximum number of exemplars to preserve @@ -78,8 +76,7 @@ private[metrics] object ExemplarReservoir { reservoir <- create(size, selector, lookup) } yield reservoir - /** Creates a reservoir that preserves the latest seen measurement per - * histogram bucket. + /** Creates a reservoir that preserves the latest seen measurement per histogram bucket. * * @param boundaries * the bucket boundaries of the histogram @@ -100,8 +97,7 @@ private[metrics] object ExemplarReservoir { lookup ) - /** Creates a proxy reservoir that records offered values that have passed the - * filter. + /** Creates a proxy reservoir that records offered values that have passed the filter. * * @param filter * filters the offered values diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/Reservoirs.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/Reservoirs.scala index bac27af1a..71a321b8e 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/Reservoirs.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exemplar/Reservoirs.scala @@ -25,8 +25,7 @@ import org.typelevel.otel4s.metrics.MeasurementValue private[metrics] sealed trait Reservoirs[F[_]] { - /** Creates a reservoir with fixed size that stores the given number of - * exemplars. + /** Creates a reservoir with fixed size that stores the given number of exemplars. * * @param size * the maximum number of exemplars to preserve @@ -36,8 +35,7 @@ private[metrics] sealed trait Reservoirs[F[_]] { */ def fixedSize[A: MeasurementValue](size: Int): F[ExemplarReservoir[F, A]] - /** Creates a reservoir that preserves the latest seen measurement per - * histogram bucket. + /** Creates a reservoir that preserves the latest seen measurement per histogram bucket. * * @param boundaries * the bucket boundaries of the histogram @@ -59,8 +57,7 @@ private[metrics] object Reservoirs { * used by the exemplar reservoir to filter the offered values * * @param lookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context * * @tparam F * the higher-kinded type of a polymorphic effect @@ -83,8 +80,7 @@ private[metrics] object Reservoirs { /** Creates [[Reservoirs]] that returns 'always-on' reservoirs. * * @param lookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context * * @tparam F * the higher-kinded type of a polymorphic effect @@ -105,8 +101,7 @@ private[metrics] object Reservoirs { /** Creates [[Reservoirs]] that returns filtered reservoirs. * * @param lookup - * used by the exemplar reservoir to extract tracing information from the - * context + * used by the exemplar reservoir to extract tracing information from the context * * @tparam F * the higher-kinded type of a polymorphic effect diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationSelector.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationSelector.scala index 2228a15e7..94b0ca65a 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationSelector.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationSelector.scala @@ -31,15 +31,13 @@ trait AggregationSelector { forAsynchronous(asynchronous) } - /** Returns preferred [[Aggregation]] for the given - * [[InstrumentType.Synchronous]]. + /** Returns preferred [[Aggregation]] for the given [[InstrumentType.Synchronous]]. */ def forSynchronous( instrumentType: InstrumentType.Synchronous ): Aggregation with Aggregation.Synchronous - /** Returns preferred [[Aggregation]] for the given - * [[InstrumentType.Asynchronous]]. + /** Returns preferred [[Aggregation]] for the given [[InstrumentType.Asynchronous]]. */ def forAsynchronous( instrumentType: InstrumentType.Asynchronous diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationTemporalitySelector.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationTemporalitySelector.scala index fe2b3bcc1..da5fc9014 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationTemporalitySelector.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/AggregationTemporalitySelector.scala @@ -23,8 +23,7 @@ import org.typelevel.otel4s.sdk.metrics.data.AggregationTemporality */ trait AggregationTemporalitySelector { - /** Returns preferred aggregation temporality for the given - * [[InstrumentType]]. + /** Returns preferred aggregation temporality for the given [[InstrumentType]]. */ def select(instrumentType: InstrumentType): AggregationTemporality } @@ -36,9 +35,8 @@ object AggregationTemporalitySelector { def alwaysCumulative: AggregationTemporalitySelector = _ => AggregationTemporality.Cumulative - /** Returns cumulative aggregation temporality for `UpDownCounter` and - * `ObservableUpDownCounter`, and delta aggregation temporality for any other - * instrument. + /** Returns cumulative aggregation temporality for `UpDownCounter` and `ObservableUpDownCounter`, and delta + * aggregation temporality for any other instrument. */ def deltaPreferred: AggregationTemporalitySelector = { case InstrumentType.UpDownCounter => @@ -51,9 +49,8 @@ object AggregationTemporalitySelector { AggregationTemporality.Delta } - /** Returns cumulative aggregation temporality for `UpDownCounter`, - * `ObservableUpDownCounter`, `ObservableCounter`, and delta aggregation - * temporality for any other instrument. + /** Returns cumulative aggregation temporality for `UpDownCounter`, `ObservableUpDownCounter`, `ObservableCounter`, + * and delta aggregation temporality for any other instrument. */ def lowMemory: AggregationTemporalitySelector = { case InstrumentType.UpDownCounter => diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporter.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporter.scala index 7bc8093d6..e89d20e07 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporter.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporter.scala @@ -29,8 +29,7 @@ import org.typelevel.otel4s.sdk.metrics.data.MetricData /** A metric exporter that logs every metric using [[cats.effect.std.Console]]. * * @note - * use this exporter for debugging purposes because it may affect the - * performance + * use this exporter for debugging purposes because it may affect the performance * * @tparam F * the higher-kinded type of a polymorphic effect @@ -66,8 +65,7 @@ private final class ConsoleMetricExporter[F[_]: Monad: Console]( object ConsoleMetricExporter { - /** Creates a metric exporter that logs every metric using - * [[cats.effect.std.Console]]. + /** Creates a metric exporter that logs every metric using [[cats.effect.std.Console]]. * * @tparam F * the higher-kinded type of a polymorphic effect @@ -75,8 +73,7 @@ object ConsoleMetricExporter { def apply[F[_]: Monad: Console]: MetricExporter.Push[F] = apply(AggregationTemporalitySelector.alwaysCumulative) - /** Creates a metric exporter that logs every metric using - * [[cats.effect.std.Console]]. + /** Creates a metric exporter that logs every metric using [[cats.effect.std.Console]]. * * @param aggregationTemporalitySelector * the aggregation temporality selector to use diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricExporter.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricExporter.scala index 8166ccd6c..e1ef420c9 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricExporter.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricExporter.scala @@ -40,15 +40,13 @@ sealed trait MetricExporter[F[_]] { /** The preferred aggregation for the given instrument. * - * If no views are configured for a metric instrument, an aggregation - * provided by the selector will be used. + * If no views are configured for a metric instrument, an aggregation provided by the selector will be used. */ def defaultAggregationSelector: AggregationSelector /** The preferred cardinality limit for the given instrument. * - * If no views are configured for a metric instrument, a limit provided by - * the selector will be used. + * If no views are configured for a metric instrument, a limit provided by the selector will be used. */ def defaultCardinalityLimitSelector: CardinalityLimitSelector @@ -80,8 +78,7 @@ object MetricExporter { */ def exportMetrics[G[_]: Foldable](metrics: G[MetricData]): F[Unit] - /** Exports the collection of sampled `MetricData` that have not yet been - * exported. + /** Exports the collection of sampled `MetricData` that have not yet been exported. */ def flush: F[Unit] } @@ -99,8 +96,7 @@ object MetricExporter { def noop[F[_]: Applicative]: MetricExporter[F] = new Noop - private[metrics] final class Noop[F[_]: Applicative] - extends MetricExporter.Push[F] { + private[metrics] final class Noop[F[_]: Applicative] extends MetricExporter.Push[F] { val name: String = "MetricExporter.Noop" def aggregationTemporalitySelector: AggregationTemporalitySelector = diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricProducer.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricProducer.scala index dbcd1e374..550c7ee26 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricProducer.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricProducer.scala @@ -28,9 +28,8 @@ import org.typelevel.otel4s.sdk.metrics.data.MetricData */ trait MetricProducer[F[_]] { - /** Produces metrics by collecting them from the SDK. If there are - * asynchronous instruments involved, their callback functions will be - * evaluated. + /** Produces metrics by collecting them from the SDK. If there are asynchronous instruments involved, their callback + * functions will be evaluated. */ def produce: F[Vector[MetricData]] } diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricReader.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricReader.scala index 9815223bb..bffe29a10 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricReader.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/MetricReader.scala @@ -25,8 +25,7 @@ import org.typelevel.otel4s.sdk.metrics.data.MetricData import scala.concurrent.duration.FiniteDuration -/** A reader of metrics that collects metrics from the associated metric - * producers. +/** A reader of metrics that collects metrics from the associated metric producers. * * @see * [[https://opentelemetry.io/docs/specs/otel/metrics/sdk/#metricreader]] @@ -42,23 +41,21 @@ trait MetricReader[F[_]] { /** The preferred aggregation for the given instrument. * - * If no views are configured for a metric instrument, an aggregation - * provided by the selector will be used. + * If no views are configured for a metric instrument, an aggregation provided by the selector will be used. */ def defaultAggregationSelector: AggregationSelector /** The preferred cardinality limit for the given instrument. * - * If no views are configured for a metric instrument, a limit provided by - * the selector will be used. + * If no views are configured for a metric instrument, a limit provided by the selector will be used. */ def defaultCardinalityLimitSelector: CardinalityLimitSelector /** Sets the metric producer to be used by this reader. * * @note - * this should only be called by the SDK and should be considered an - * internal API. The producers can be configured only once. + * this should only be called by the SDK and should be considered an internal API. The producers can be configured + * only once. * * @param producers * the producers to use to collect the metrics @@ -69,16 +66,14 @@ trait MetricReader[F[_]] { */ def collectAllMetrics: F[Vector[MetricData]] - /** Collects all metrics and sends them to the exporter. Flushes the exporter - * too. + /** Collects all metrics and sends them to the exporter. Flushes the exporter too. */ def forceFlush: F[Unit] } object MetricReader { - /** Creates a period metric reader that collects and exports metrics with the - * given interval. + /** Creates a period metric reader that collects and exports metrics with the given interval. * * @param exporter * the exporter to send the collected metrics to diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReader.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReader.scala index 669a292bc..31a803ce2 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReader.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReader.scala @@ -132,8 +132,7 @@ private object PeriodicMetricReader { exportTimeout: FiniteDuration ) - /** Creates a period metric reader that collects and exports metrics with the - * given interval. + /** Creates a period metric reader that collects and exports metrics with the given interval. * * @param exporter * the exporter to send the collected metrics to diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/Advice.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/Advice.scala index c4c72abd3..0879887a6 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/Advice.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/Advice.scala @@ -28,8 +28,7 @@ import org.typelevel.otel4s.metrics.BucketBoundaries */ private[metrics] sealed trait Advice { - /** The recommended set of bucket boundaries to use if the selected - * aggregation is `ExplicitBucketHistogram`. + /** The recommended set of bucket boundaries to use if the selected aggregation is `ExplicitBucketHistogram`. */ def explicitBucketBoundaries: Option[BucketBoundaries] @@ -51,8 +50,7 @@ private[metrics] object Advice { /** Creates an [[Advice]] with the given values. * * @param bucketBoundaries - * the recommended set of bucket boundaries to use if the selected - * aggregation is `explicit bucket histogram` + * the recommended set of bucket boundaries to use if the selected aggregation is `explicit bucket histogram` */ def apply(bucketBoundaries: Option[BucketBoundaries]): Advice = Impl(bucketBoundaries) diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/CallbackRegistration.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/CallbackRegistration.scala index 44af6767c..f11cac4d8 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/CallbackRegistration.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/CallbackRegistration.scala @@ -31,8 +31,7 @@ private[metrics] final class CallbackRegistration[F[_]: MonadCancelThrow]( private val hasStorages: Boolean = measurements.exists(_.hasStorages) - /** Set the active reader on each observable measurement so that measurements - * are only recorded to relevant storages. + /** Set the active reader on each observable measurement so that measurements are only recorded to relevant storages. * * @param reader * the reader to use diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MeterSharedState.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MeterSharedState.scala index e7a533ff1..8a837289a 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MeterSharedState.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MeterSharedState.scala @@ -53,8 +53,7 @@ private[metrics] final class MeterSharedState[ registries: Map[RegisteredReader[F], MetricStorageRegistry[F]] ) { - /** Creates a metric storage for the given descriptor of a synchronous - * instrument. + /** Creates a metric storage for the given descriptor of a synchronous instrument. * * @param descriptor * a descriptor to create a storage for @@ -127,8 +126,7 @@ private[metrics] final class MeterSharedState[ } } - /** Creates an observable measurement for the given descriptor of an - * asynchronous instrument. + /** Creates an observable measurement for the given descriptor of an asynchronous instrument. * * @param descriptor * a descriptor to create an observable measurement for @@ -226,8 +224,7 @@ private[metrics] final class MeterSharedState[ } } - /** Registers a callback and removes it from the state upon resource - * finalization. + /** Registers a callback and removes it from the state upon resource finalization. * * @param callback * a callback to register diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricDescriptor.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricDescriptor.scala index 5644127b6..b188fa9bb 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricDescriptor.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricDescriptor.scala @@ -58,8 +58,7 @@ private[metrics] sealed trait MetricDescriptor { private[metrics] object MetricDescriptor { - /** Creates a [[MetricDescriptor]] using the given `view` and - * `instrumentDescriptor`. + /** Creates a [[MetricDescriptor]] using the given `view` and `instrumentDescriptor`. * * The `name` and `description` from the `view` are prioritized. * diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistry.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistry.scala index ab1da6da7..a1d736029 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistry.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistry.scala @@ -38,11 +38,10 @@ private[metrics] final class MetricStorageRegistry[ /** Registers a storage to this registry. * - * If a metric with compatible identity was previously registered, returns - * the previously registered storage. + * If a metric with compatible identity was previously registered, returns the previously registered storage. * - * If a metric with the same name (case-insensitive) but incompatible - * descriptor was previously registered, logs a diagnostic warning. + * If a metric with the same name (case-insensitive) but incompatible descriptor was previously registered, logs a + * diagnostic warning. * * @param storage * the metric storage to register diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurement.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurement.scala index d9ce67fb4..d7f765ab5 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurement.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurement.scala @@ -33,8 +33,7 @@ import org.typelevel.otel4s.sdk.metrics.data.TimeWindow import org.typelevel.otel4s.sdk.metrics.internal.exporter.RegisteredReader import org.typelevel.otel4s.sdk.metrics.internal.storage.MetricStorage -private[metrics] sealed trait SdkObservableMeasurement[F[_], A] - extends ObservableMeasurement[F, A] { self => +private[metrics] sealed trait SdkObservableMeasurement[F[_], A] extends ObservableMeasurement[F, A] { self => /** The scope associated with this measurement. */ diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorage.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorage.scala index dec723d5f..819a51c6c 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorage.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorage.scala @@ -206,7 +206,7 @@ private object AsynchronousStorage { aggregator: Aggregator.Asynchronous[F, A] ): F[Collector[F, A]] = aggregationTemporality match { - case AggregationTemporality.Delta => delta[F, A](reader, aggregator) + case AggregationTemporality.Delta => delta[F, A](reader, aggregator) case AggregationTemporality.Cumulative => cumulative[F, A] } diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/MetricStorage.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/MetricStorage.scala index 0fe4c6daf..e3c63c009 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/MetricStorage.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/MetricStorage.scala @@ -51,8 +51,7 @@ private[metrics] trait MetricStorage[F[_]] { /** Collects the metrics from this storage. * * @note - * if the aggregation temporality for the metric is `delta`, the state will - * be reset. + * if the aggregation temporality for the metric is `delta`, the state will be reset. * * @param resource * the resource to associate the metrics with @@ -93,9 +92,7 @@ private[metrics] object MetricStorage { * @tparam A * the type of the values to store */ - trait Synchronous[F[_], A] - extends MetricStorage[F] - with Synchronous.Writeable[F, A] + trait Synchronous[F[_], A] extends MetricStorage[F] with Synchronous.Writeable[F, A] object Synchronous { diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/AttributesProcessor.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/AttributesProcessor.scala index 77261dc3d..5fe9731bf 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/AttributesProcessor.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/AttributesProcessor.scala @@ -22,8 +22,8 @@ import org.typelevel.otel4s.Attribute import org.typelevel.otel4s.Attributes import org.typelevel.otel4s.sdk.context.Context -/** The AttributesProcessor can customize which attributes are to be reported as - * metric dimensions and add additional dimensions from the context. +/** The AttributesProcessor can customize which attributes are to be reported as metric dimensions and add additional + * dimensions from the context. */ private[metrics] sealed trait AttributesProcessor { @@ -47,8 +47,7 @@ private[metrics] object AttributesProcessor { */ def noop: AttributesProcessor = Noop - /** Creates an [[AttributesProcessor]] that retains attributes with the - * matching names. + /** Creates an [[AttributesProcessor]] that retains attributes with the matching names. * * @param retain * the attribute keys to retain @@ -56,8 +55,7 @@ private[metrics] object AttributesProcessor { def retain(retain: Set[String]): AttributesProcessor = new Retain(retain) - /** Creates an [[AttributesProcessor]] that retains attributes that match the - * predicate. + /** Creates an [[AttributesProcessor]] that retains attributes that match the predicate. * * @param predicate * the predicate to match diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/InstrumentSelector.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/InstrumentSelector.scala index 5bf71194f..94fe4afab 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/InstrumentSelector.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/InstrumentSelector.scala @@ -20,8 +20,7 @@ package view import cats.Hash import cats.Show -/** Instrument selection criteria for applying views registered via meter - * provider. +/** Instrument selection criteria for applying views registered via meter provider. * * The predicate is built by the logical conjunction of the present properties. */ @@ -35,8 +34,7 @@ sealed trait InstrumentSelector { /** The required name of an instrument. * - * Instrument name may contain the wildcard characters `*` and `?` with the - * following matching criteria: + * Instrument name may contain the wildcard characters `*` and `?` with the following matching criteria: * - `*` - matches 0 or more instances of any character * - `?` - matches exactly one instance of any character * @@ -98,8 +96,7 @@ object InstrumentSelector { /** Adds the given `name` as a predicate for an instrument. * - * Instrument name may contain the wildcard characters `*` and `?` with the - * following matching criteria: + * Instrument name may contain the wildcard characters `*` and `?` with the following matching criteria: * - `*` - matches 0 or more instances of any character * - `?` - matches exactly one instance of any character * @@ -151,8 +148,7 @@ object InstrumentSelector { */ def withMeterSchemaUrl(schemaUrl: String): Builder - /** Creates an [[InstrumentSelector]] with the configuration of this - * builder. + /** Creates an [[InstrumentSelector]] with the configuration of this builder. */ def build: InstrumentSelector } diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/View.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/View.scala index ea87664ae..6b058189b 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/View.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/View.scala @@ -53,8 +53,7 @@ sealed trait View { */ private[metrics] def attributesProcessor: Option[AttributesProcessor] - /** The cardinality limit of this view - the maximum number of series for a - * metric. + /** The cardinality limit of this view - the maximum number of series for a metric. * * `None` means the MetricReader's default cardinality limit should be used. */ @@ -105,8 +104,7 @@ object View { */ def addAttributeFilter(retain: Set[String]): Builder - /** Adds an attribute filter which retains attributes that satisfy the - * `filter`. + /** Adds an attribute filter which retains attributes that satisfy the `filter`. * * @param filter * the filter to use @@ -162,14 +160,10 @@ object View { copy(aggregation = Some(aggregation)) def addAttributeFilter(retain: Set[String]): Builder = - copy(attributesProcessors = - attributesProcessors :+ AttributesProcessor.retain(retain) - ) + copy(attributesProcessors = attributesProcessors :+ AttributesProcessor.retain(retain)) def addAttributeFilter(filter: Attribute[_] => Boolean): Builder = - copy(attributesProcessors = - attributesProcessors :+ AttributesProcessor.attributePredicate(filter) - ) + copy(attributesProcessors = attributesProcessors :+ AttributesProcessor.attributePredicate(filter)) def withCardinalityLimit(limit: Int): Builder = { require(limit > 0, s"cardinality limit [$limit] must be positive") diff --git a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/ViewRegistry.scala b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/ViewRegistry.scala index ff05ad3ff..4f0fa2d58 100644 --- a/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/ViewRegistry.scala +++ b/sdk/metrics/src/main/scala/org/typelevel/otel4s/sdk/metrics/view/ViewRegistry.scala @@ -53,9 +53,7 @@ private[metrics] final class ViewRegistry[F[_]: Monad: Console]( ): Boolean = { selector.instrumentType.forall(tpe => descriptor.instrumentType == tpe) && selector.instrumentUnit.forall(unit => descriptor.unit.contains(unit)) && - selector.instrumentName.forall(n => - ViewRegistry.toGlobPattern(n)(descriptor.name.toString) - ) && + selector.instrumentName.forall(n => ViewRegistry.toGlobPattern(n)(descriptor.name.toString)) && selector.meterName.forall(n => n == meterScope.name) && selector.meterVersion.forall(v => meterScope.version.contains(v)) && selector.meterSchemaUrl.forall(s => meterScope.schemaUrl.contains(s)) @@ -85,8 +83,7 @@ private[metrics] object ViewRegistry { globPattern.equalsIgnoreCase(s) } - /** Transforms the `input` to a regex by converting `*` to `.*`, `?` to `.`, - * and escaping other characters. + /** Transforms the `input` to a regex by converting `*` to `.*`, `?` to `.`, and escaping other characters. */ private def makePattern(input: String): Pattern = { def quote(str: String): String = diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounterSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounterSuite.scala index 08e0bbf09..395ba7c2e 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounterSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableCounterSuite.scala @@ -33,9 +33,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import org.typelevel.otel4s.sdk.metrics.test.InMemoryMeterSharedState import org.typelevel.otel4s.sdk.metrics.test.PointDataUtils -class SdkObservableCounterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SdkObservableCounterSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val askContext: Ask[IO, Context] = Ask.const(Context.root) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableGaugeSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableGaugeSuite.scala index dd1bc886b..6175b48d9 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableGaugeSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableGaugeSuite.scala @@ -32,9 +32,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import org.typelevel.otel4s.sdk.metrics.test.InMemoryMeterSharedState import org.typelevel.otel4s.sdk.metrics.test.PointDataUtils -class SdkObservableGaugeSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SdkObservableGaugeSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val askContext: Ask[IO, Context] = Ask.const(Context.root) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableUpDownCounterSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableUpDownCounterSuite.scala index f19d9d970..210ffea4b 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableUpDownCounterSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/SdkObservableUpDownCounterSuite.scala @@ -33,9 +33,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import org.typelevel.otel4s.sdk.metrics.test.InMemoryMeterSharedState import org.typelevel.otel4s.sdk.metrics.test.PointDataUtils -class SdkObservableUpDownCounterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SdkObservableUpDownCounterSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val askContext: Ask[IO, Context] = Ask.const(Context.root) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregatorSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregatorSuite.scala index a37a6c706..d4422e37f 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregatorSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/ExplicitBucketHistogramAggregatorSuite.scala @@ -41,9 +41,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import scala.concurrent.duration._ -class ExplicitBucketHistogramAggregatorSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class ExplicitBucketHistogramAggregatorSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private val traceContextKey = Context.Key .unique[SyncIO, TraceContext]("trace-context") @@ -245,12 +243,11 @@ class ExplicitBucketHistogramAggregatorSuite values: List[Double], boundaries: BucketBoundaries ): Vector[Long] = - values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { - case (acc, value) => - val i = boundaries.boundaries.indexWhere(b => value <= b) - val idx = if (i == -1) boundaries.length else i + values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { case (acc, value) => + val i = boundaries.boundaries.indexWhere(b => value <= b) + val idx = if (i == -1) boundaries.length else i - acc.updated(idx, acc(idx) + 1L) + acc.updated(idx, acc(idx) + 1L) } // retains last exemplar for each bucket diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregatorSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregatorSuite.scala index 0dc52f68b..100bc868c 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregatorSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/aggregation/LastValueAggregatorSuite.scala @@ -39,9 +39,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import scala.concurrent.duration._ -class LastValueAggregatorSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class LastValueAggregatorSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private val traceContextKey = Context.Key .unique[SyncIO, TraceContext]("trace-context") diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigureSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigureSuite.scala index 75273b951..d1737a3c5 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigureSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/autoconfigure/MeterProviderAutoConfigureSuite.scala @@ -127,8 +127,7 @@ class MeterProviderAutoConfigureSuite extends CatsEffectSuite { config: Config, resource: TelemetryResource = TelemetryResource.empty, customizer: Customizer[SdkMeterProvider.Builder[IO]] = (a, _) => a, - exporterConfigurers: Set[AutoConfigure.Named[IO, MetricExporter[IO]]] = - Set.empty + exporterConfigurers: Set[AutoConfigure.Named[IO, MetricExporter[IO]]] = Set.empty )(f: MeterProvider[IO] => IO[A]): IO[A] = Resource.eval(Random.scalaUtilRandom[IO]).use { implicit random => implicit val askContext: AskContext[IO] = Ask.const(Context.root) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoirSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoirSuite.scala index 6e0a33e02..18d5ce5dd 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoirSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exemplar/ExemplarReservoirSuite.scala @@ -32,9 +32,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Arbitraries._ import scala.concurrent.duration._ -class ExemplarReservoirSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class ExemplarReservoirSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private val traceContextKey = Context.Key .unique[SyncIO, TraceContext]("trace-context") diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporterSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporterSuite.scala index 46d697a09..7b0e86417 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporterSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/ConsoleMetricExporterSuite.scala @@ -26,9 +26,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import org.typelevel.otel4s.sdk.test.InMemoryConsole import org.typelevel.otel4s.sdk.test.InMemoryConsole._ -class ConsoleMetricExporterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class ConsoleMetricExporterSuite extends CatsEffectSuite with ScalaCheckEffectSuite { test("print metrics to the console") { PropF.forAllF(Gen.listOf(Gens.metricData)) { metrics => diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/InMemoryMetricExporter.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/InMemoryMetricExporter.scala index 181a01008..7d9b26ec7 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/InMemoryMetricExporter.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/InMemoryMetricExporter.scala @@ -50,12 +50,9 @@ object InMemoryMetricExporter { def create[F[_]: Concurrent]( capacity: Option[Int], - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, - defaultAggregationSelector: AggregationSelector = - AggregationSelector.default, - defaultCardinalityLimitSelector: CardinalityLimitSelector = - CardinalityLimitSelector.default + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, + defaultAggregationSelector: AggregationSelector = AggregationSelector.default, + defaultCardinalityLimitSelector: CardinalityLimitSelector = CardinalityLimitSelector.default ): F[InMemoryMetricExporter[F]] = for { queue <- capacity.fold(Queue.unbounded[F, MetricData])(Queue.bounded(_)) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReaderSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReaderSuite.scala index 41d48c0fb..2c9ffde37 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReaderSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/exporter/PeriodicMetricReaderSuite.scala @@ -33,9 +33,7 @@ import org.typelevel.otel4s.sdk.test.InMemoryConsole import scala.concurrent.duration._ import scala.util.control.NoStackTrace -class PeriodicMetricReaderSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class PeriodicMetricReaderSuite extends CatsEffectSuite with ScalaCheckEffectSuite { test("export metrics with a fixed interval") { PropF.forAllF { (metrics: List[MetricData]) => diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistrySuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistrySuite.scala index a50af39c7..bf5df6dcf 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistrySuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/MetricStorageRegistrySuite.scala @@ -29,9 +29,7 @@ import org.typelevel.otel4s.sdk.metrics.scalacheck.Gens import org.typelevel.otel4s.sdk.metrics.view.View import org.typelevel.otel4s.sdk.test.InMemoryConsole -class MetricStorageRegistrySuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class MetricStorageRegistrySuite extends CatsEffectSuite with ScalaCheckEffectSuite { test("register a storage") { PropF.forAllF(Gens.instrumentDescriptor) { descriptor => diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurementSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurementSuite.scala index 58ff8a2e9..49b6a2554 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurementSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/SdkObservableMeasurementSuite.scala @@ -39,9 +39,7 @@ import org.typelevel.otel4s.sdk.test.InMemoryConsole import scala.concurrent.duration._ -class SdkObservableMeasurementSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SdkObservableMeasurementSuite extends CatsEffectSuite with ScalaCheckEffectSuite { test("log an error when reader is unset") { PropF.forAllF( diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorageSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorageSuite.scala index d07fcf0f7..11174bc8c 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorageSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/AsynchronousStorageSuite.scala @@ -47,9 +47,7 @@ import org.typelevel.otel4s.sdk.test.NoopConsole import scala.concurrent.duration._ -class AsynchronousStorageSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class AsynchronousStorageSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val noopConsole: Console[IO] = new NoopConsole[IO] private implicit val askContext: Ask[IO, Context] = Ask.const(Context.root) @@ -328,8 +326,7 @@ class AsynchronousStorageSuite producer: MetricProducer[IO] = emptyProducer, view: Option[View] = None, start: FiniteDuration = Duration.Zero, - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative ): IO[MetricStorage.Asynchronous[IO, A]] = { val inMemory = new InMemoryMetricReader[IO]( producer, diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/SynchronousStorageSuite.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/SynchronousStorageSuite.scala index 9551e40b0..0fc6da563 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/SynchronousStorageSuite.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/internal/storage/SynchronousStorageSuite.scala @@ -46,9 +46,7 @@ import org.typelevel.otel4s.sdk.test.NoopConsole import scala.concurrent.duration._ -class SynchronousStorageSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SynchronousStorageSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val noopConsole: Console[IO] = new NoopConsole[IO] @@ -308,8 +306,7 @@ class SynchronousStorageSuite producer: MetricProducer[IO] = emptyProducer, view: Option[View] = None, start: FiniteDuration = Duration.Zero, - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative ): IO[MetricStorage.Synchronous[IO, A]] = { val inMemory = new InMemoryMetricReader[IO]( producer, diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/scalacheck/Gens.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/scalacheck/Gens.scala index 843d8e32d..afb217bf3 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/scalacheck/Gens.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/scalacheck/Gens.scala @@ -53,13 +53,13 @@ trait Gens extends org.typelevel.otel4s.sdk.scalacheck.Gens { Gen.oneOf(InstrumentType.values) val synchronousInstrumentType: Gen[InstrumentType.Synchronous] = - Gen.oneOf(InstrumentType.values.collect { - case tpe: InstrumentType.Synchronous => tpe + Gen.oneOf(InstrumentType.values.collect { case tpe: InstrumentType.Synchronous => + tpe }) val asynchronousInstrumentType: Gen[InstrumentType.Asynchronous] = - Gen.oneOf(InstrumentType.values.collect { - case tpe: InstrumentType.Asynchronous => tpe + Gen.oneOf(InstrumentType.values.collect { case tpe: InstrumentType.Asynchronous => + tpe }) val synchronousInstrumentDescriptor: Gen[InstrumentDescriptor.Synchronous] = @@ -86,8 +86,8 @@ trait Gens extends org.typelevel.otel4s.sdk.scalacheck.Gens { valueOpt: Option[String], f: InstrumentSelector.Builder => String => InstrumentSelector.Builder ): InstrumentSelector.Builder => InstrumentSelector.Builder = - valueOpt.fold((a: InstrumentSelector.Builder) => a) { - value => (a: InstrumentSelector.Builder) => f(a)(value) + valueOpt.fold((a: InstrumentSelector.Builder) => a) { value => (a: InstrumentSelector.Builder) => + f(a)(value) } for { @@ -205,12 +205,11 @@ trait Gens extends org.typelevel.otel4s.sdk.scalacheck.Gens { values: List[Double], boundaries: BucketBoundaries ): Vector[Long] = - values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { - case (acc, value) => - val i = boundaries.boundaries.indexWhere(b => value <= b) - val idx = if (i == -1) boundaries.length else i + values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { case (acc, value) => + val i = boundaries.boundaries.indexWhere(b => value <= b) + val idx = if (i == -1) boundaries.length else i - acc.updated(idx, acc(idx) + 1L) + acc.updated(idx, acc(idx) + 1L) } // retains last exemplar for each bucket diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/InMemoryMeterSharedState.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/InMemoryMeterSharedState.scala index 6803645b3..309d8828e 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/InMemoryMeterSharedState.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/InMemoryMeterSharedState.scala @@ -51,8 +51,7 @@ object InMemoryMeterSharedState { resource: TelemetryResource, scope: InstrumentationScope, start: FiniteDuration, - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative ): F[InMemoryMeterSharedState[F]] = { implicit val askContext: Ask[F, Context] = Ask.const(Context.root) diff --git a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/PointDataUtils.scala b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/PointDataUtils.scala index d4deddc2c..7547d9889 100644 --- a/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/PointDataUtils.scala +++ b/sdk/metrics/src/test/scala/org/typelevel/otel4s/sdk/metrics/test/PointDataUtils.scala @@ -72,12 +72,11 @@ object PointDataUtils { ) val counts: Vector[Long] = - values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { - case (acc, value) => - val i = boundaries.boundaries.indexWhere(b => value.toDouble <= b) - val idx = if (i == -1) boundaries.length else i + values.foldLeft(Vector.fill(boundaries.length + 1)(0L)) { case (acc, value) => + val i = boundaries.boundaries.indexWhere(b => value.toDouble <= b) + val idx = if (i == -1) boundaries.length else i - acc.updated(idx, acc(idx) + 1L) + acc.updated(idx, acc(idx) + 1L) } PointData.histogram( diff --git a/sdk/testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/OpenTelemetrySdkTestkit.scala b/sdk/testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/OpenTelemetrySdkTestkit.scala index 3eab0b7ca..4d0ec4e62 100644 --- a/sdk/testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/OpenTelemetrySdkTestkit.scala +++ b/sdk/testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/OpenTelemetrySdkTestkit.scala @@ -58,8 +58,7 @@ object OpenTelemetrySdkTestkit { type Customizer[A] = A => A - /** Creates [[OpenTelemetrySdkTestkit]] that keeps spans and metrics - * in-memory. + /** Creates [[OpenTelemetrySdkTestkit]] that keeps spans and metrics in-memory. * * @param customizeMeterProviderBuilder * the customization of the meter provider builder @@ -74,27 +73,20 @@ object OpenTelemetrySdkTestkit { * the preferred aggregation for the given instrument type * * @param defaultAggregationSelector - * the preferred aggregation for the given instrument type. If no views are - * configured for a metric instrument, an aggregation provided by the - * selector will be used + * the preferred aggregation for the given instrument type. If no views are configured for a metric instrument, an + * aggregation provided by the selector will be used * * @param defaultCardinalityLimitSelector - * the preferred cardinality limit for the given instrument type. If no - * views are configured for a metric instrument, a limit provided by the - * selector will be used + * the preferred cardinality limit for the given instrument type. If no views are configured for a metric + * instrument, a limit provided by the selector will be used */ def inMemory[F[_]: Async: Parallel: Console: LocalContextProvider]( - customizeMeterProviderBuilder: Customizer[SdkMeterProvider.Builder[F]] = - identity[SdkMeterProvider.Builder[F]], - customizeTracerProviderBuilder: Customizer[SdkTracerProvider.Builder[F]] = - identity[SdkTracerProvider.Builder[F]], + customizeMeterProviderBuilder: Customizer[SdkMeterProvider.Builder[F]] = identity[SdkMeterProvider.Builder[F]], + customizeTracerProviderBuilder: Customizer[SdkTracerProvider.Builder[F]] = identity[SdkTracerProvider.Builder[F]], textMapPropagators: Iterable[TextMapPropagator[Context]] = Nil, - aggregationTemporalitySelector: AggregationTemporalitySelector = - AggregationTemporalitySelector.alwaysCumulative, - defaultAggregationSelector: AggregationSelector = - AggregationSelector.default, - defaultCardinalityLimitSelector: CardinalityLimitSelector = - CardinalityLimitSelector.default + aggregationTemporalitySelector: AggregationTemporalitySelector = AggregationTemporalitySelector.alwaysCumulative, + defaultAggregationSelector: AggregationSelector = AggregationSelector.default, + defaultCardinalityLimitSelector: CardinalityLimitSelector = CardinalityLimitSelector.default ): Resource[F, OpenTelemetrySdkTestkit[F]] = Resource.eval(LocalProvider[F, Context].local).flatMap { implicit local => val traceContextLookup: TraceContextLookup = diff --git a/sdk/trace-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/trace/TracesTestkit.scala b/sdk/trace-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/trace/TracesTestkit.scala index e7e201ec9..d1b072476 100644 --- a/sdk/trace-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/trace/TracesTestkit.scala +++ b/sdk/trace-testkit/src/main/scala/org/typelevel/otel4s/sdk/testkit/trace/TracesTestkit.scala @@ -55,8 +55,7 @@ object TracesTestkit { * the customization of the builder */ def inMemory[F[_]: Async: Parallel: Console: LocalContextProvider]( - customize: SdkTracerProvider.Builder[F] => SdkTracerProvider.Builder[F] = - (b: SdkTracerProvider.Builder[F]) => b + customize: SdkTracerProvider.Builder[F] => SdkTracerProvider.Builder[F] = (b: SdkTracerProvider.Builder[F]) => b ): Resource[F, TracesTestkit[F]] = { def createTracerProvider( processor: SpanProcessor[F] diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/IdGenerator.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/IdGenerator.scala index 89fe4db54..a354bd046 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/IdGenerator.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/IdGenerator.scala @@ -42,8 +42,7 @@ trait IdGenerator[F[_]] { */ def generateTraceId: F[ByteVector] - /** Whether it's safe to skip the ID validation: we are sure the generated ids - * are valid. + /** Whether it's safe to skip the ID validation: we are sure the generated ids are valid. */ private[trace] def canSkipIdValidation: Boolean = false @@ -53,14 +52,12 @@ object IdGenerator { private final val InvalidId = 0 - /** Creates [[IdGenerator]] that uses [[cats.effect.std.Random]] under the - * hood. + /** Creates [[IdGenerator]] that uses [[cats.effect.std.Random]] under the hood. */ def random[F[_]: Monad: Random]: IdGenerator[F] = new RandomIdGenerator[F] - private final class RandomIdGenerator[F[_]: Monad: Random] - extends IdGenerator[F] { + private final class RandomIdGenerator[F[_]: Monad: Random] extends IdGenerator[F] { def generateSpanId: F[ByteVector] = Random[F].nextLong diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkContextKeys.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkContextKeys.scala index 872f4c348..f32d1b49b 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkContextKeys.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkContextKeys.scala @@ -25,8 +25,8 @@ import org.typelevel.otel4s.trace.SpanContext */ object SdkContextKeys { - /** The [[org.typelevel.otel4s.trace.SpanContext SpanContext]] is stored under - * this key in the [[org.typelevel.otel4s.sdk.context.Context Context]]. + /** The [[org.typelevel.otel4s.trace.SpanContext SpanContext]] is stored under this key in the + * [[org.typelevel.otel4s.sdk.context.Context Context]]. * * To retrieve the context use: * {{{ @@ -39,8 +39,8 @@ object SdkContextKeys { .unique[SyncIO, SpanContext]("otel4s-trace-span-context-key") .unsafeRunSync() - /** The [[org.typelevel.otel4s.baggage.Baggage Baggage]] is stored under this - * key in the [[org.typelevel.otel4s.sdk.context.Context Context]]. + /** The [[org.typelevel.otel4s.baggage.Baggage Baggage]] is stored under this key in the + * [[org.typelevel.otel4s.sdk.context.Context Context]]. * * To retrieve the baggage use: * {{{ diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackend.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackend.scala index 77e0d9b39..95596e23b 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackend.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackend.scala @@ -43,13 +43,10 @@ import org.typelevel.otel4s.trace.StatusCode import scala.collection.immutable import scala.concurrent.duration.FiniteDuration -/** The backend of the span that manages it's internal state. It has mutable and - * immutable states: - * - immutable state - cannot be modified at any point of the span's - * lifecycle, for example: span context, parent's span context, span kind, - * and so on - * - mutable state - can be modified during the lifecycle, for example: name, - * attributes, events, etc +/** The backend of the span that manages it's internal state. It has mutable and immutable states: + * - immutable state - cannot be modified at any point of the span's lifecycle, for example: span context, parent's + * span context, span kind, and so on + * - mutable state - can be modified during the lifecycle, for example: name, attributes, events, etc * * All modifications of the mutable state are ignored once the span is ended. * @@ -280,8 +277,8 @@ private object SdkSpanBackend { * the collection of [[LinkData]] of the span * * @param userStartTimestamp - * the explicit start timestamp. If `None` is passed the start time will be - * calculated automatically (via `Clock[F].realTime`) + * the explicit start timestamp. If `None` is passed the start time will be calculated automatically (via + * `Clock[F].realTime`) */ def start[F[_]: Temporal: Console]( context: SpanContext, diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTracerProvider.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTracerProvider.scala index ad437768e..9c0453b47 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTracerProvider.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTracerProvider.scala @@ -73,12 +73,10 @@ object SdkTracerProvider { /** Sets an [[IdGenerator]]. * - * [[IdGenerator]] will be used each time a - * [[org.typelevel.otel4s.trace.Span Span]] is started. + * [[IdGenerator]] will be used each time a [[org.typelevel.otel4s.trace.Span Span]] is started. * * @note - * the id generator must be thread-safe and return immediately (no remote - * calls, as contention free as possible). + * the id generator must be thread-safe and return immediately (no remote calls, as contention free as possible). * * @param idGenerator * the [[IdGenerator]] to use @@ -89,8 +87,7 @@ object SdkTracerProvider { * [[org.typelevel.otel4s.trace.Tracer Tracer]]. * * @note - * on multiple subsequent calls, the resource from the last call will be - * retained. + * on multiple subsequent calls, the resource from the last call will be retained. * * @param resource * the [[TelemetryResource]] to use @@ -100,8 +97,7 @@ object SdkTracerProvider { /** Merges the given [[TelemetryResource]] with the current one. * * @note - * if both resources have different non-empty `schemaUrl`, the merge will - * fail. + * if both resources have different non-empty `schemaUrl`, the merge will fail. * * @see * [[TelemetryResource.mergeUnsafe]] @@ -113,8 +109,7 @@ object SdkTracerProvider { /** Sets an initial [[SpanLimits]]. * - * The limits will be used for every - * [[org.typelevel.otel4s.trace.Span Span]]. + * The limits will be used for every [[org.typelevel.otel4s.trace.Span Span]]. * * @param limits * the [[SpanLimits]] to use @@ -123,21 +118,18 @@ object SdkTracerProvider { /** Sets a [[org.typelevel.otel4s.sdk.trace.samplers.Sampler Sampler]]. * - * The sampler will be called each time a - * [[org.typelevel.otel4s.trace.Span Span]] is started. + * The sampler will be called each time a [[org.typelevel.otel4s.trace.Span Span]] is started. * * @note - * the sampler must be thread-safe and return immediately (no remote - * calls, as contention free as possible). + * the sampler must be thread-safe and return immediately (no remote calls, as contention free as possible). * * @param sampler * the [[org.typelevel.otel4s.sdk.trace.samplers.Sampler Sampler]] to use */ def withSampler(sampler: Sampler): Builder[F] - /** Adds - * [[org.typelevel.otel4s.context.propagation.TextMapPropagator TextMapPropagator]]s - * to use for the context propagation. + /** Adds [[org.typelevel.otel4s.context.propagation.TextMapPropagator TextMapPropagator]]s to use for the context + * propagation. * * @param propagators * the propagators to add @@ -146,25 +138,22 @@ object SdkTracerProvider { propagators: TextMapPropagator[Context]* ): Builder[F] - /** Adds a - * [[org.typelevel.otel4s.sdk.trace.processor.SpanProcessor SpanProcessor]] - * to the span processing pipeline that will be built. + /** Adds a [[org.typelevel.otel4s.sdk.trace.processor.SpanProcessor SpanProcessor]] to the span processing pipeline + * that will be built. * - * The span processor will be called each time a - * [[org.typelevel.otel4s.trace.Span Span]] is started or ended. + * The span processor will be called each time a [[org.typelevel.otel4s.trace.Span Span]] is started or ended. * * @note - * the span processor must be thread-safe and return immediately (no - * remote calls, as contention free as possible). + * the span processor must be thread-safe and return immediately (no remote calls, as contention free as + * possible). * * @param processor * the span processor to add */ def addSpanProcessor(processor: SpanProcessor[F]): Builder[F] - /** Creates a new - * [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]] with the - * configuration of this builder. + /** Creates a new [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]] with the configuration of this + * builder. */ def build: F[TracerProvider[F]] } diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTraces.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTraces.scala index 0e61bc7e6..87055f05a 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTraces.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SdkTraces.scala @@ -55,13 +55,12 @@ sealed trait SdkTraces[F[_]] { */ def tracerProvider: TracerProvider[F] - /** The propagators used by the - * [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. + /** The propagators used by the [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. */ def propagators: ContextPropagators[Context] - /** The [[org.typelevel.otel4s.sdk.context.LocalContext LocalContext]] used by - * the [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. + /** The [[org.typelevel.otel4s.sdk.context.LocalContext LocalContext]] used by the + * [[org.typelevel.otel4s.trace.TracerProvider TracerProvider]]. */ def localContext: LocalContext[F] } @@ -71,8 +70,8 @@ object SdkTraces { /** Autoconfigures [[SdkTraces]] using [[AutoConfigured.Builder]]. * * @note - * the external components (e.g. OTLP exporter) must be registered - * manually. Add the `otel4s-sdk-exporter` dependency to the build file: + * the external components (e.g. OTLP exporter) must be registered manually. Add the `otel4s-sdk-exporter` + * dependency to the build file: * {{{ * libraryDependencies += "org.typelevel" %%% "otel4s-sdk-exporter" % "x.x.x" * }}} @@ -88,8 +87,7 @@ object SdkTraces { * a function for customizing the auto-configured SDK builder */ def autoConfigured[F[_]: Async: Parallel: Console: LocalContextProvider]( - customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = - (a: AutoConfigured.Builder[F]) => a + customize: AutoConfigured.Builder[F] => AutoConfigured.Builder[F] = (a: AutoConfigured.Builder[F]) => a ): Resource[F, SdkTraces[F]] = customize(AutoConfigured.builder[F]).build @@ -111,25 +109,24 @@ object SdkTraces { /** Sets the given config to use when resolving properties. * * @note - * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no - * effect if the custom config is provided. + * [[addPropertiesLoader]] and [[addPropertiesCustomizer]] will have no effect if the custom config is + * provided. * * @param config * the config to use */ def withConfig(config: Config): Builder[F] - /** Adds the properties loader. Multiple loaders will be added. The loaded - * properties will be merged with the default config. Loaded properties - * take precedence over the default ones. + /** Adds the properties loader. Multiple loaders will be added. The loaded properties will be merged with the + * default config. Loaded properties take precedence over the default ones. * * @param loader * the additional loader to add */ def addPropertiesLoader(loader: F[Map[String, String]]): Builder[F] - /** Adds the properties customizer. Multiple customizers can be added, and - * they will be applied in the order they were added. + /** Adds the properties customizer. Multiple customizers can be added, and they will be applied in the order they + * were added. * * @param customizer * the customizer to add @@ -138,8 +135,8 @@ object SdkTraces { customizer: Config => Map[String, String] ): Builder[F] - /** Adds the tracer provider builder customizer. Multiple customizers can - * be added, and they will be applied in the order they were added. + /** Adds the tracer provider builder customizer. Multiple customizers can be added, and they will be applied in + * the order they were added. * * @param customizer * the customizer to add @@ -148,8 +145,8 @@ object SdkTraces { customizer: Customizer[SdkTracerProvider.Builder[F]] ): Builder[F] - /** Adds the telemetry resource customizer. Multiple customizers can be - * added, and they will be applied in the order they were added. + /** Adds the telemetry resource customizer. Multiple customizers can be added, and they will be applied in the + * order they were added. * * @param customizer * the customizer to add @@ -158,17 +155,15 @@ object SdkTraces { customizer: Customizer[TelemetryResource] ): Builder[F] - /** Adds the telemetry resource detector. Multiple detectors can be added, - * and the detected telemetry resources will be merged. + /** Adds the telemetry resource detector. Multiple detectors can be added, and the detected telemetry resources + * will be merged. * * By default, the following detectors are enabled: * - host: `host.arch`, `host.name` * - os: `os.type`, `os.description` - * - process: `process.command`, `process.command_args`, - * `process.command_line`, `process.executable.name`, + * - process: `process.command`, `process.command_args`, `process.command_line`, `process.executable.name`, * `process.executable.path`, `process.pid`, `process.owner` - * - process_runtime: `process.runtime.name`, - * `process.runtime.version`, `process.runtime.description` + * - process_runtime: `process.runtime.name`, `process.runtime.version`, `process.runtime.description` * * @param detector * the detector to add @@ -177,8 +172,7 @@ object SdkTraces { detector: TelemetryResourceDetector[F] ): Builder[F] - /** Adds the exporter configurer. Can be used to register exporters that - * aren't included in the SDK. + /** Adds the exporter configurer. Can be used to register exporters that aren't included in the SDK. * * @example * Add the `otel4s-sdk-exporter` dependency to the build file: @@ -200,8 +194,7 @@ object SdkTraces { configurer: AutoConfigure.Named[F, SpanExporter[F]] ): Builder[F] - /** Adds the sampler configurer. Can be used to register samplers that - * aren't included in the SDK. + /** Adds the sampler configurer. Can be used to register samplers that aren't included in the SDK. * * @param configurer * the configurer to add @@ -210,8 +203,7 @@ object SdkTraces { configurer: AutoConfigure.Named[F, Sampler] ): Builder[F] - /** Adds the text map propagator configurer. Can be used to register - * propagators that aren't included in the SDK. + /** Adds the text map propagator configurer. Can be used to register propagators that aren't included in the SDK. * * @param configurer * the configurer to add @@ -284,9 +276,7 @@ object SdkTraces { def addTracerProviderCustomizer( customizer: Customizer[SdkTracerProvider.Builder[F]] ): Builder[F] = - copy(tracerProviderCustomizer = - merge(this.tracerProviderCustomizer, customizer) - ) + copy(tracerProviderCustomizer = merge(this.tracerProviderCustomizer, customizer)) def addExporterConfigurer( configurer: AutoConfigure.Named[F, SpanExporter[F]] @@ -301,18 +291,14 @@ object SdkTraces { def addTextMapPropagatorConfigurer( configurer: AutoConfigure.Named[F, TextMapPropagator[Context]] ): Builder[F] = - copy(textMapPropagatorConfigurers = - this.textMapPropagatorConfigurers + configurer - ) + copy(textMapPropagatorConfigurers = this.textMapPropagatorConfigurers + configurer) def build: Resource[F, SdkTraces[F]] = { def loadConfig: F[Config] = for { props <- propertiesLoader config <- Config.load(props) - } yield propertiesCustomizers.foldLeft(config)((cfg, c) => - cfg.withOverrides(c(cfg)) - ) + } yield propertiesCustomizers.foldLeft(config)((cfg, c) => cfg.withOverrides(c(cfg))) def loadNoop: Resource[F, SdkTraces[F]] = Resource.eval( diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanLimits.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanLimits.scala index b8fdebbf7..e97da240b 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanLimits.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanLimits.scala @@ -41,8 +41,8 @@ sealed trait SpanLimits { /** The max number of attributes per link. */ def maxNumberOfAttributesPerLink: Int - /** The max number of characters for string attribute values. For string array - * attribute values, applies to each entry individually. + /** The max number of characters for string attribute values. For string array attribute values, applies to each entry + * individually. */ def maxAttributeValueLength: Int @@ -88,8 +88,8 @@ object SpanLimits { /** Sets the max number of attributes per link. */ def withMaxNumberOfAttributesPerLink(value: Int): Builder - /** Sets the max number of characters for string attribute values. For - * string array attribute values, applies to each entry individually. + /** Sets the max number of characters for string attribute values. For string array attribute values, applies to + * each entry individually. */ def withMaxAttributeValueLength(value: Int): Builder diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanRef.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanRef.scala index d852a6580..213c7365c 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanRef.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/SpanRef.scala @@ -28,8 +28,7 @@ import scala.concurrent.duration.FiniteDuration /** An extended Span interface that provides access to internal state. * - * Since the span's internal state can be mutated during the lifetime, some - * operations are effectful. + * Since the span's internal state can be mutated during the lifetime, some operations are effectful. * * @tparam F * the higher-kinded type of a polymorphic effect @@ -39,8 +38,7 @@ trait SpanRef[F[_]] extends Span.Backend[F] { /** Returns the kind of the span. */ def kind: SpanKind - /** Returns the instrumentation scope specified when creating the tracer which - * produced this span. + /** Returns the instrumentation scope specified when creating the tracer which produced this span. */ def scopeInfo: InstrumentationScope @@ -50,14 +48,12 @@ trait SpanRef[F[_]] extends Span.Backend[F] { /** Returns the name of the span. * * @note - * the name of the span can be changed during the lifetime of the span by - * using [[org.typelevel.otel4s.trace.Span.updateName Span.updateName]], so - * this value cannot be cached. + * the name of the span can be changed during the lifetime of the span by using + * [[org.typelevel.otel4s.trace.Span.updateName Span.updateName]], so this value cannot be cached. */ def name: F[String] - /** Returns an immutable instance of the [[data.SpanData SpanData]], for use - * in export. + /** Returns an immutable instance of the [[data.SpanData SpanData]], for use in export. */ def toSpanData: F[SpanData] @@ -70,14 +66,11 @@ trait SpanRef[F[_]] extends Span.Backend[F] { */ def duration: F[FiniteDuration] - /** Returns the attribute value for the given `key`. Returns `None` if the key - * is absent in the storage. + /** Returns the attribute value for the given `key`. Returns `None` if the key is absent in the storage. * * @note - * the attribute values can be changed during the lifetime of the span by - * using - * [[org.typelevel.otel4s.trace.Span.addAttribute Span.addAttribute]], so - * this value cannot be cached. + * the attribute values can be changed during the lifetime of the span by using + * [[org.typelevel.otel4s.trace.Span.addAttribute Span.addAttribute]], so this value cannot be cached. */ def getAttribute[A](key: AttributeKey[A]): F[Option[A]] diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/SamplerAutoConfigure.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/SamplerAutoConfigure.scala index d1615264b..5743a9b5c 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/SamplerAutoConfigure.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/SamplerAutoConfigure.scala @@ -141,24 +141,19 @@ private[sdk] object SamplerAutoConfigure { * | otel.traces.sampler.arg | OTEL_TRACES_SAMPLER_ARG | An argument to the configured tracer if supported, for example a ratio. | * }}} * - * The following options for `otel.traces.sampler` are supported out of the - * box: + * The following options for `otel.traces.sampler` are supported out of the box: * - `always_on` - [[Sampler.AlwaysOn]] * * - `always_off` - [[Sampler.AlwaysOff]] * - * - `traceidratio` - [[Sampler.traceIdRatioBased]], where - * `otel.traces.sampler.arg` sets the ratio + * - `traceidratio` - [[Sampler.traceIdRatioBased]], where `otel.traces.sampler.arg` sets the ratio * - * - `parentbased_always_on` - [[Sampler.parentBased]] with - * [[Sampler.AlwaysOn]] + * - `parentbased_always_on` - [[Sampler.parentBased]] with [[Sampler.AlwaysOn]] * - * - `parentbased_always_off` - [[Sampler.parentBased]] with - * [[Sampler.AlwaysOff]] + * - `parentbased_always_off` - [[Sampler.parentBased]] with [[Sampler.AlwaysOff]] * - * - `parentbased_traceidratio`- [[Sampler.parentBased]] with - * [[Sampler.traceIdRatioBased]], where `otel.traces.sampler.arg` sets - * the ratio + * - `parentbased_traceidratio`- [[Sampler.parentBased]] with [[Sampler.traceIdRatioBased]], where + * `otel.traces.sampler.arg` sets the ratio * * @see * [[https://opentelemetry.io/docs/languages/java/configuration/#sampler]] diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3Propagator.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3Propagator.scala index d5e16ed3c..055fe48b2 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3Propagator.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3Propagator.scala @@ -32,8 +32,7 @@ import scodec.bits.ByteVector /** A B3 propagator. * - * The propagator extracts span details from the `single` and `multiple` - * headers. + * The propagator extracts span details from the `single` and `multiple` headers. * * The injection format depends on the provided `injector`. * @@ -80,14 +79,13 @@ object B3Propagator { .unsafeRunSync() } - /** Returns a [[B3Propagator]] that injects span details into a single `b3` - * header. + /** Returns a [[B3Propagator]] that injects span details into a single `b3` header. */ def singleHeader: TextMapPropagator[Context] = SingleHeader - /** Returns a [[B3Propagator]] that injects span details into multiple - * headers: `X-B3-TraceId`, `X-B3-SpanId`, `X-B3-Sampled`. + /** Returns a [[B3Propagator]] that injects span details into multiple headers: `X-B3-TraceId`, `X-B3-SpanId`, + * `X-B3-Sampled`. */ def multipleHeaders: TextMapPropagator[Context] = MultipleHeaders diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/JaegerPropagator.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/JaegerPropagator.scala index a43c036d2..e7edd5664 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/JaegerPropagator.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/JaegerPropagator.scala @@ -87,10 +87,9 @@ private final class JaegerPropagator extends TextMapPropagator[Context] { ctx.get(SdkContextKeys.BaggageKey) match { case Some(baggage) => - baggage.asMap.foldLeft(withSpanContext) { - case (carrier, (key, entry)) => - val k = Const.BaggagePrefix + key - TextMapUpdater[A].updated(carrier, k, urlEncode(entry.value)) + baggage.asMap.foldLeft(withSpanContext) { case (carrier, (key, entry)) => + val k = Const.BaggagePrefix + key + TextMapUpdater[A].updated(carrier, k, urlEncode(entry.value)) } case None => diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CBaggagePropagator.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CBaggagePropagator.scala index 1c2330c32..db0ae6316 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CBaggagePropagator.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CBaggagePropagator.scala @@ -79,28 +79,24 @@ private final class W3CBaggagePropagator extends TextMapPropagator[Context] { .mkString(",") private def decode(headerContent: String): Baggage = - headerContent.split(Const.Delimiter).foldLeft(Baggage.empty) { - case (baggage, entry) => - val parts = entry.split(Const.ValueDelimiter, 2) - if (parts.length == 2) { - val key = parts(0).trim - val value = parts(1).trim - - if (isValidKey(key)) { - val entryParts = value.split(Const.MetadataDelimiter, 2) - if (entryParts.nonEmpty) { - val value = entryParts(0).trim - if (isValidValue(value)) { - val decoded = urlDecode(value) - val meta = entryParts - .lift(1) - .map(_.trim) - .filter(_.nonEmpty) - .map(urlDecode) - baggage.updated(key, decoded, meta) - } else { - baggage - } + headerContent.split(Const.Delimiter).foldLeft(Baggage.empty) { case (baggage, entry) => + val parts = entry.split(Const.ValueDelimiter, 2) + if (parts.length == 2) { + val key = parts(0).trim + val value = parts(1).trim + + if (isValidKey(key)) { + val entryParts = value.split(Const.MetadataDelimiter, 2) + if (entryParts.nonEmpty) { + val value = entryParts(0).trim + if (isValidValue(value)) { + val decoded = urlDecode(value) + val meta = entryParts + .lift(1) + .map(_.trim) + .filter(_.nonEmpty) + .map(urlDecode) + baggage.updated(key, decoded, meta) } else { baggage } @@ -110,6 +106,9 @@ private final class W3CBaggagePropagator extends TextMapPropagator[Context] { } else { baggage } + } else { + baggage + } } private def urlEncode(input: String): String = @@ -143,8 +142,7 @@ object W3CBaggagePropagator { // see https://datatracker.ietf.org/doc/html/rfc7230#section-3.2.6 val AllowedKeyChars: Set[Char] = - Set('!', '#', '$', '%', '&', '\'', '*', '+', '-', '.', '^', '_', '`', '|', - '~') ++ + Set('!', '#', '$', '%', '&', '\'', '*', '+', '-', '.', '^', '_', '`', '|', '~') ++ ('0' to '9') ++ ('a' to 'z') ++ ('A' to 'Z') diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CTraceContextPropagator.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CTraceContextPropagator.scala index 1aafefe70..1866cd382 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CTraceContextPropagator.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/context/propagation/W3CTraceContextPropagator.scala @@ -33,8 +33,7 @@ import org.typelevel.otel4s.trace.TraceState * @see * [[https://www.w3.org/TR/trace-context/]] */ -private final class W3CTraceContextPropagator - extends TextMapPropagator[Context] { +private final class W3CTraceContextPropagator extends TextMapPropagator[Context] { import W3CTraceContextPropagator.Headers import W3CTraceContextPropagator.Const diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/EventData.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/EventData.scala index 6394c4f4d..7ccef25b8 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/EventData.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/EventData.scala @@ -84,8 +84,7 @@ object EventData { * * The name of the even will be `exception`. * - * Exception details (name, message, and stacktrace) will be added to the - * attributes. + * Exception details (name, message, and stacktrace) will be added to the attributes. * * @param timestamp * the timestamp of the event @@ -97,8 +96,8 @@ object EventData { * the attributes to associate with the event * * @param escaped - * should be set to true if the exception is recorded at a point where it - * is known that the exception is escaping the scope of the span + * should be set to true if the exception is recorded at a point where it is known that the exception is escaping + * the scope of the span */ def fromException( timestamp: FiniteDuration, diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LimitedData.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LimitedData.scala index 42feb6dac..6cabcb6af 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LimitedData.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LimitedData.scala @@ -47,24 +47,23 @@ sealed trait LimitedData[A, S <: immutable.Iterable[A]] { */ def elements: S - /** Appends an element to the container if the number of container elements - * has not reached the limit, otherwise drops the element. + /** Appends an element to the container if the number of container elements has not reached the limit, otherwise drops + * the element. * * @param a * the element to append */ def append(a: A): LimitedData[A, S] - /** Appends all given elements to the container up to the limit and drops the - * rest elements. + /** Appends all given elements to the container up to the limit and drops the rest elements. * * @param as * the collection of elements to append */ def appendAll(as: S): LimitedData[A, S] - /** Prepends all given elements to the container up to the limit and drops all - * elements that exceeds the limit (even if they already existed before). + /** Prepends all given elements to the container up to the limit and drops all elements that exceeds the limit (even + * if they already existed before). * * @param as * the collection of elements to prepend @@ -81,8 +80,7 @@ sealed trait LimitedData[A, S <: immutable.Iterable[A]] { object LimitedData { - implicit def limitedDataHash[A, S <: immutable.Iterable[A]: Hash] - : Hash[LimitedData[A, S]] = + implicit def limitedDataHash[A, S <: immutable.Iterable[A]: Hash]: Hash[LimitedData[A, S]] = Hash.by(events => (events.sizeLimit, events.dropped, events.elements)) /** Created [[LimitedData]] with the collection of [[Attribute]] inside. diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LinkData.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LinkData.scala index 28c5e9054..db5e7db21 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LinkData.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/LinkData.scala @@ -33,8 +33,7 @@ import org.typelevel.otel4s.trace.SpanContext */ sealed trait LinkData { - /** The [[org.typelevel.otel4s.trace.SpanContext SpanContext]] of the span - * this link refers to. + /** The [[org.typelevel.otel4s.trace.SpanContext SpanContext]] of the span this link refers to. */ def spanContext: SpanContext diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/SpanData.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/SpanData.scala index bdd3d6b4a..b31193bee 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/SpanData.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/SpanData.scala @@ -29,8 +29,7 @@ import org.typelevel.otel4s.trace.SpanKind import scala.concurrent.duration.FiniteDuration -/** Immutable representation of all data collected by the - * [[org.typelevel.otel4s.trace.Span Span]]. +/** Immutable representation of all data collected by the [[org.typelevel.otel4s.trace.Span Span]]. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/api/#span]] @@ -113,8 +112,7 @@ object SpanData { * the span context associated with the span * * @param parentSpanContext - * an optional parent span context. Use `None` if there is no parent span - * context + * an optional parent span context. Use `None` if there is no parent span context * * @param kind * the kind of the span diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/StatusData.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/StatusData.scala index e6a52ad64..b1d1c7ef3 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/StatusData.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/data/StatusData.scala @@ -21,8 +21,7 @@ import cats.Show import cats.syntax.show._ import org.typelevel.otel4s.trace.StatusCode -/** Defines the status of a span by providing a standard status in conjunction - * with an optional description message. +/** Defines the status of a span by providing a standard status in conjunction with an optional description message. * * @param status * status code @@ -51,8 +50,7 @@ sealed abstract class StatusData(val status: StatusCode) { object StatusData { - /** Indicates the successfully completed operation, validated by an - * application developer or operator. + /** Indicates the successfully completed operation, validated by an application developer or operator. */ case object Ok extends StatusData(StatusCode.Ok) { def description: Option[String] = None @@ -66,8 +64,7 @@ object StatusData { /** Indicates an occurred error. */ - final case class Error(description: Option[String]) - extends StatusData(StatusCode.Error) + final case class Error(description: Option[String]) extends StatusData(StatusCode.Error) /** Returns [[StatusData]] for the given `status`. */ diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporter.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporter.scala index f885b501b..010c453ae 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporter.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporter.scala @@ -22,15 +22,12 @@ import cats.effect.std.Console import cats.syntax.foldable._ import org.typelevel.otel4s.sdk.trace.data.SpanData -/** Creates a span exporter that logs every span using - * [[cats.effect.std.Console]]. +/** Creates a span exporter that logs every span using [[cats.effect.std.Console]]. * * @note - * use this exporter for debugging purposes because it may affect the - * performance + * use this exporter for debugging purposes because it may affect the performance */ -private final class ConsoleSpanExporter[F[_]: Applicative: Console] - extends SpanExporter[F] { +private final class ConsoleSpanExporter[F[_]: Applicative: Console] extends SpanExporter[F] { val name: String = "ConsoleSpanExporter" diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/SpanExporter.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/SpanExporter.scala index 8d4c22d54..049a52020 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/SpanExporter.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/exporter/SpanExporter.scala @@ -26,8 +26,7 @@ import cats.data.NonEmptyList import cats.syntax.all._ import org.typelevel.otel4s.sdk.trace.data.SpanData -/** An interface that allows different tracing services to export recorded data - * for sampled spans in their own format. +/** An interface that allows different tracing services to export recorded data for sampled spans in their own format. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#span-exporter]] @@ -39,8 +38,7 @@ trait SpanExporter[F[_]] { /** The name of the exporter. * - * It will be used in an exception to distinguish individual failures in the - * multi-error scenario. + * It will be used in an exception to distinguish individual failures in the multi-error scenario. * * @see * [[org.typelevel.otel4s.sdk.trace.exporter.SpanExporter.ExporterFailure SpanExporter.ExporterFailure]] @@ -50,27 +48,23 @@ trait SpanExporter[F[_]] { */ def name: String - /** Called to export sampled - * [[org.typelevel.otel4s.sdk.trace.data.SpanData SpanData]]. + /** Called to export sampled [[org.typelevel.otel4s.sdk.trace.data.SpanData SpanData]]. * * @note - * the export operations can be performed simultaneously depending on the - * type of span processor being used. However, the batch span processor - * will ensure that only one export can occur at a time. + * the export operations can be performed simultaneously depending on the type of span processor being used. + * However, the batch span processor will ensure that only one export can occur at a time. * * @param spans * the sampled spans to be exported */ def exportSpans[G[_]: Foldable](spans: G[SpanData]): F[Unit] - /** Exports the collection of sampled - * [[org.typelevel.otel4s.sdk.trace.data.SpanData SpanData]] that have not - * yet been exported. + /** Exports the collection of sampled [[org.typelevel.otel4s.sdk.trace.data.SpanData SpanData]] that have not yet been + * exported. * * @note - * the export operations can be performed simultaneously depending on the - * type of span processor being used. However, the batch span processor - * will ensure that only one export can occur at a time. + * the export operations can be performed simultaneously depending on the type of span processor being used. + * However, the batch span processor will ensure that only one export can occur at a time. */ def flush: F[Unit] @@ -95,8 +89,7 @@ object SpanExporter { def noop[F[_]: Applicative]: SpanExporter[F] = new Noop - implicit def spanExporterMonoid[F[_]: MonadThrow: Parallel] - : Monoid[SpanExporter[F]] = + implicit def spanExporterMonoid[F[_]: MonadThrow: Parallel]: Monoid[SpanExporter[F]] = new Monoid[SpanExporter[F]] { val empty: SpanExporter[F] = noop[F] diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessor.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessor.scala index 31484ccaf..71709f4ec 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessor.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessor.scala @@ -34,15 +34,14 @@ import org.typelevel.otel4s.trace.SpanContext import scala.concurrent.duration._ -/** Implementation of the [[SpanProcessor]] that batches spans exported by the - * SDK then pushes them to the exporter pipeline. +/** Implementation of the [[SpanProcessor]] that batches spans exported by the SDK then pushes them to the exporter + * pipeline. * - * All spans reported by the SDK implementation are first added to a queue. If - * the queue is full (with a `config.maxQueueSize` maximum size), the incoming - * spans are dropped. + * All spans reported by the SDK implementation are first added to a queue. If the queue is full (with a + * `config.maxQueueSize` maximum size), the incoming spans are dropped. * - * Spans are exported either when there are `config.maxExportBatchSize` pending - * spans or `config.scheduleDelay` has passed since the last export attempt. + * Spans are exported either when there are `config.maxExportBatchSize` pending spans or `config.scheduleDelay` has + * passed since the last export attempt. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#batching-processor]] @@ -196,23 +195,20 @@ object BatchSpanProcessor { */ def withScheduleDelay(delay: FiniteDuration): Builder[F] - /** Sets the maximum time an export will be allowed to run before being - * cancelled. + /** Sets the maximum time an export will be allowed to run before being cancelled. * * Default value is `30 seconds`. */ def withExporterTimeout(timeout: FiniteDuration): Builder[F] - /** Sets the maximum number of Spans that are kept in the queue before start - * dropping. More memory than this value may be allocated to optimize queue - * access. + /** Sets the maximum number of Spans that are kept in the queue before start dropping. More memory than this value + * may be allocated to optimize queue access. * * Default value is `2048`. */ def withMaxQueueSize(maxQueueSize: Int): Builder[F] - /** Sets the maximum batch size for every export. This must be smaller or - * equal to `maxQueueSize`. + /** Sets the maximum batch size for every export. This must be smaller or equal to `maxQueueSize`. * * Default value is `512`. */ @@ -247,15 +243,13 @@ object BatchSpanProcessor { /** The configuration of the [[BatchSpanProcessor]]. * * @param scheduleDelay - * the maximum delay interval in milliseconds between two consecutive - * exports + * the maximum delay interval in milliseconds between two consecutive exports * * @param exporterTimeout * how long the export can run before it is cancelled * * @param maxQueueSize - * the maximum queue size. Once the the limit is reached new spans will be - * dropped + * the maximum queue size. Once the the limit is reached new spans will be dropped * * @param maxExportBatchSize * the maximum batch size of every export diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessor.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessor.scala index 4a1d1aa75..fb6f7618e 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessor.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessor.scala @@ -25,12 +25,11 @@ import org.typelevel.otel4s.sdk.trace.data.SpanData import org.typelevel.otel4s.sdk.trace.exporter.SpanExporter import org.typelevel.otel4s.trace.SpanContext -/** An implementation of the [[SpanProcessor]] that passes ended - * [[data.SpanData SpanData]] directly to the configured exporter. +/** An implementation of the [[SpanProcessor]] that passes ended [[data.SpanData SpanData]] directly to the configured + * exporter. * * @note - * this processor exports spans individually upon completion, resulting in a - * single span per export request. + * this processor exports spans individually upon completion, resulting in a single span per export request. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#simple-processor]] @@ -70,8 +69,7 @@ final class SimpleSpanProcessor[F[_]: MonadThrow: Console] private ( object SimpleSpanProcessor { - /** Creates a [[SimpleSpanProcessor]] that passes only '''sampled''' ended - * spans to the given `exporter`. + /** Creates a [[SimpleSpanProcessor]] that passes only '''sampled''' ended spans to the given `exporter`. * * @param exporter * the [[exporter.SpanExporter SpanExporter]] to use @@ -81,8 +79,7 @@ object SimpleSpanProcessor { ): SimpleSpanProcessor[F] = apply(exporter, exportOnlySampled = true) - /** Creates a [[SimpleSpanProcessor]] that passes ended spans to the given - * `exporter`. + /** Creates a [[SimpleSpanProcessor]] that passes ended spans to the given `exporter`. * * @param exporter * the [[exporter.SpanExporter SpanExporter]] to use diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SpanProcessor.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SpanProcessor.scala index 5aaadd9e0..c7191ce71 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SpanProcessor.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/processor/SpanProcessor.scala @@ -27,8 +27,7 @@ import cats.syntax.all._ import org.typelevel.otel4s.sdk.trace.data.SpanData import org.typelevel.otel4s.trace.SpanContext -/** The interface that tracer uses to invoke hooks when a span is started or - * ended. +/** The interface that tracer uses to invoke hooks when a span is started or ended. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#span-processor]] @@ -40,8 +39,7 @@ trait SpanProcessor[F[_]] { /** The name of the processor. * - * It will be used in an exception to distinguish individual failures in the - * multi-error scenario. + * It will be used in an exception to distinguish individual failures in the multi-error scenario. * * @see * [[SpanProcessor.ProcessorFailure]] @@ -53,8 +51,7 @@ trait SpanProcessor[F[_]] { /** Called when a span is started, if the `span.isRecording` returns true. * - * This method is called synchronously on the execution thread, should not - * throw or block the execution thread. + * This method is called synchronously on the execution thread, should not throw or block the execution thread. * * @param parentContext * the optional parent [[trace.SpanContext SpanContext]] @@ -72,8 +69,7 @@ trait SpanProcessor[F[_]] { /** Called when a span is ended, if the `span.isRecording` returns true. * - * This method is called synchronously on the execution thread, should not - * throw or block the execution thread. + * This method is called synchronously on the execution thread, should not throw or block the execution thread. * * @param span * the ended span @@ -96,8 +92,7 @@ trait SpanProcessor[F[_]] { object SpanProcessor { - /** Creates a [[SpanProcessor]] which delegates all processing to the - * processors in order. + /** Creates a [[SpanProcessor]] which delegates all processing to the processors in order. */ def of[F[_]: MonadThrow: Parallel]( processors: SpanProcessor[F]* @@ -112,8 +107,7 @@ object SpanProcessor { def noop[F[_]: Applicative]: SpanProcessor[F] = new Noop - implicit def spanProcessorMonoid[F[_]: MonadThrow: Parallel] - : Monoid[SpanProcessor[F]] = + implicit def spanProcessorMonoid[F[_]: MonadThrow: Parallel]: Monoid[SpanProcessor[F]] = new Monoid[SpanProcessor[F]] { val empty: SpanProcessor[F] = noop[F] diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSampler.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSampler.scala index 0729f57b4..b8c576379 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSampler.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSampler.scala @@ -24,8 +24,7 @@ import scodec.bits.ByteVector /** Sampler that uses the sampled flag of the parent Span, if present. * - * If the span has no parent, this Sampler will use the "root" sampler that it - * is built with. + * If the span has no parent, this Sampler will use the "root" sampler that it is built with. * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#parentbased]] @@ -77,18 +76,17 @@ private[samplers] final case class ParentBasedSampler private ( object ParentBasedSampler { - /** Creates a [[Builder]] for the parent-based sampler that enables - * configuration of the parent-based sampling strategy. + /** Creates a [[Builder]] for the parent-based sampler that enables configuration of the parent-based sampling + * strategy. * - * The parent's sampling decision is used if a parent span exists, otherwise - * this strategy uses the root sampler's decision. + * The parent's sampling decision is used if a parent span exists, otherwise this strategy uses the root sampler's + * decision. * - * There are a several options available on the builder to control the - * precise behavior of how the decision will be made. + * There are a several options available on the builder to control the precise behavior of how the decision will be + * made. * * @param root - * the [[Sampler]] which is used to make the sampling decisions if the - * parent does not exist + * the [[Sampler]] which is used to make the sampling decisions if the parent does not exist */ def builder(root: Sampler): Builder = BuilderImpl(root, None, None, None, None) @@ -97,34 +95,27 @@ object ParentBasedSampler { */ sealed trait Builder { - /** Assigns the [[Sampler]] to use when there is a remote parent that was - * sampled. + /** Assigns the [[Sampler]] to use when there is a remote parent that was sampled. * - * If not set, defaults to always sampling if the remote parent was - * sampled. + * If not set, defaults to always sampling if the remote parent was sampled. */ def withRemoteParentSampled(sampler: Sampler): Builder - /** Assigns the [[Sampler]] to use when there is a remote parent that was - * not sampled. + /** Assigns the [[Sampler]] to use when there is a remote parent that was not sampled. * - * If not set, defaults to never sampling when the remote parent isn't - * sampled. + * If not set, defaults to never sampling when the remote parent isn't sampled. */ def withRemoteParentNotSampled(sampler: Sampler): Builder - /** Assigns the [[Sampler]] to use when there is a local parent that was - * sampled. + /** Assigns the [[Sampler]] to use when there is a local parent that was sampled. * * If not set, defaults to always sampling if the local parent was sampled. */ def withLocalParentSampled(sampler: Sampler): Builder - /** Assigns the [[Sampler]] to use when there is a local parent that was not - * sampled. + /** Assigns the [[Sampler]] to use when there is a local parent that was not sampled. * - * If not set, defaults to never sampling when the local parent isn't - * sampled. + * If not set, defaults to never sampling when the local parent isn't sampled. */ def withLocalParentNotSampled(sampler: Sampler): Builder diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/Sampler.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/Sampler.scala index 803c1a185..22f94fa73 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/Sampler.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/Sampler.scala @@ -60,8 +60,7 @@ trait Sampler { parentLinks: Vector[LinkData] ): SamplingResult - /** The description of the [[Sampler]]. This may be displayed on debug pages - * or in the logs. + /** The description of the [[Sampler]]. This may be displayed on debug pages or in the logs. */ def description: String @@ -86,31 +85,27 @@ object Sampler { val AlwaysOff: Sampler = new Const(SamplingResult.Drop, "AlwaysOffSampler") - /** Returns a [[Sampler]] that always makes the same decision as the parent - * Span to whether or not to sample. + /** Returns a [[Sampler]] that always makes the same decision as the parent Span to whether or not to sample. * - * If there is no parent, the sampler uses the provided root [[Sampler]] to - * determine the sampling decision. + * If there is no parent, the sampler uses the provided root [[Sampler]] to determine the sampling decision. * * @param root - * the [[Sampler]] which is used to make the sampling decisions if the - * parent does not exist + * the [[Sampler]] which is used to make the sampling decisions if the parent does not exist */ def parentBased(root: Sampler): Sampler = parentBasedBuilder(root).build - /** Creates a [[ParentBasedSampler.Builder]] for parent-based sampler that - * enables configuration of the parent-based sampling strategy. + /** Creates a [[ParentBasedSampler.Builder]] for parent-based sampler that enables configuration of the parent-based + * sampling strategy. * - * The parent's sampling decision is used if a parent span exists, otherwise - * this strategy uses the root sampler's decision. + * The parent's sampling decision is used if a parent span exists, otherwise this strategy uses the root sampler's + * decision. * - * There are a several options available on the builder to control the - * precise behavior of how the decision will be made. + * There are a several options available on the builder to control the precise behavior of how the decision will be + * made. * * @param root - * the [[Sampler]] which is used to make the sampling decisions if the - * parent does not exist + * the [[Sampler]] which is used to make the sampling decisions if the parent does not exist */ def parentBasedBuilder(root: Sampler): ParentBasedSampler.Builder = ParentBasedSampler.builder(root) @@ -119,12 +114,11 @@ object Sampler { * * The ratio of sampling a trace is equal to that of the specified ratio. * - * The algorithm used by the Sampler is undefined, notably it may or may not - * use parts of the trace ID when generating a sampling decision. + * The algorithm used by the Sampler is undefined, notably it may or may not use parts of the trace ID when + * generating a sampling decision. * - * Currently, only the ratio of traces that are sampled can be relied on, not - * how the sampled traces are determined. As such, it is recommended to only - * use this [[Sampler]] for root spans using [[parentBased]]. + * Currently, only the ratio of traces that are sampled can be relied on, not how the sampled traces are determined. + * As such, it is recommended to only use this [[Sampler]] for root spans using [[parentBased]]. * * @param ratio * the desired ratio of sampling. Must be >= 0 and <= 1.0. diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingDecision.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingDecision.scala index 40de3db88..357276ec2 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingDecision.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingDecision.scala @@ -31,18 +31,15 @@ object SamplingDecision { /** The span is not recorded, and all events and attributes will be dropped. */ - case object Drop - extends SamplingDecision(isSampled = false, isRecording = false) + case object Drop extends SamplingDecision(isSampled = false, isRecording = false) /** The span is recorded, but the Sampled flag will not be set. */ - case object RecordOnly - extends SamplingDecision(isSampled = false, isRecording = true) + case object RecordOnly extends SamplingDecision(isSampled = false, isRecording = true) /** The span is recorded, and the Sampled flag will be set. */ - case object RecordAndSample - extends SamplingDecision(isSampled = true, isRecording = true) + case object RecordAndSample extends SamplingDecision(isSampled = true, isRecording = true) implicit val samplingDecisionHash: Hash[SamplingDecision] = Hash.fromUniversalHashCode diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingResult.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingResult.scala index 479848ea4..c73bdd5c1 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingResult.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/SamplingResult.scala @@ -29,8 +29,7 @@ import org.typelevel.otel4s.trace.TraceState */ sealed trait SamplingResult { - /** The decision on whether a span should be recorded, recorded and sampled or - * not recorded. + /** The decision on whether a span should be recorded, recorded and sampled or not recorded. */ def decision: SamplingDecision @@ -40,14 +39,12 @@ sealed trait SamplingResult { /** A modifier of the parent's TraceState. * - * It may return the same trace state that was provided originally, or an - * updated one. + * It may return the same trace state that was provided originally, or an updated one. * * @note - * if updated returns an empty trace state, the trace state will be - * cleared, so samplers should normally use - * [[SamplingResult.TraceStateUpdater.Identity]] to return the passed-in - * trace state if it's not intended to be changed. + * if updated returns an empty trace state, the trace state will be cleared, so samplers should normally use + * [[SamplingResult.TraceStateUpdater.Identity]] to return the passed-in trace state if it's not intended to be + * changed. */ def traceStateUpdater: SamplingResult.TraceStateUpdater @@ -68,13 +65,11 @@ object SamplingResult { /** A modifier of the parent's TraceState. * - * It may return the same trace state that was provided originally, or an - * updated one. + * It may return the same trace state that was provided originally, or an updated one. * * @note - * if an empty trace state is returned, the trace state will be cleared, so - * the updater should normally return the passed-in trace state (via - * [[TraceStateUpdater.Identity]]) if it's intended to be changed. + * if an empty trace state is returned, the trace state will be cleared, so the updater should normally return the + * passed-in trace state (via [[TraceStateUpdater.Identity]]) if it's intended to be changed. */ sealed trait TraceStateUpdater { def update(state: TraceState): TraceState @@ -88,8 +83,7 @@ object SamplingResult { } /** Returns the given trace state modified by the `modify` function. */ - final case class Modifier(modify: TraceState => TraceState) - extends TraceStateUpdater { + final case class Modifier(modify: TraceState => TraceState) extends TraceStateUpdater { def update(state: TraceState): TraceState = modify(state) } @@ -110,20 +104,20 @@ object SamplingResult { } } - /** The [[SamplingResult]] with the [[SamplingDecision.RecordAndSample]] - * decision, no attributes, and [[TraceStateUpdater.Identity]] updater. + /** The [[SamplingResult]] with the [[SamplingDecision.RecordAndSample]] decision, no attributes, and + * [[TraceStateUpdater.Identity]] updater. */ val RecordAndSample: SamplingResult = fromDecision(SamplingDecision.RecordAndSample) - /** The [[SamplingResult]] with the [[SamplingDecision.RecordOnly]] decision, - * no attributes, and [[TraceStateUpdater.Identity]] updater. + /** The [[SamplingResult]] with the [[SamplingDecision.RecordOnly]] decision, no attributes, and + * [[TraceStateUpdater.Identity]] updater. */ val RecordOnly: SamplingResult = fromDecision(SamplingDecision.RecordOnly) - /** The [[SamplingResult]] with the [[SamplingDecision.Drop]] decision, no - * attributes, and [[TraceStateUpdater.Identity]] updater. + /** The [[SamplingResult]] with the [[SamplingDecision.Drop]] decision, no attributes, and + * [[TraceStateUpdater.Identity]] updater. */ val Drop: SamplingResult = fromDecision(SamplingDecision.Drop) @@ -155,8 +149,7 @@ object SamplingResult { if (attributes.isEmpty) apply(decision) else Impl(decision, attributes, TraceStateUpdater.Identity) - /** Creates a [[SamplingResult]] with the given `decision`, `attributes`, and - * `traceStateUpdater`. + /** Creates a [[SamplingResult]] with the given `decision`, `attributes`, and `traceStateUpdater`. * * @param decision * the [[SamplingDecision]] to associate with the result diff --git a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/TraceIdRatioBasedSampler.scala b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/TraceIdRatioBasedSampler.scala index e2f70fa45..445ba1f16 100644 --- a/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/TraceIdRatioBasedSampler.scala +++ b/sdk/trace/src/main/scala/org/typelevel/otel4s/sdk/trace/samplers/TraceIdRatioBasedSampler.scala @@ -26,15 +26,12 @@ import scodec.bits.ByteVector /** The input `ratio` must be between 0 and 1.0. * - * 0.1 means only 10% of the incoming spans will be sampled, and 1.0 stands for - * 100%. + * 0.1 means only 10% of the incoming spans will be sampled, and 1.0 stands for 100%. * - * The ratio-based sampler must be deterministic, so it utilizes the Long value - * extracted from the trace id. + * The ratio-based sampler must be deterministic, so it utilizes the Long value extracted from the trace id. * - * The logic is the following: the sampling result will be - * [[SamplingResult.RecordAndSample]] if the extracted long value is lower than - * the upper bound limit (`ratio` * Long.MaxValue). + * The logic is the following: the sampling result will be [[SamplingResult.RecordAndSample]] if the extracted long + * value is lower than the upper bound limit (`ratio` * Long.MaxValue). * * @see * [[https://opentelemetry.io/docs/specs/otel/trace/sdk/#traceidratiobased]] @@ -70,15 +67,12 @@ private object TraceIdRatioBasedSampler { * * The ratio of sampling a trace is equal to that of the specified `ratio`. * - * 0.1 means only 10% of the incoming spans will be sampled, and 1.0 stands - * for 100%. + * 0.1 means only 10% of the incoming spans will be sampled, and 1.0 stands for 100%. * - * The ratio-based sampler must be deterministic, so it utilizes the Long - * value extracted from the trace id. + * The ratio-based sampler must be deterministic, so it utilizes the Long value extracted from the trace id. * - * The logic is the following: the sampling result will be - * [[SamplingResult.RecordAndSample]] if the extracted long value is lower - * than the upper bound limit (`ratio` * Long.MaxValue). + * The logic is the following: the sampling result will be [[SamplingResult.RecordAndSample]] if the extracted long + * value is lower than the upper bound limit (`ratio` * Long.MaxValue). * * @param ratio * the desired ratio of sampling. Must be >= 0 and <= 1.0. diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackendSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackendSuite.scala index bf060ea7b..b917b7de9 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackendSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBackendSuite.scala @@ -374,8 +374,7 @@ class SdkSpanBackendSuite extends CatsEffectSuite with ScalaCheckEffectSuite { ) .appendAll(attributes), events = LimitedData.events(spanLimits.maxNumberOfEvents), - links = - LimitedData.links(spanLimits.maxNumberOfLinks).appendAll(links), + links = LimitedData.links(spanLimits.maxNumberOfLinks).appendAll(links), instrumentationScope = scope, resource = Defaults.resource ) diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBuilderSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBuilderSuite.scala index 0d6bdc811..d7259dff7 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBuilderSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkSpanBuilderSuite.scala @@ -97,9 +97,8 @@ class SdkSpanBuilderSuite extends CatsEffectSuite with ScalaCheckEffectSuite { val withTimestamp = startTimestamp.foldLeft(withParent)(_.withStartTimestamp(_)) - val withLinks = linkDataInput.items.foldLeft(withTimestamp) { - (b, link) => - b.addLink(link.spanContext, link.attributes.toSeq) + val withLinks = linkDataInput.items.foldLeft(withTimestamp) { (b, link) => + b.addLink(link.spanContext, link.attributes.toSeq) } val withAttributes = @@ -202,8 +201,7 @@ object SdkSpanBuilderSuite { attributes ++ extraAttributes.toVector.to(Attributes) ) - private[trace] implicit val LinkDataInputArbitrary - : Arbitrary[LinkDataInput] = + private[trace] implicit val LinkDataInputArbitrary: Arbitrary[LinkDataInput] = Arbitrary( for { maxNumberOfAttributes <- Gen.choose(0, 100) diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SpanNode.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SpanNode.scala index a0a87a3e7..bbd7ddbe3 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SpanNode.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SpanNode.scala @@ -66,9 +66,7 @@ object SpanNode { val calculated = withDepth ++ acc val children = - nodesInDepth.flatMap(n => - nodesByParent.getOrElse(Some(n.spanContext.spanIdHex), Nil) - ) + nodesInDepth.flatMap(n => nodesByParent.getOrElse(Some(n.spanContext.spanIdHex), Nil)) children match { case Nil => diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/TracerProviderAutoConfigureSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/TracerProviderAutoConfigureSuite.scala index c641ab959..3212494d8 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/TracerProviderAutoConfigureSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/autoconfigure/TracerProviderAutoConfigureSuite.scala @@ -198,8 +198,7 @@ class TracerProviderAutoConfigureSuite extends CatsEffectSuite { propagators: ContextPropagators[Context] = ContextPropagators.noop, customizer: Customizer[SdkTracerProvider.Builder[IO]] = (a, _) => a, samplerConfigurers: Set[AutoConfigure.Named[IO, Sampler]] = Set.empty, - exporterConfigurers: Set[AutoConfigure.Named[IO, SpanExporter[IO]]] = - Set.empty + exporterConfigurers: Set[AutoConfigure.Named[IO, SpanExporter[IO]]] = Set.empty )(f: TracerProvider[IO] => IO[A]): IO[A] = Resource.eval(LocalProvider[IO, Context].local).use { implicit local => Resource.eval(Random.scalaUtilRandom[IO]).use { implicit random => diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3PropagatorSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3PropagatorSuite.scala index 1df17489e..03eca602c 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3PropagatorSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/context/propagation/B3PropagatorSuite.scala @@ -580,21 +580,20 @@ class B3PropagatorSuite extends CatsEffectSuite with ScalaCheckSuite { }*/ test("single - extract - single and multi headers - prioritize single") { - Prop.forAll(Gens.spanContext, Gens.traceId, Gens.spanId) { - (ctx, traceId, spanId) => - val sampled = if (ctx.isSampled) "1" else "0" - val header = ctx.traceIdHex + "-" + ctx.spanIdHex + "-" + sampled - val carrier = Map( - Headers.Combined -> header, - Headers.TraceId -> traceId.toBase16, - Headers.SpanId -> spanId.toBase16, - Headers.Sampled -> sampled - ) - - val result = single.extract(Context.root, carrier) - val expected = asRemote(ctx) - - assertEquals(getSpanContext(result), Some(expected)) + Prop.forAll(Gens.spanContext, Gens.traceId, Gens.spanId) { (ctx, traceId, spanId) => + val sampled = if (ctx.isSampled) "1" else "0" + val header = ctx.traceIdHex + "-" + ctx.spanIdHex + "-" + sampled + val carrier = Map( + Headers.Combined -> header, + Headers.TraceId -> traceId.toBase16, + Headers.SpanId -> spanId.toBase16, + Headers.Sampled -> sampled + ) + + val result = single.extract(Context.root, carrier) + val expected = asRemote(ctx) + + assertEquals(getSpanContext(result), Some(expected)) } } diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/data/LimitedDataSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/data/LimitedDataSuite.scala index c8541b19c..f44ba179f 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/data/LimitedDataSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/data/LimitedDataSuite.scala @@ -34,9 +34,8 @@ class LimitedDataSuite extends ScalaCheckSuite { val data = LimitedData .attributes(150, Int.MaxValue) .appendAll(attributes) - val dataWithDropped = extraAttributes.foldLeft(data) { - (data, attribute) => - data.append(attribute) + val dataWithDropped = extraAttributes.foldLeft(data) { (data, attribute) => + data.append(attribute) } assertEquals(dataWithDropped.dropped, 150) diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporterSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporterSuite.scala index 81c4b7cb0..e4a7d01bb 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporterSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/exporter/ConsoleSpanExporterSuite.scala @@ -29,9 +29,7 @@ import org.typelevel.otel4s.sdk.test.InMemoryConsole._ import org.typelevel.otel4s.sdk.trace.data.SpanData import org.typelevel.otel4s.sdk.trace.scalacheck.Gens -class ConsoleSpanExporterSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class ConsoleSpanExporterSuite extends CatsEffectSuite with ScalaCheckEffectSuite { test("span data is exported as a log which is printed to the console") { PropF.forAllF(Gen.listOf(Gens.spanData)) { spans => diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessorSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessorSuite.scala index d25756c9a..cc71f4d2d 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessorSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/BatchSpanProcessorSuite.scala @@ -32,9 +32,7 @@ import org.typelevel.otel4s.sdk.trace.exporter.InMemorySpanExporter import org.typelevel.otel4s.sdk.trace.exporter.SpanExporter import org.typelevel.otel4s.sdk.trace.scalacheck.Arbitraries._ -class BatchSpanProcessorSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class BatchSpanProcessorSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val noopConsole: Console[IO] = new NoopConsole[IO] diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessorSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessorSuite.scala index f0794fa65..77506dfba 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessorSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/processor/SimpleSpanProcessorSuite.scala @@ -43,9 +43,7 @@ import org.typelevel.otel4s.trace.StatusCode import scala.collection.immutable import scala.concurrent.duration.FiniteDuration -class SimpleSpanProcessorSuite - extends CatsEffectSuite - with ScalaCheckEffectSuite { +class SimpleSpanProcessorSuite extends CatsEffectSuite with ScalaCheckEffectSuite { private implicit val noopConsole: Console[IO] = new NoopConsole[IO] diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSamplerSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSamplerSuite.scala index fcc51b881..c53b8ee5b 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSamplerSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/samplers/ParentBasedSamplerSuite.scala @@ -46,35 +46,34 @@ class ParentBasedSamplerSuite extends ScalaCheckSuite { } test("created with root sampler - returns correct sampling result") { - Prop.forAll(samplerChoiceGen, ShouldSampleInput.shouldSampleInputGen) { - (choice, input) => - val sampler = Sampler.parentBased(choice.sampler) - - val expected = input.parentContext match { - // valid remote parent - case Some(parent) if parent.isValid && parent.isRemote => - if (parent.isSampled) SamplingResult.RecordAndSample - else SamplingResult.Drop - - // valid local parent - case Some(parent) if parent.isValid => - if (parent.isSampled) SamplingResult.RecordAndSample - else SamplingResult.Drop - - case _ => - choice.result - } - - val result = sampler.shouldSample( - input.parentContext, - input.traceId, - input.name, - input.spanKind, - input.attributes, - input.parentLinks - ) - - assertEquals(result, expected) + Prop.forAll(samplerChoiceGen, ShouldSampleInput.shouldSampleInputGen) { (choice, input) => + val sampler = Sampler.parentBased(choice.sampler) + + val expected = input.parentContext match { + // valid remote parent + case Some(parent) if parent.isValid && parent.isRemote => + if (parent.isSampled) SamplingResult.RecordAndSample + else SamplingResult.Drop + + // valid local parent + case Some(parent) if parent.isValid => + if (parent.isSampled) SamplingResult.RecordAndSample + else SamplingResult.Drop + + case _ => + choice.result + } + + val result = sampler.shouldSample( + input.parentContext, + input.traceId, + input.name, + input.spanKind, + input.attributes, + input.parentLinks + ) + + assertEquals(result, expected) } } @@ -166,10 +165,8 @@ class ParentBasedSamplerSuite extends ScalaCheckSuite { ) object SamplerChoice { - case object AlwaysOn - extends SamplerChoice(Sampler.AlwaysOn, SamplingResult.RecordAndSample) + case object AlwaysOn extends SamplerChoice(Sampler.AlwaysOn, SamplingResult.RecordAndSample) - case object AlwaysOff - extends SamplerChoice(Sampler.AlwaysOff, SamplingResult.Drop) + case object AlwaysOff extends SamplerChoice(Sampler.AlwaysOff, SamplingResult.Drop) } } diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Cogens.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Cogens.scala index 8ed383cb0..7b2e3b97d 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Cogens.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Cogens.scala @@ -32,9 +32,7 @@ import org.typelevel.otel4s.trace.StatusCode import scala.concurrent.duration.FiniteDuration -trait Cogens - extends org.typelevel.otel4s.sdk.scalacheck.Cogens - with org.typelevel.otel4s.trace.scalacheck.Cogens { +trait Cogens extends org.typelevel.otel4s.sdk.scalacheck.Cogens with org.typelevel.otel4s.trace.scalacheck.Cogens { implicit val samplingDecisionCogen: Cogen[SamplingDecision] = Cogen[String].contramap(_.toString) diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Gens.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Gens.scala index fba413b7a..0ca96e250 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Gens.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/scalacheck/Gens.scala @@ -27,9 +27,7 @@ import org.typelevel.otel4s.sdk.trace.data.StatusData import org.typelevel.otel4s.sdk.trace.samplers.SamplingDecision import org.typelevel.otel4s.sdk.trace.samplers.SamplingResult -trait Gens - extends org.typelevel.otel4s.sdk.scalacheck.Gens - with org.typelevel.otel4s.trace.scalacheck.Gens { +trait Gens extends org.typelevel.otel4s.sdk.scalacheck.Gens with org.typelevel.otel4s.trace.scalacheck.Gens { val samplingDecision: Gen[SamplingDecision] = Gen.oneOf( diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AndroidExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AndroidExperimentalAttributes.scala index 63bf427ef..83a26e659 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AndroidExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AndroidExperimentalAttributes.scala @@ -21,21 +21,19 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object AndroidExperimentalAttributes { - /** Uniquely identifies the framework API revision offered by a version - * (`os.version`) of the android operating system. More information can be - * found here. */ val AndroidOsApiLevel: AttributeKey[String] = AttributeKey("android.os.api_level") - /** Deprecated use the `device.app.lifecycle` event definition including - * `android.state` as a payload field instead.

+ /** Deprecated use the `device.app.lifecycle` event definition including `android.state` as a payload field instead. + *

* @note *

The Android lifecycle states are defined in Activity - * lifecycle callbacks, and from which the `OS identifiers` are - * derived. + * href="https://developer.android.com/guide/components/activities/activity-lifecycle#lc">Activity lifecycle + * callbacks, and from which the `OS identifiers` are derived. */ val AndroidState: AttributeKey[String] = AttributeKey("android.state") @@ -45,20 +43,18 @@ object AndroidExperimentalAttributes { abstract class AndroidStateValue(val value: String) object AndroidStateValue { - /** Any time before Activity.onResume() or, if the app has no Activity, - * Context.startService() has been called in the app for the first time. + /** Any time before Activity.onResume() or, if the app has no Activity, Context.startService() has been called in + * the app for the first time. */ case object Created extends AndroidStateValue("created") - /** Any time after Activity.onPause() or, if the app has no Activity, - * Context.stopService() has been called when the app was in the foreground - * state. + /** Any time after Activity.onPause() or, if the app has no Activity, Context.stopService() has been called when the + * app was in the foreground state. */ case object Background extends AndroidStateValue("background") - /** Any time after Activity.onResume() or, if the app has no Activity, - * Context.startService() has been called when the app was in either the - * created or background states. + /** Any time after Activity.onResume() or, if the app has no Activity, Context.startService() has been called when + * the app was in either the created or background states. */ case object Foreground extends AndroidStateValue("foreground") } diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ArtifactExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ArtifactExperimentalAttributes.scala index da5d56dec..daaec3433 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ArtifactExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ArtifactExperimentalAttributes.scala @@ -21,65 +21,52 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object ArtifactExperimentalAttributes { - /** The provenance filename of the built attestation which directly relates to - * the build artifact filename. This filename SHOULD accompany the artifact - * at publish time. See the SLSA * Relationship specification for more information. */ val ArtifactAttestationFilename: AttributeKey[String] = AttributeKey("artifact.attestation.filename") - /** The full hash - * value (see glossary), of the built attestation. Some envelopes in the - * software attestation space also refer to this as the hash value (see glossary), of + * the built attestation. Some envelopes in the software attestation space also refer to this as the digest. */ val ArtifactAttestationHash: AttributeKey[String] = AttributeKey("artifact.attestation.hash") - /** The id of the build software - * attestation. + /** The id of the build software attestation. */ val ArtifactAttestationId: AttributeKey[String] = AttributeKey("artifact.attestation.id") - /** The human readable file name of the artifact, typically generated during - * build and release processes. Often includes the package name and version - * in the file name.

+ /** The human readable file name of the artifact, typically generated during build and release processes. Often + * includes the package name and version in the file name.

* @note - *

This file name can also act as the Package - * Name in cases where the package ecosystem maps accordingly. - * Additionally, the artifact can - * be published for others, but that is not a guarantee. + *

This file name can also act as the Package + * Name in cases where the package ecosystem maps accordingly. Additionally, the artifact can be published for others, but that is + * not a guarantee. */ val ArtifactFilename: AttributeKey[String] = AttributeKey("artifact.filename") - /** The full hash - * value (see glossary), often found in checksum.txt on a release of the - * artifact and used to verify package integrity.

+ /** The full hash value (see glossary), often + * found in checksum.txt on a release of the artifact and used to verify package integrity.

* @note - *

The specific algorithm used to create the cryptographic hash value - * is not defined. In situations where an artifact has multiple - * cryptographic hashes, it is up to the implementer to choose which hash - * value to set here; this should be the most secure hash algorithm that is - * suitable for the situation and consistent with the corresponding - * attestation. The implementer can then provide the other hash values - * through an additional set of attribute extensions as they deem - * necessary. + *

The specific algorithm used to create the cryptographic hash value is not defined. In situations where an + * artifact has multiple cryptographic hashes, it is up to the implementer to choose which hash value to set here; + * this should be the most secure hash algorithm that is suitable for the situation and consistent with the + * corresponding attestation. The implementer can then provide the other hash values through an additional set of + * attribute extensions as they deem necessary. */ val ArtifactHash: AttributeKey[String] = AttributeKey("artifact.hash") - /** The Package URL of - * the package - * artifact provides a standard way to identify and locate the packaged - * artifact. + /** The Package URL of the package artifact provides a standard way to + * identify and locate the packaged artifact. */ val ArtifactPurl: AttributeKey[String] = AttributeKey("artifact.purl") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AwsExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AwsExperimentalAttributes.scala index 2fdcf9225..31c4a51e8 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AwsExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AwsExperimentalAttributes.scala @@ -21,8 +21,7 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object AwsExperimentalAttributes { - /** The JSON-serialized value of each item in the `AttributeDefinitions` - * request field. + /** The JSON-serialized value of each item in the `AttributeDefinitions` request field. */ val AwsDynamodbAttributeDefinitions: AttributeKey[Seq[String]] = AttributeKey("aws.dynamodb.attribute_definitions") @@ -37,8 +36,7 @@ object AwsExperimentalAttributes { val AwsDynamodbConsistentRead: AttributeKey[Boolean] = AttributeKey("aws.dynamodb.consistent_read") - /** The JSON-serialized value of each item in the `ConsumedCapacity` response - * field. + /** The JSON-serialized value of each item in the `ConsumedCapacity` response field. */ val AwsDynamodbConsumedCapacity: AttributeKey[Seq[String]] = AttributeKey("aws.dynamodb.consumed_capacity") @@ -53,14 +51,12 @@ object AwsExperimentalAttributes { val AwsDynamodbExclusiveStartTable: AttributeKey[String] = AttributeKey("aws.dynamodb.exclusive_start_table") - /** The JSON-serialized value of each item in the - * `GlobalSecondaryIndexUpdates` request field. + /** The JSON-serialized value of each item in the `GlobalSecondaryIndexUpdates` request field. */ val AwsDynamodbGlobalSecondaryIndexUpdates: AttributeKey[Seq[String]] = AttributeKey("aws.dynamodb.global_secondary_index_updates") - /** The JSON-serialized value of each item of the `GlobalSecondaryIndexes` - * request field + /** The JSON-serialized value of each item of the `GlobalSecondaryIndexes` request field */ val AwsDynamodbGlobalSecondaryIndexes: AttributeKey[Seq[String]] = AttributeKey("aws.dynamodb.global_secondary_indexes") @@ -80,8 +76,7 @@ object AwsExperimentalAttributes { val AwsDynamodbLimit: AttributeKey[Long] = AttributeKey("aws.dynamodb.limit") - /** The JSON-serialized value of each item of the `LocalSecondaryIndexes` - * request field. + /** The JSON-serialized value of each item of the `LocalSecondaryIndexes` request field. */ val AwsDynamodbLocalSecondaryIndexes: AttributeKey[Seq[String]] = AttributeKey("aws.dynamodb.local_secondary_indexes") @@ -91,14 +86,12 @@ object AwsExperimentalAttributes { val AwsDynamodbProjection: AttributeKey[String] = AttributeKey("aws.dynamodb.projection") - /** The value of the `ProvisionedThroughput.ReadCapacityUnits` request - * parameter. + /** The value of the `ProvisionedThroughput.ReadCapacityUnits` request parameter. */ val AwsDynamodbProvisionedReadCapacity: AttributeKey[Double] = AttributeKey("aws.dynamodb.provisioned_read_capacity") - /** The value of the `ProvisionedThroughput.WriteCapacityUnits` request - * parameter. + /** The value of the `ProvisionedThroughput.WriteCapacityUnits` request parameter. */ val AwsDynamodbProvisionedWriteCapacity: AttributeKey[Double] = AttributeKey("aws.dynamodb.provisioned_write_capacity") @@ -138,23 +131,19 @@ object AwsExperimentalAttributes { val AwsDynamodbTotalSegments: AttributeKey[Long] = AttributeKey("aws.dynamodb.total_segments") - /** The ARN of an ECS - * cluster. + /** The ARN of an ECS cluster. */ val AwsEcsClusterArn: AttributeKey[String] = AttributeKey("aws.ecs.cluster.arn") /** The Amazon Resource Name (ARN) of an ECS - * container instance. + * href="https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ECS_instances.html">ECS container instance. */ val AwsEcsContainerArn: AttributeKey[String] = AttributeKey("aws.ecs.container.arn") - /** The launch - * type for an ECS task. + /** The launch type for an + * ECS task. */ val AwsEcsLaunchtype: AttributeKey[String] = AttributeKey("aws.ecs.launchtype") @@ -167,8 +156,8 @@ object AwsExperimentalAttributes { AttributeKey("aws.ecs.task.arn") /** The family name of the ECS - * task definition used to create the ECS task. + * href="https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_definitions.html">ECS task definition + * used to create the ECS task. */ val AwsEcsTaskFamily: AttributeKey[String] = AttributeKey("aws.ecs.task.family") @@ -188,12 +177,10 @@ object AwsExperimentalAttributes { val AwsEksClusterArn: AttributeKey[String] = AttributeKey("aws.eks.cluster.arn") - /** The full invoked ARN as provided on the `Context` passed to the function - * (`Lambda-Runtime-Invoked-Function-Arn` header on the - * `/runtime/invocation/next` applicable).

+ /** The full invoked ARN as provided on the `Context` passed to the function (`Lambda-Runtime-Invoked-Function-Arn` + * header on the `/runtime/invocation/next` applicable).

* @note - *

This may be different from `cloud.resource_id` if an alias is - * involved. + *

This may be different from `cloud.resource_id` if an alias is involved. */ val AwsLambdaInvokedArn: AttributeKey[String] = AttributeKey("aws.lambda.invoked_arn") @@ -209,9 +196,8 @@ object AwsExperimentalAttributes { /** The name(s) of the AWS log group(s) an application is writing to.

* @note - *

Multiple log groups must be supported for cases like multi-container - * applications, where a single application has sidecar containers, and - * each write to their own log group. + *

Multiple log groups must be supported for cases like multi-container applications, where a single + * application has sidecar containers, and each write to their own log group. */ val AwsLogGroupNames: AttributeKey[Seq[String]] = AttributeKey("aws.log.group.names") @@ -220,9 +206,8 @@ object AwsExperimentalAttributes { * @note *

See the log - * stream ARN format documentation. One log group can contain several - * log streams, so these ARNs necessarily identify both a log group and a - * log stream. + * stream ARN format documentation. One log group can contain several log streams, so these ARNs necessarily + * identify both a log group and a log stream. */ val AwsLogStreamArns: AttributeKey[Seq[String]] = AttributeKey("aws.log.stream.arns") @@ -232,36 +217,27 @@ object AwsExperimentalAttributes { val AwsLogStreamNames: AttributeKey[Seq[String]] = AttributeKey("aws.log.stream.names") - /** The AWS request ID as returned in the response headers `x-amz-request-id` - * or `x-amz-requestid`. + /** The AWS request ID as returned in the response headers `x-amz-request-id` or `x-amz-requestid`. */ val AwsRequestId: AttributeKey[String] = AttributeKey("aws.request_id") - /** The S3 bucket name the request refers to. Corresponds to the `--bucket` - * parameter of the S3 - * API operations.

+ /** The S3 bucket name the request refers to. Corresponds to the `--bucket` parameter of the S3 API operations.

* @note - *

The `bucket` attribute is applicable to all S3 operations that - * reference a bucket, i.e. that require the bucket name as a mandatory - * parameter. This applies to almost all S3 operations except - * `list-buckets`. + *

The `bucket` attribute is applicable to all S3 operations that reference a bucket, i.e. that require the + * bucket name as a mandatory parameter. This applies to almost all S3 operations except `list-buckets`. */ val AwsS3Bucket: AttributeKey[String] = AttributeKey("aws.s3.bucket") /** The source object (in the form `bucket`/`key`) for the copy operation.

* @note - *

The `copy_source` attribute applies to S3 copy operations and - * corresponds to the `--copy-source` parameter of the copy-object - * operation within the S3 API. This applies in particular to the - * following operations:

+ *

The `copy_source` attribute applies to S3 copy operations and corresponds to the `--copy-source` parameter + * of the copy-object operation + * within the S3 API. This applies in particular to the following operations:

*/ val AwsS3CopySource: AttributeKey[String] = AttributeKey("aws.s3.copy_source") @@ -269,35 +245,25 @@ object AwsExperimentalAttributes { /** The delete request container that specifies the objects to be deleted.

* @note *

The `delete` attribute is only applicable to the delete-object - * operation. The `delete` attribute corresponds to the `--delete` - * parameter of the delete-objects - * operation within the S3 API. + * href="https://docs.aws.amazon.com/cli/latest/reference/s3api/delete-object.html">delete-object operation. + * The `delete` attribute corresponds to the `--delete` parameter of the delete-objects operation + * within the S3 API. */ val AwsS3Delete: AttributeKey[String] = AttributeKey("aws.s3.delete") - /** The S3 object key the request refers to. Corresponds to the `--key` - * parameter of the S3 - * API operations.

+ /** The S3 object key the request refers to. Corresponds to the `--key` parameter of the S3 API operations.

* @note - *

The `key` attribute is applicable to all object-related S3 - * operations, i.e. that require the object key as a mandatory parameter. - * This applies in particular to the following operations:

*/ val AwsS3Key: AttributeKey[String] = AttributeKey("aws.s3.key") - /** The part number of the part being uploaded in a multipart-upload - * operation. This is a positive integer between 1 and 10,000.

+ /** The part number of the part being uploaded in a multipart-upload operation. This is a positive integer between 1 + * and 10,000.

* @note *

The `part_number` attribute is only applicable to the upload-part - * and upload-part and upload-part-copy - * operations. The `part_number` attribute corresponds to the - * `--part-number` parameter of the upload-part - * operation within the S3 API. + * operations. The `part_number` attribute corresponds to the `--part-number` parameter of the upload-part operation within the + * S3 API. */ val AwsS3PartNumber: AttributeKey[Long] = AttributeKey("aws.s3.part_number") /** Upload ID that identifies the multipart upload.

* @note - *

The `upload_id` attribute applies to S3 multipart-upload operations - * and corresponds to the `--upload-id` parameter of the S3 - * API multipart operations. This applies in particular to the - * following operations:

*/ val AwsS3UploadId: AttributeKey[String] = AttributeKey("aws.s3.upload_id") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AzExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AzExperimentalAttributes.scala index dfc24b08b..6337ed4ab 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AzExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/AzExperimentalAttributes.scala @@ -21,8 +21,7 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object AzExperimentalAttributes { - /** The unique identifier of the service request. It's generated by the Azure - * service and returned with the response. + /** The unique identifier of the service request. It's generated by the Azure service and returned with the response. */ val AzServiceRequestId: AttributeKey[String] = AttributeKey("az.service_request_id") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/BrowserExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/BrowserExperimentalAttributes.scala index 4d05ffecf..bbfa28828 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/BrowserExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/BrowserExperimentalAttributes.scala @@ -23,44 +23,36 @@ object BrowserExperimentalAttributes { /** Array of brand name and version separated by a space

* @note - *

This value is intended to be taken from the UA client hints - * API (`navigator.userAgentData.brands`). + *

This value is intended to be taken from the UA + * client hints API (`navigator.userAgentData.brands`). */ val BrowserBrands: AttributeKey[Seq[String]] = AttributeKey("browser.brands") /** Preferred language of the user using the browser

* @note - *

This value is intended to be taken from the Navigator API - * `navigator.language`. + *

This value is intended to be taken from the Navigator API `navigator.language`. */ val BrowserLanguage: AttributeKey[String] = AttributeKey("browser.language") /** A boolean that is true if the browser is running on a mobile device

* @note - *

This value is intended to be taken from the UA client hints - * API (`navigator.userAgentData.mobile`). If unavailable, this - * attribute SHOULD be left unset. + *

This value is intended to be taken from the UA + * client hints API (`navigator.userAgentData.mobile`). If unavailable, this attribute SHOULD be left unset. */ val BrowserMobile: AttributeKey[Boolean] = AttributeKey("browser.mobile") /** The platform on which the browser is running

* @note - *

This value is intended to be taken from the UA client hints - * API (`navigator.userAgentData.platform`). If unavailable, the legacy - * `navigator.platform` API SHOULD NOT be used instead and this attribute - * SHOULD be left unset in order for the values to be consistent. The list - * of possible values is defined in the W3C - * User-Agent Client Hints specification. Note that some (but not all) - * of these values can overlap with values in the `os.type` and `os.name` attributes. However, for - * consistency, the values in the `browser.platform` attribute should + *

This value is intended to be taken from the UA + * client hints API (`navigator.userAgentData.platform`). If unavailable, the legacy `navigator.platform` API + * SHOULD NOT be used instead and this attribute SHOULD be left unset in order for the values to be consistent. The + * list of possible values is defined in the W3C User-Agent Client Hints specification. + * Note that some (but not all) of these values can overlap with values in the `os.type` and + * `os.name` attributes. However, for consistency, the values in the `browser.platform` attribute should * capture the exact value that the user agent provides. */ val BrowserPlatform: AttributeKey[String] = diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CicdExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CicdExperimentalAttributes.scala index 6f7d03262..76db6b9ce 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CicdExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CicdExperimentalAttributes.scala @@ -31,11 +31,9 @@ object CicdExperimentalAttributes { val CicdPipelineRunId: AttributeKey[String] = AttributeKey("cicd.pipeline.run.id") - /** The human readable name of a task within a pipeline. Task here most - * closely aligns with a computing - * process in a pipeline. Other terms for tasks include commands, steps, - * and procedures. + /** The human readable name of a task within a pipeline. Task here most closely aligns with a computing process in a pipeline. Other terms for + * tasks include commands, steps, and procedures. */ val CicdPipelineTaskName: AttributeKey[String] = AttributeKey("cicd.pipeline.task.name") @@ -45,9 +43,8 @@ object CicdExperimentalAttributes { val CicdPipelineTaskRunId: AttributeKey[String] = AttributeKey("cicd.pipeline.task.run.id") - /** The URL of the pipeline - * run providing the complete address in order to locate and identify the - * pipeline run. + /** The URL of the pipeline run providing the complete address in + * order to locate and identify the pipeline run. */ val CicdPipelineTaskRunUrlFull: AttributeKey[String] = AttributeKey("cicd.pipeline.task.run.url.full") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ClientExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ClientExperimentalAttributes.scala index 14b529be6..324ec7842 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ClientExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ClientExperimentalAttributes.scala @@ -21,12 +21,11 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object ClientExperimentalAttributes { - /** Client address - domain name if available without reverse DNS lookup; - * otherwise, IP address or Unix domain socket name.

+ /** Client address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket + * name.

* @note - *

When observed from the server side, and when communicating through - * an intermediary, `client.address` SHOULD represent the client address - * behind any intermediaries, for example proxies, if it's available. + *

When observed from the server side, and when communicating through an intermediary, `client.address` SHOULD + * represent the client address behind any intermediaries, for example proxies, if it's available. */ @deprecated( "use `org.typelevel.otel4s.semconv.attributes.ClientAttributes.ClientAddress` instead.", @@ -37,9 +36,8 @@ object ClientExperimentalAttributes { /** Client port number.

* @note - *

When observed from the server side, and when communicating through - * an intermediary, `client.port` SHOULD represent the client port behind - * any intermediaries, for example proxies, if it's available. + *

When observed from the server side, and when communicating through an intermediary, `client.port` SHOULD + * represent the client port behind any intermediaries, for example proxies, if it's available. */ @deprecated( "use `org.typelevel.otel4s.semconv.attributes.ClientAttributes.ClientPort` instead.", diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudExperimentalAttributes.scala index af2b64a55..8185bb861 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudExperimentalAttributes.scala @@ -26,20 +26,17 @@ object CloudExperimentalAttributes { val CloudAccountId: AttributeKey[String] = AttributeKey("cloud.account.id") - /** Cloud regions often have multiple, isolated locations known as zones to - * increase availability. Availability zone represents the zone where the - * resource is running.

+ /** Cloud regions often have multiple, isolated locations known as zones to increase availability. Availability zone + * represents the zone where the resource is running.

* @note - *

Availability zones are called "zones" on Alibaba Cloud and Google - * Cloud. + *

Availability zones are called "zones" on Alibaba Cloud and Google Cloud. */ val CloudAvailabilityZone: AttributeKey[String] = AttributeKey("cloud.availability_zone") /** The cloud platform in use.

* @note - *

The prefix of the service SHOULD match the one specified in - * `cloud.provider`. + *

The prefix of the service SHOULD match the one specified in `cloud.provider`. */ val CloudPlatform: AttributeKey[String] = AttributeKey("cloud.platform") @@ -51,51 +48,37 @@ object CloudExperimentalAttributes { /** The geographical region the resource is running.

* @note - *

Refer to your provider's docs to see the available regions, for - * example Alibaba - * Cloud regions, AWS - * regions, Azure - * regions, Google - * Cloud regions, or Tencent - * Cloud regions. + *

Refer to your provider's docs to see the available regions, for example Alibaba Cloud regions, AWS regions, Azure regions, Google Cloud regions, or Tencent Cloud regions. */ val CloudRegion: AttributeKey[String] = AttributeKey("cloud.region") - /** Cloud provider-specific native identifier of the monitored cloud resource - * (e.g. an ARN - * on AWS, a fully - * qualified resource ID on Azure, a full - * resource name on GCP)

+ /** Cloud provider-specific native identifier of the monitored cloud resource (e.g. an ARN on AWS, a fully qualified resource ID on + * Azure, a full resource name + * on GCP)

* @note - *

On some cloud providers, it may not be possible to determine the - * full ID at startup, so it may be necessary to set `cloud.resource_id` as - * a span attribute instead.

The exact value to use for - * `cloud.resource_id` depends on the cloud provider. The following - * well-known definitions MUST be used if you set this attribute and they - * apply:

*/ val CloudResourceId: AttributeKey[String] = AttributeKey("cloud.resource_id") @@ -115,8 +98,7 @@ object CloudExperimentalAttributes { /** Red Hat OpenShift on Alibaba Cloud */ - case object AlibabaCloudOpenshift - extends CloudPlatformValue("alibaba_cloud_openshift") + case object AlibabaCloudOpenshift extends CloudPlatformValue("alibaba_cloud_openshift") /** AWS Elastic Compute Cloud */ @@ -136,8 +118,7 @@ object CloudExperimentalAttributes { /** AWS Elastic Beanstalk */ - case object AwsElasticBeanstalk - extends CloudPlatformValue("aws_elastic_beanstalk") + case object AwsElasticBeanstalk extends CloudPlatformValue("aws_elastic_beanstalk") /** AWS App Runner */ @@ -153,13 +134,11 @@ object CloudExperimentalAttributes { /** Azure Container Apps */ - case object AzureContainerApps - extends CloudPlatformValue("azure_container_apps") + case object AzureContainerApps extends CloudPlatformValue("azure_container_apps") /** Azure Container Instances */ - case object AzureContainerInstances - extends CloudPlatformValue("azure_container_instances") + case object AzureContainerInstances extends CloudPlatformValue("azure_container_instances") /** Azure Kubernetes Service */ @@ -179,13 +158,11 @@ object CloudExperimentalAttributes { /** Google Bare Metal Solution (BMS) */ - case object GcpBareMetalSolution - extends CloudPlatformValue("gcp_bare_metal_solution") + case object GcpBareMetalSolution extends CloudPlatformValue("gcp_bare_metal_solution") /** Google Cloud Compute Engine (GCE) */ - case object GcpComputeEngine - extends CloudPlatformValue("gcp_compute_engine") + case object GcpComputeEngine extends CloudPlatformValue("gcp_compute_engine") /** Google Cloud Run */ @@ -193,13 +170,11 @@ object CloudExperimentalAttributes { /** Google Cloud Kubernetes Engine (GKE) */ - case object GcpKubernetesEngine - extends CloudPlatformValue("gcp_kubernetes_engine") + case object GcpKubernetesEngine extends CloudPlatformValue("gcp_kubernetes_engine") /** Google Cloud Functions (GCF) */ - case object GcpCloudFunctions - extends CloudPlatformValue("gcp_cloud_functions") + case object GcpCloudFunctions extends CloudPlatformValue("gcp_cloud_functions") /** Google Cloud App Engine (GAE) */ @@ -211,8 +186,7 @@ object CloudExperimentalAttributes { /** Red Hat OpenShift on IBM Cloud */ - case object IbmCloudOpenshift - extends CloudPlatformValue("ibm_cloud_openshift") + case object IbmCloudOpenshift extends CloudPlatformValue("ibm_cloud_openshift") /** Tencent Cloud Cloud Virtual Machine (CVM) */ diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudeventsExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudeventsExperimentalAttributes.scala index 8390bb98f..45e92f0b3 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudeventsExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CloudeventsExperimentalAttributes.scala @@ -21,38 +21,32 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object CloudeventsExperimentalAttributes { - /** The event_id - * uniquely identifies the event. + /** The event_id uniquely + * identifies the event. */ val CloudeventsEventId: AttributeKey[String] = AttributeKey("cloudevents.event_id") - /** The source - * identifies the context in which an event happened. + /** The source identifies + * the context in which an event happened. */ val CloudeventsEventSource: AttributeKey[String] = AttributeKey("cloudevents.event_source") - /** The version - * of the CloudEvents specification which the event uses. + /** The version of the + * CloudEvents specification which the event uses. */ val CloudeventsEventSpecVersion: AttributeKey[String] = AttributeKey("cloudevents.event_spec_version") - /** The subject - * of the event in the context of the event producer (identified by source). + /** The subject of the event + * in the context of the event producer (identified by source). */ val CloudeventsEventSubject: AttributeKey[String] = AttributeKey("cloudevents.event_subject") - /** The event_type - * contains a value describing the type of event related to the originating - * occurrence. + /** The event_type contains a + * value describing the type of event related to the originating occurrence. */ val CloudeventsEventType: AttributeKey[String] = AttributeKey("cloudevents.event_type") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CodeExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CodeExperimentalAttributes.scala index 008596854..07a271919 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CodeExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/CodeExperimentalAttributes.scala @@ -21,40 +21,37 @@ import org.typelevel.otel4s.AttributeKey // DO NOT EDIT, this is an Auto-generated file from buildscripts/templates/registry/otel4s/attributes/experimental/SemanticAttributes.scala.j2 object CodeExperimentalAttributes { - /** The column number in `code.filepath` best representing the operation. It - * SHOULD point within the code unit named in `code.function`. + /** The column number in `code.filepath` best representing the operation. It SHOULD point within the code unit named + * in `code.function`. */ val CodeColumn: AttributeKey[Long] = AttributeKey("code.column") - /** The source code file name that identifies the code unit as uniquely as - * possible (preferably an absolute file path). + /** The source code file name that identifies the code unit as uniquely as possible (preferably an absolute file + * path). */ val CodeFilepath: AttributeKey[String] = AttributeKey("code.filepath") - /** The method or function name, or equivalent (usually rightmost part of the - * code unit's name). + /** The method or function name, or equivalent (usually rightmost part of the code unit's name). */ val CodeFunction: AttributeKey[String] = AttributeKey("code.function") - /** The line number in `code.filepath` best representing the operation. It - * SHOULD point within the code unit named in `code.function`. + /** The line number in `code.filepath` best representing the operation. It SHOULD point within the code unit named in + * `code.function`. */ val CodeLineno: AttributeKey[Long] = AttributeKey("code.lineno") - /** The "namespace" within which `code.function` is defined. Usually the - * qualified class or module name, such that `code.namespace` + some - * separator + `code.function` form a unique identifier for the code unit. + /** The "namespace" within which `code.function` is defined. Usually the qualified class or module name, such that + * `code.namespace` + some separator + `code.function` form a unique identifier for the code unit. */ val CodeNamespace: AttributeKey[String] = AttributeKey("code.namespace") - /** A stacktrace as a string in the natural representation for the language - * runtime. The representation is to be determined and documented by each - * language SIG. + /** A stacktrace as a string in the natural representation for the language runtime. The representation is to be + * determined and documented by each language SIG. */ val CodeStacktrace: AttributeKey[String] = AttributeKey("code.stacktrace") diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ContainerExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ContainerExperimentalAttributes.scala index c8c5c6d31..ce476df4d 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ContainerExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/ContainerExperimentalAttributes.scala @@ -23,20 +23,18 @@ object ContainerExperimentalAttributes { /** The command used to run the container (i.e. the command name).

* @note - *

If using embedded credentials or sensitive data, it is recommended - * to remove them to prevent potential leakage. + *

If using embedded credentials or sensitive data, it is recommended to remove them to prevent potential + * leakage. */ val ContainerCommand: AttributeKey[String] = AttributeKey("container.command") - /** All the command arguments (including the command/executable itself) run by - * the container. [2] + /** All the command arguments (including the command/executable itself) run by the container. [2] */ val ContainerCommandArgs: AttributeKey[Seq[String]] = AttributeKey("container.command_args") - /** The full command run by the container as a single string representing the - * full command. [2] + /** The full command run by the container as a single string representing the full command. [2] */ val ContainerCommandLine: AttributeKey[String] = AttributeKey("container.command_line") @@ -48,24 +46,21 @@ object ContainerExperimentalAttributes { AttributeKey("container.cpu.state") /** Container ID. Usually a UUID, as for example used to identify - * Docker containers. The UUID might be abbreviated. + * href="https://docs.docker.com/engine/reference/run/#container-identification">identify Docker containers. The + * UUID might be abbreviated. */ val ContainerId: AttributeKey[String] = AttributeKey("container.id") - /** Runtime specific image identifier. Usually a hash algorithm followed by a - * UUID.

+ /** Runtime specific image identifier. Usually a hash algorithm followed by a UUID.

* @note - *

Docker defines a sha256 of the image id; `container.image.id` - * corresponds to the `Image` field from the Docker container inspect API - * endpoint. K8s defines a link to the container registry repository with - * digest `"imageID": "registry.azurecr.io - * /namespace/service/dockerfile@sha256:bdeabd40c3a8a492eaf9e8e44d0ebbb84bac7ee25ac0cf8a7159d25f62555625"`. - * The ID is assigned by the container runtime and can vary in different - * environments. Consider using `oci.manifest.digest` if it is important to - * identify the same image in different environments/runtimes. + *

Docker defines a sha256 of the image id; `container.image.id` corresponds to the `Image` field from the + * Docker container inspect API endpoint. K8s + * defines a link to the container registry repository with digest `"imageID": "registry.azurecr.io + * /namespace/service/dockerfile@sha256:bdeabd40c3a8a492eaf9e8e44d0ebbb84bac7ee25ac0cf8a7159d25f62555625"`. The ID + * is assigned by the container runtime and can vary in different environments. Consider using + * `oci.manifest.digest` if it is important to identify the same image in different environments/runtimes. */ val ContainerImageId: AttributeKey[String] = AttributeKey("container.image.id") @@ -75,12 +70,9 @@ object ContainerExperimentalAttributes { val ContainerImageName: AttributeKey[String] = AttributeKey("container.image.name") - /** Repo digests of the container image as provided by the container runtime. - *

+ /** Repo digests of the container image as provided by the container runtime.

* @note - *

Docker - * and Docker and CRI * report those under the `RepoDigests` field. */ @@ -88,15 +80,13 @@ object ContainerExperimentalAttributes { AttributeKey("container.image.repo_digests") /** Container image tags. An example can be found in Docker - * Image Inspect. Should be only the `` section of the full name for - * example from `registry.example.com/my-org/my-image:`. + * href="https://docs.docker.com/engine/api/v1.43/#tag/Image/operation/ImageInspect">Docker Image Inspect. Should + * be only the `` section of the full name for example from `registry.example.com/my-org/my-image:`. */ val ContainerImageTags: AttributeKey[Seq[String]] = AttributeKey("container.image.tags") - /** Container labels, `` being the label name, the value being the label - * value. + /** Container labels, `` being the label name, the value being the label value. */ val ContainerLabel: AttributeKey[String] = AttributeKey("container.label") @@ -124,8 +114,7 @@ object ContainerExperimentalAttributes { @annotation.nowarn("cat=deprecation") object ContainerCpuStateValue { - /** When tasks of the cgroup are in user mode (Linux). When all container - * processes are in user mode (Windows). + /** When tasks of the cgroup are in user mode (Linux). When all container processes are in user mode (Windows). */ case object User extends ContainerCpuStateValue("user") @@ -133,8 +122,7 @@ object ContainerExperimentalAttributes { */ case object System extends ContainerCpuStateValue("system") - /** When tasks of the cgroup are in kernel mode (Linux). When all container - * processes are in kernel mode (Windows). + /** When tasks of the cgroup are in kernel mode (Linux). When all container processes are in kernel mode (Windows). */ case object Kernel extends ContainerCpuStateValue("kernel") } diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DbExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DbExperimentalAttributes.scala index c43688f49..9395662b8 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DbExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DbExperimentalAttributes.scala @@ -42,14 +42,13 @@ object DbExperimentalAttributes { val DbCassandraIdempotence: AttributeKey[Boolean] = AttributeKey("db.cassandra.idempotence") - /** The fetch size used for paging, i.e. how many rows will be returned at - * once. + /** The fetch size used for paging, i.e. how many rows will be returned at once. */ val DbCassandraPageSize: AttributeKey[Long] = AttributeKey("db.cassandra.page_size") - /** The number of times a query was speculatively executed. Not set or `0` if - * the query was not executed speculatively. + /** The number of times a query was speculatively executed. Not set or `0` if the query was not executed + * speculatively. */ val DbCassandraSpeculativeExecutionCount: AttributeKey[Long] = AttributeKey("db.cassandra.speculative_execution_count") @@ -60,13 +59,11 @@ object DbExperimentalAttributes { val DbCassandraTable: AttributeKey[String] = AttributeKey("db.cassandra.table") - /** The name of the connection pool; unique within the instrumented - * application. In case the connection pool implementation doesn't provide a - * name, instrumentation SHOULD use a combination of parameters that would - * make the name unique, for example, combining attributes `server.address`, - * `server.port`, and `db.namespace`, formatted as - * `server.address:server.port/db.namespace`. Instrumentations that generate - * connection pool name following different patterns SHOULD document it. + /** The name of the connection pool; unique within the instrumented application. In case the connection pool + * implementation doesn't provide a name, instrumentation SHOULD use a combination of parameters that would make the + * name unique, for example, combining attributes `server.address`, `server.port`, and `db.namespace`, formatted as + * `server.address:server.port/db.namespace`. Instrumentations that generate connection pool name following different + * patterns SHOULD document it. */ val DbClientConnectionPoolName: AttributeKey[String] = AttributeKey("db.client.connection.pool.name") @@ -90,14 +87,11 @@ object DbExperimentalAttributes { /** The name of a collection (table, container) within the database.

* @note - *

It is RECOMMENDED to capture the value as provided by the - * application without attempting to do any case normalization. If the - * collection name is parsed from the query text, it SHOULD be the first - * collection name found in the query and it SHOULD match the value - * provided in the query text including any schema and database name - * prefix. For batch operations, if the individual operations are known to - * have the same collection name then that collection name SHOULD be used, - * otherwise `db.collection.name` SHOULD NOT be captured. + *

It is RECOMMENDED to capture the value as provided by the application without attempting to do any case + * normalization. If the collection name is parsed from the query text, it SHOULD be the first collection name + * found in the query and it SHOULD match the value provided in the query text including any schema and database + * name prefix. For batch operations, if the individual operations are known to have the same collection name then + * that collection name SHOULD be used, otherwise `db.collection.name` SHOULD NOT be captured. */ val DbCollectionName: AttributeKey[String] = AttributeKey("db.collection.name") @@ -155,26 +149,23 @@ object DbExperimentalAttributes { val DbElasticsearchClusterName: AttributeKey[String] = AttributeKey("db.elasticsearch.cluster.name") - /** Represents the human-readable identifier of the node/instance to which a - * request was routed. + /** Represents the human-readable identifier of the node/instance to which a request was routed. */ val DbElasticsearchNodeName: AttributeKey[String] = AttributeKey("db.elasticsearch.node.name") /** A dynamic value in the url path.

* @note - *

Many Elasticsearch url paths allow dynamic values. These SHOULD be - * recorded in span attributes in the format - * `db.elasticsearch.path_parts.`, where `` is the url path part - * name. The implementation SHOULD reference the Many Elasticsearch url paths allow dynamic values. These SHOULD be recorded in span attributes in the format + * `db.elasticsearch.path_parts.`, where `` is the url path part name. The implementation SHOULD + * reference the elasticsearch * schema in order to map the path part values to their names. */ val DbElasticsearchPathParts: AttributeKey[String] = AttributeKey("db.elasticsearch.path_parts") - /** Deprecated, no general replacement at this time. For Elasticsearch, use - * `db.elasticsearch.node.name` instead. + /** Deprecated, no general replacement at this time. For Elasticsearch, use `db.elasticsearch.node.name` instead. */ @deprecated( "Deprecated, no general replacement at this time. For Elasticsearch, use `db.elasticsearch.node.name` instead.", @@ -195,8 +186,7 @@ object DbExperimentalAttributes { val DbMongodbCollection: AttributeKey[String] = AttributeKey("db.mongodb.collection") - /** Deprecated, SQL Server instance is now populated as a part of - * `db.namespace` attribute. + /** Deprecated, SQL Server instance is now populated as a part of `db.namespace` attribute. */ @deprecated("Deprecated, no replacement at this time.", "") val DbMssqlInstanceName: AttributeKey[String] = @@ -208,18 +198,14 @@ object DbExperimentalAttributes { val DbName: AttributeKey[String] = AttributeKey("db.name") - /** The name of the database, fully qualified within the server address and - * port.

+ /** The name of the database, fully qualified within the server address and port.

* @note - *

If a database system has multiple namespace components, they SHOULD - * be concatenated (potentially using database system specific conventions) - * from most general to most specific namespace component, and more - * specific namespaces SHOULD NOT be captured without the more general - * namespaces, to ensure that "startswith" queries for the more general - * namespaces will be valid. Semantic conventions for individual database - * systems SHOULD document what `db.namespace` means in the context of that - * system. It is RECOMMENDED to capture the value as provided by the - * application without attempting to do any case normalization. + *

If a database system has multiple namespace components, they SHOULD be concatenated (potentially using + * database system specific conventions) from most general to most specific namespace component, and more specific + * namespaces SHOULD NOT be captured without the more general namespaces, to ensure that "startswith" queries for + * the more general namespaces will be valid. Semantic conventions for individual database systems SHOULD document + * what `db.namespace` means in the context of that system. It is RECOMMENDED to capture the value as provided by + * the application without attempting to do any case normalization. */ val DbNamespace: AttributeKey[String] = AttributeKey("db.namespace") @@ -230,37 +216,31 @@ object DbExperimentalAttributes { val DbOperation: AttributeKey[String] = AttributeKey("db.operation") - /** The number of queries included in a batch + /** The number of queries included in a batch * operation.

* @note - *

Operations are only considered batches when they contain two or more - * operations, and so `db.operation.batch.size` SHOULD never be `1`. + *

Operations are only considered batches when they contain two or more operations, and so + * `db.operation.batch.size` SHOULD never be `1`. */ val DbOperationBatchSize: AttributeKey[Long] = AttributeKey("db.operation.batch.size") /** The name of the operation or command being executed.

* @note - *

It is RECOMMENDED to capture the value as provided by the - * application without attempting to do any case normalization. If the - * operation name is parsed from the query text, it SHOULD be the first - * operation name found in the query. For batch operations, if the - * individual operations are known to have the same operation name then - * that operation name SHOULD be used prepended by `BATCH `, otherwise - * `db.operation.name` SHOULD be `BATCH` or some other database system - * specific term if more applicable. + *

It is RECOMMENDED to capture the value as provided by the application without attempting to do any case + * normalization. If the operation name is parsed from the query text, it SHOULD be the first operation name found + * in the query. For batch operations, if the individual operations are known to have the same operation name then + * that operation name SHOULD be used prepended by `BATCH `, otherwise `db.operation.name` SHOULD be `BATCH` or + * some other database system specific term if more applicable. */ val DbOperationName: AttributeKey[String] = AttributeKey("db.operation.name") - /** A query parameter used in `db.query.text`, with `` being the - * parameter name, and the attribute value being a string representation of - * the parameter value.

+ /** A query parameter used in `db.query.text`, with `` being the parameter name, and the attribute value being a + * string representation of the parameter value.

* @note - *

Query parameters should only be captured when `db.query.text` is - * parameterized with placeholders. If a parameter has no name and instead - * is referenced only by index, then `` SHOULD be the 0-based index. + *

Query parameters should only be captured when `db.query.text` is parameterized with placeholders. If a + * parameter has no name and instead is referenced only by index, then `` SHOULD be the 0-based index. */ val DbQueryParameter: AttributeKey[String] = AttributeKey("db.query.parameter") @@ -268,16 +248,13 @@ object DbExperimentalAttributes { /** The database query being executed.

* @note *

For sanitization see Sanitization - * of `db.query.text`. For batch operations, if the individual - * operations are known to have the same query text then that query text - * SHOULD be used, otherwise all of the individual query texts SHOULD be - * concatenated with separator `; ` or some other database system specific - * separator if more applicable. Even though parameterized query text can - * potentially have sensitive data, by using a parameterized query the user - * is giving a strong signal that any sensitive data will be passed as - * parameter values, and the benefit to observability of capturing the - * static part of the query text by default outweighs the risk. + * href="../../docs/database/database-spans.md#sanitization-of-dbquerytext">Sanitization of `db.query.text`. + * For batch operations, if the individual operations are known to have the same query text then that query text + * SHOULD be used, otherwise all of the individual query texts SHOULD be concatenated with separator `; ` or some + * other database system specific separator if more applicable. Even though parameterized query text can + * potentially have sensitive data, by using a parameterized query the user is giving a strong signal that any + * sensitive data will be passed as parameter values, and the benefit to observability of capturing the static part + * of the query text by default outweighs the risk. */ val DbQueryText: AttributeKey[String] = AttributeKey("db.query.text") @@ -300,13 +277,11 @@ object DbExperimentalAttributes { val DbStatement: AttributeKey[String] = AttributeKey("db.statement") - /** The database management system (DBMS) product as identified by the client - * instrumentation.

+ /** The database management system (DBMS) product as identified by the client instrumentation.

* @note - *

The actual DBMS may differ from the one identified by the client. - * For example, when using PostgreSQL client libraries to connect to a - * CockroachDB, the `db.system` is set to `postgresql` based on the - * instrumentation's best knowledge. + *

The actual DBMS may differ from the one identified by the client. For example, when using PostgreSQL client + * libraries to connect to a CockroachDB, the `db.system` is set to `postgresql` based on the instrumentation's + * best knowledge. */ val DbSystem: AttributeKey[String] = AttributeKey("db.system") @@ -328,8 +303,7 @@ object DbExperimentalAttributes { /** each_quorum. */ - case object EachQuorum - extends DbCassandraConsistencyLevelValue("each_quorum") + case object EachQuorum extends DbCassandraConsistencyLevelValue("each_quorum") /** quorum. */ @@ -337,8 +311,7 @@ object DbExperimentalAttributes { /** local_quorum. */ - case object LocalQuorum - extends DbCassandraConsistencyLevelValue("local_quorum") + case object LocalQuorum extends DbCassandraConsistencyLevelValue("local_quorum") /** one. */ @@ -366,8 +339,7 @@ object DbExperimentalAttributes { /** local_serial. */ - case object LocalSerial - extends DbCassandraConsistencyLevelValue("local_serial") + case object LocalSerial extends DbCassandraConsistencyLevelValue("local_serial") } /** Values for [[DbClientConnectionState]]. @@ -477,8 +449,7 @@ object DbExperimentalAttributes { /** execute_javascript. */ - case object ExecuteJavascript - extends DbCosmosdbOperationTypeValue("ExecuteJavaScript") + case object ExecuteJavascript extends DbCosmosdbOperationTypeValue("ExecuteJavaScript") } /** Values for [[DbSystem]]. diff --git a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DeploymentExperimentalAttributes.scala b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DeploymentExperimentalAttributes.scala index 415d062f0..c3b4d4889 100644 --- a/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DeploymentExperimentalAttributes.scala +++ b/semconv/experimental/src/main/scala/org/typelevel/otel4s/semconv/experimental/attributes/DeploymentExperimentalAttributes.scala @@ -27,16 +27,13 @@ object DeploymentExperimentalAttributes { val DeploymentEnvironment: AttributeKey[String] = AttributeKey("deployment.environment") - /** Name of the deployment - * environment (aka deployment tier).

+ /** Name of the deployment environment (aka deployment + * tier).

* @note - *

`deployment.environment.name` does not affect the uniqueness - * constraints defined through the `service.namespace`, `service.name` and - * `service.instance.id` resource attributes. This implies that resources - * carrying the following attribute combinations MUST be considered to be - * identifying the same service: