Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/main' into local-tracing
Browse files Browse the repository at this point in the history
  • Loading branch information
rossabaker committed Jan 31, 2023
2 parents 2ef92ef + 75e4466 commit 2a20646
Show file tree
Hide file tree
Showing 10 changed files with 78 additions and 68 deletions.
41 changes: 41 additions & 0 deletions core/common/src/main/scala/org/typelevel/otel4s/Attribute.scala
Original file line number Diff line number Diff line change
Expand Up @@ -28,3 +28,44 @@ package org.typelevel.otel4s
* the type of the attribute's value. One of [[AttributeType]]
*/
final case class Attribute[A](key: AttributeKey[A], value: A)

object Attribute {

@annotation.implicitNotFound("""
Could not find the `KeySelect` for ${A}. The `KeySelect` is defined for the following types:
String, Boolean, Long, Double, List[String], List[Boolean], List[Long], List[Double].
""")
sealed trait KeySelect[A] {
def make(name: String): AttributeKey[A]
}

object KeySelect {
def apply[A](implicit ev: KeySelect[A]): KeySelect[A] = ev

implicit val stringKey: KeySelect[String] = instance(AttributeKey.string)
implicit val booleanKey: KeySelect[Boolean] = instance(AttributeKey.boolean)
implicit val longKey: KeySelect[Long] = instance(AttributeKey.long)
implicit val doubleKey: KeySelect[Double] = instance(AttributeKey.double)

implicit val stringListKey: KeySelect[List[String]] =
instance(AttributeKey.stringList)

implicit val booleanListKey: KeySelect[List[Boolean]] =
instance(AttributeKey.booleanList)

implicit val longListKey: KeySelect[List[Long]] =
instance(AttributeKey.longList)

implicit val doubleListKey: KeySelect[List[Double]] =
instance(AttributeKey.doubleList)

private def instance[A](f: String => AttributeKey[A]): KeySelect[A] =
new KeySelect[A] {
def make(name: String): AttributeKey[A] = f(name)
}
}

def apply[A: KeySelect](name: String, value: A): Attribute[A] =
Attribute(KeySelect[A].make(name), value)

}
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ class CounterSuite extends CatsEffectSuite {

def allocateAttribute = {
allocated = true
List(Attribute(AttributeKey.string("key"), "value"))
List(Attribute("key", "value"))
}

for {
Expand All @@ -42,7 +42,7 @@ class CounterSuite extends CatsEffectSuite {
}

test("record value and attributes") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand All @@ -61,7 +61,7 @@ class CounterSuite extends CatsEffectSuite {
}

test("inc by one") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ class HistogramSuite extends CatsEffectSuite {

def allocateAttribute = {
allocated = true
List(Attribute(AttributeKey.string("key"), "value"))
List(Attribute("key", "value"))
}

for {
Expand All @@ -47,7 +47,7 @@ class HistogramSuite extends CatsEffectSuite {
}

test("record value and attributes") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand All @@ -66,7 +66,7 @@ class HistogramSuite extends CatsEffectSuite {
}

test("record duration") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")
val sleepDuration = 500.millis
val unit = TimeUnit.MILLISECONDS

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ class UpDownCounterSuite extends CatsEffectSuite {

def allocateAttribute = {
allocated = true
List(Attribute(AttributeKey.string("key"), "value"))
List(Attribute("key", "value"))
}

for {
Expand All @@ -43,7 +43,7 @@ class UpDownCounterSuite extends CatsEffectSuite {
}

test("record value and attributes") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand All @@ -62,7 +62,7 @@ class UpDownCounterSuite extends CatsEffectSuite {
}

test("inc by one") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand All @@ -81,7 +81,7 @@ class UpDownCounterSuite extends CatsEffectSuite {
}

test("dec by one") {
val attribute = Attribute(AttributeKey.string("key"), "value")
val attribute = Attribute("key", "value")

val expected =
List(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ class TracerSuite extends CatsEffectSuite {

def attribute = {
allocated = true
List(Attribute(AttributeKey.string("key"), "value"))
List(Attribute("key", "value"))
}

def exception = {
Expand Down
4 changes: 2 additions & 2 deletions docs/examples/jaeger-docker.md
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ import cats.effect.std.Console
import cats.effect.std.Random
import cats.syntax.all._
import io.opentelemetry.api.GlobalOpenTelemetry
import org.typelevel.otel4s.{Attribute, AttributeKey}
import org.typelevel.otel4s.Attribute
import org.typelevel.otel4s.java.OtelJava
import org.typelevel.otel4s.trace.Tracer

Expand All @@ -103,7 +103,7 @@ object Work {

def doWorkInternal(steps: Int): F[Unit] = {
val step = Tracer[F]
.span("internal", Attribute(AttributeKey.long("steps"), steps.toLong))
.span("internal", Attribute("steps", steps.toLong))
.surround {
for {
random <- Random.scalaUtilRandom
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,26 +24,14 @@ class ConversionsSuite extends FunSuite {

test("proper conversion to OpenTelemetry Attributes") {
val attributes = List(
Attribute(AttributeKey.string("string"), "string"),
Attribute(AttributeKey.boolean("boolean"), false),
Attribute(AttributeKey.long("long"), 0L),
Attribute(AttributeKey.double("double"), 0.0),
Attribute(
AttributeKey.stringList("string"),
List("string 1", "string 2")
),
Attribute(
AttributeKey.booleanList("boolean"),
List(false, true)
),
Attribute(
AttributeKey.longList("long"),
List(Long.MinValue, Long.MaxValue)
),
Attribute(
AttributeKey.doubleList("double"),
List(Double.MinValue, Double.MaxValue)
)
Attribute("string", "string"),
Attribute("boolean", false),
Attribute("long", 0L),
Attribute("double", 0.0),
Attribute("string", List("string 1", "string 2")),
Attribute("boolean", List(false, true)),
Attribute("long", List(Long.MinValue, Long.MaxValue)),
Attribute("double", List(Double.MinValue, Double.MaxValue))
)

val expected = JAttributes
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,21 +45,15 @@ class CounterSuite extends CatsEffectSuite {
.withDescription("description")
.create

_ <- counter.add(
1L,
Attribute(AttributeKey.string("string-attribute"), "value")
)
_ <- counter.add(1L, Attribute("string-attribute", "value"))

metrics <- sdk.metrics
} yield {
val resourceAttributes = List(
Attribute(AttributeKey.string("service.name"), "unknown_service:java"),
Attribute(AttributeKey.string("telemetry.sdk.language"), "java"),
Attribute(AttributeKey.string("telemetry.sdk.name"), "opentelemetry"),
Attribute(
AttributeKey.string("telemetry.sdk.version"),
BuildInfo.openTelemetrySdkVersion
)
Attribute("service.name", "unknown_service:java"),
Attribute("telemetry.sdk.language", "java"),
Attribute("telemetry.sdk.name", "opentelemetry"),
Attribute("telemetry.sdk.version", BuildInfo.openTelemetrySdkVersion)
)

val scope = new InstrumentationScope(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,6 @@ import io.opentelemetry.sdk.trace.`export`.SimpleSpanProcessor
import io.opentelemetry.sdk.trace.internal.data.ExceptionEventData
import munit.CatsEffectSuite
import org.typelevel.otel4s.Attribute
import org.typelevel.otel4s.AttributeKey
import org.typelevel.otel4s.trace.Span
import org.typelevel.otel4s.trace.Tracer
import org.typelevel.otel4s.trace.TracerProvider
Expand Down Expand Up @@ -74,7 +73,7 @@ class TracerSuite extends CatsEffectSuite {
test("set attributes only once") {
val key = "string-attribute"
val value = "value"
val attribute = Attribute(AttributeKey.string(key), value)
val attribute = Attribute(key, value)

for {
sdk <- makeSdk()
Expand Down Expand Up @@ -121,7 +120,7 @@ class TracerSuite extends CatsEffectSuite {
}

test("propagate attributes") {
val attribute = Attribute(AttributeKey.string("string-attribute"), "value")
val attribute = Attribute("string-attribute", "value")

for {
sdk <- makeSdk()
Expand Down Expand Up @@ -391,7 +390,7 @@ class TracerSuite extends CatsEffectSuite {
}

test("trace resource") {
val attribute = Attribute(AttributeKey.string("string-attribute"), "value")
val attribute = Attribute("string-attribute", "value")

val acquireInnerDuration = 25.millis
val body1Duration = 100.millis
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -188,47 +188,35 @@ object MetricsSdk {
attributes.asMap().asScala.toList.collect {
case (attribute, value: String)
if attribute.getType == JAttributeType.STRING =>
Attribute(AttributeKey.string(attribute.getKey), value)
Attribute(attribute.getKey, value)

case (attribute, value: jl.Boolean)
if attribute.getType == JAttributeType.BOOLEAN =>
Attribute(AttributeKey.boolean(attribute.getKey), value.booleanValue())
Attribute(attribute.getKey, value.booleanValue())

case (attribute, value: jl.Long)
if attribute.getType == JAttributeType.LONG =>
Attribute(AttributeKey.long(attribute.getKey), value.longValue())
Attribute(attribute.getKey, value.longValue())

case (attribute, value: jl.Double)
if attribute.getType == JAttributeType.DOUBLE =>
Attribute(AttributeKey.double(attribute.getKey), value.doubleValue())
Attribute(attribute.getKey, value.doubleValue())

case (attribute, value: ju.List[String] @unchecked)
if attribute.getType == JAttributeType.STRING_ARRAY =>
Attribute(
AttributeKey.stringList(attribute.getKey),
value.asScala.toList
)
Attribute(attribute.getKey, value.asScala.toList)

case (attribute, value: ju.List[jl.Boolean] @unchecked)
if attribute.getType == JAttributeType.BOOLEAN_ARRAY =>
Attribute(
AttributeKey.booleanList(attribute.getKey),
value.asScala.toList.map(_.booleanValue())
)
Attribute(attribute.getKey, value.asScala.toList.map(_.booleanValue()))

case (attribute, value: ju.List[jl.Long] @unchecked)
if attribute.getType == JAttributeType.LONG_ARRAY =>
Attribute(
AttributeKey.longList(attribute.getKey),
value.asScala.toList.map(_.longValue())
)
Attribute(attribute.getKey, value.asScala.toList.map(_.longValue()))

case (attribute, value: ju.List[jl.Double] @unchecked)
if attribute.getType == JAttributeType.DOUBLE_ARRAY =>
Attribute(
AttributeKey.doubleList(attribute.getKey),
value.asScala.toList.map(_.doubleValue())
)
Attribute(attribute.getKey, value.asScala.toList.map(_.doubleValue()))
}

}

0 comments on commit 2a20646

Please sign in to comment.