From 9c9b56cd8bc5e24444d30f921e646154423eb3b2 Mon Sep 17 00:00:00 2001 From: Maksym Ochenashko Date: Tue, 26 Dec 2023 19:50:51 +0200 Subject: [PATCH] Move `instances` to the `core-common` package --- build.sbt | 4 +-- .../otel4s/instances/AllInstances.scala | 19 ++++++++++++++ .../otel4s/instances/LocalInstances.scala | 13 ++++++---- .../typelevel/otel4s/instances/package.scala | 25 +++++++++++++++++++ .../instances/LocalInstancesSuite.scala | 6 ++--- docs/instrumentation/tracing-java-interop.md | 2 +- docs/tracing-context-propagation.md | 2 +- .../src/main/scala/PekkoHttpExample.scala | 4 +-- .../typelevel/otel4s/oteljava/OtelJava.scala | 2 +- .../otel4s/oteljava/trace/Traces.scala | 2 +- .../otel4s/oteljava/trace/TracerSuite.scala | 2 +- .../otel4s/sdk/trace/SdkTraceScopeSuite.scala | 19 +------------- 12 files changed, 65 insertions(+), 35 deletions(-) create mode 100644 core/common/src/main/scala/org/typelevel/otel4s/instances/AllInstances.scala rename oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/instances.scala => core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala (80%) create mode 100644 core/common/src/main/scala/org/typelevel/otel4s/instances/package.scala rename oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/InstancesSuite.scala => core/common/src/test/scala/org/typelevel/otel4s/instances/LocalInstancesSuite.scala (86%) diff --git a/build.sbt b/build.sbt index 093e166ea..3ffc927f4 100644 --- a/build.sbt +++ b/build.sbt @@ -103,6 +103,8 @@ lazy val `core-common` = crossProject(JVMPlatform, JSPlatform, NativePlatform) "org.typelevel" %%% "cats-mtl" % CatsMtlVersion, "org.typelevel" %%% "vault" % VaultVersion % Test, "org.typelevel" %%% "cats-laws" % CatsVersion % Test, + "org.typelevel" %%% "cats-mtl-laws" % CatsMtlVersion % Test, + "org.typelevel" %%% "cats-effect-testkit" % CatsEffectVersion % Test, "org.typelevel" %%% "discipline-munit" % MUnitDisciplineVersion % Test, "lgbt.princess" %%% "platform" % PlatformVersion % Test ) @@ -247,8 +249,6 @@ lazy val `oteljava-common` = project "org.typelevel" %%% "cats-effect" % CatsEffectVersion, "org.typelevel" %%% "cats-mtl" % CatsMtlVersion, "io.opentelemetry" % "opentelemetry-api" % OpenTelemetryVersion, - "org.typelevel" %%% "discipline-munit" % MUnitDisciplineVersion % Test, - "org.typelevel" %%% "cats-mtl-laws" % CatsMtlVersion % Test, "org.typelevel" %%% "cats-effect-testkit" % CatsEffectVersion % Test, "io.opentelemetry" % "opentelemetry-sdk-testing" % OpenTelemetryVersion % Test ), diff --git a/core/common/src/main/scala/org/typelevel/otel4s/instances/AllInstances.scala b/core/common/src/main/scala/org/typelevel/otel4s/instances/AllInstances.scala new file mode 100644 index 000000000..83702f62e --- /dev/null +++ b/core/common/src/main/scala/org/typelevel/otel4s/instances/AllInstances.scala @@ -0,0 +1,19 @@ +/* + * Copyright 2022 Typelevel + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.typelevel.otel4s.instances + +trait AllInstances extends LocalInstances diff --git a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/instances.scala b/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala similarity index 80% rename from oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/instances.scala rename to core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala index 3f4f708da..8c44322bb 100644 --- a/oteljava/common/src/main/scala/org/typelevel/otel4s/oteljava/instances.scala +++ b/core/common/src/main/scala/org/typelevel/otel4s/instances/LocalInstances.scala @@ -14,7 +14,7 @@ * limitations under the License. */ -package org.typelevel.otel4s.oteljava +package org.typelevel.otel4s.instances import cats.Applicative import cats.Functor @@ -23,19 +23,22 @@ import cats.effect.LiftIO import cats.effect.MonadCancelThrow import cats.mtl.Local -object instances { +trait LocalInstances { + // We hope this instance is moved into Cats Effect. - implicit def localForIoLocal[F[_]: MonadCancelThrow: LiftIO, E](implicit + // See https://github.com/typelevel/cats-effect/pull/3429 + implicit final def localForIOLocal[F[_]: MonadCancelThrow: LiftIO, E](implicit ioLocal: IOLocal[E] ): Local[F, E] = new Local[F, E] { - def applicative = + def applicative: Applicative[F] = Applicative[F] - def ask[E2 >: E] = + 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]) } + } diff --git a/core/common/src/main/scala/org/typelevel/otel4s/instances/package.scala b/core/common/src/main/scala/org/typelevel/otel4s/instances/package.scala new file mode 100644 index 000000000..97ac89a29 --- /dev/null +++ b/core/common/src/main/scala/org/typelevel/otel4s/instances/package.scala @@ -0,0 +1,25 @@ +/* + * Copyright 2022 Typelevel + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.typelevel.otel4s + +package object instances { + + object all extends AllInstances + + object local extends LocalInstances + +} diff --git a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/InstancesSuite.scala b/core/common/src/test/scala/org/typelevel/otel4s/instances/LocalInstancesSuite.scala similarity index 86% rename from oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/InstancesSuite.scala rename to core/common/src/test/scala/org/typelevel/otel4s/instances/LocalInstancesSuite.scala index 835585027..ab79a734a 100644 --- a/oteljava/common/src/test/scala/org/typelevel/otel4s/oteljava/InstancesSuite.scala +++ b/core/common/src/test/scala/org/typelevel/otel4s/instances/LocalInstancesSuite.scala @@ -14,7 +14,7 @@ * limitations under the License. */ -package org.typelevel.otel4s.oteljava +package org.typelevel.otel4s.instances import cats.effect.IO import cats.effect.IOLocal @@ -22,9 +22,9 @@ import cats.effect.testkit.TestInstances import cats.mtl.laws.discipline.LocalTests import munit.DisciplineSuite import org.scalacheck.Arbitrary.arbString -import org.typelevel.otel4s.oteljava.instances._ +import org.typelevel.otel4s.instances.local._ -class InstancesSuite extends DisciplineSuite with TestInstances { +class LocalInstancesSuite extends DisciplineSuite with TestInstances { implicit val ticker: Ticker = Ticker() unsafeRun { diff --git a/docs/instrumentation/tracing-java-interop.md b/docs/instrumentation/tracing-java-interop.md index f8caed2e9..2be92c1f8 100644 --- a/docs/instrumentation/tracing-java-interop.md +++ b/docs/instrumentation/tracing-java-interop.md @@ -51,9 +51,9 @@ It can be constructed in the following way: import cats.effect._ import cats.mtl.Local import cats.syntax.functor._ +import org.typelevel.otel4s.instances.local._ // brings Local derived from IOLocal import org.typelevel.otel4s.oteljava.context.Context import org.typelevel.otel4s.oteljava.OtelJava -import org.typelevel.otel4s.oteljava.instances._ // brings Local derived from IOLocal import io.opentelemetry.api.GlobalOpenTelemetry def createOtel4s[F[_]: Async](implicit L: Local[F, Context]): F[OtelJava[F]] = diff --git a/docs/tracing-context-propagation.md b/docs/tracing-context-propagation.md index bc9c2cf31..ecb1936f0 100644 --- a/docs/tracing-context-propagation.md +++ b/docs/tracing-context-propagation.md @@ -33,9 +33,9 @@ You can find both examples below and choose which one suits your requirements. import cats.effect._ import cats.mtl.Local import cats.syntax.functor._ +import org.typelevel.otel4s.instances.local._ // brings Local derived from IOLocal import org.typelevel.otel4s.oteljava.context.Context import org.typelevel.otel4s.oteljava.OtelJava -import org.typelevel.otel4s.oteljava.instances._ // brings Local derived from IOLocal import io.opentelemetry.api.GlobalOpenTelemetry def createOtel4s[F[_]: Async](implicit L: Local[F, Context]): F[OtelJava[F]] = diff --git a/examples/src/main/scala/PekkoHttpExample.scala b/examples/src/main/scala/PekkoHttpExample.scala index b48b63d5e..df39b7516 100644 --- a/examples/src/main/scala/PekkoHttpExample.scala +++ b/examples/src/main/scala/PekkoHttpExample.scala @@ -37,9 +37,9 @@ import org.apache.pekko.http.scaladsl.server.Directives._ import org.apache.pekko.http.scaladsl.server.Route import org.apache.pekko.util.ByteString import org.typelevel.otel4s.Attribute +import org.typelevel.otel4s.instances.local._ import org.typelevel.otel4s.oteljava.OtelJava import org.typelevel.otel4s.oteljava.context.Context -import org.typelevel.otel4s.oteljava.instances._ import org.typelevel.otel4s.trace.Tracer import scala.concurrent.Future @@ -78,7 +78,7 @@ object PekkoHttpExample extends IOApp.Simple { def run: IO[Unit] = IOLocal(Context.root).flatMap { implicit ioLocal: IOLocal[Context] => - implicit val local: Local[IO, Context] = localForIoLocal + implicit val local: Local[IO, Context] = localForIOLocal val otelJava: OtelJava[IO] = OtelJava.local(GlobalOpenTelemetry.get()) otelJava.tracerProvider.get("com.example").flatMap { 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 ee3a20e83..60b2f1b16 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 @@ -28,11 +28,11 @@ import io.opentelemetry.sdk.{OpenTelemetrySdk => JOpenTelemetrySdk} import io.opentelemetry.sdk.common.CompletableResultCode import org.typelevel.otel4s.Otel4s import org.typelevel.otel4s.context.propagation.ContextPropagators +import org.typelevel.otel4s.instances.local._ import org.typelevel.otel4s.metrics.MeterProvider import org.typelevel.otel4s.oteljava.context.Context import org.typelevel.otel4s.oteljava.context.LocalContext import org.typelevel.otel4s.oteljava.context.propagation.PropagatorConverters._ -import org.typelevel.otel4s.oteljava.instances._ import org.typelevel.otel4s.oteljava.metrics.Metrics import org.typelevel.otel4s.oteljava.trace.Traces import org.typelevel.otel4s.trace.TracerProvider diff --git a/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/Traces.scala b/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/Traces.scala index 598a5f7c6..b36aaa91b 100644 --- a/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/Traces.scala +++ b/oteljava/trace/src/main/scala/org/typelevel/otel4s/oteljava/trace/Traces.scala @@ -22,9 +22,9 @@ import cats.effect.LiftIO import cats.effect.Sync import io.opentelemetry.api.{OpenTelemetry => JOpenTelemetry} import org.typelevel.otel4s.context.propagation.ContextPropagators +import org.typelevel.otel4s.instances.local._ import org.typelevel.otel4s.oteljava.context.Context import org.typelevel.otel4s.oteljava.context.LocalContext -import org.typelevel.otel4s.oteljava.instances._ import org.typelevel.otel4s.trace.TracerProvider trait Traces[F[_]] { diff --git a/oteljava/trace/src/test/scala/org/typelevel/otel4s/oteljava/trace/TracerSuite.scala b/oteljava/trace/src/test/scala/org/typelevel/otel4s/oteljava/trace/TracerSuite.scala index 974e10964..868c361f1 100644 --- a/oteljava/trace/src/test/scala/org/typelevel/otel4s/oteljava/trace/TracerSuite.scala +++ b/oteljava/trace/src/test/scala/org/typelevel/otel4s/oteljava/trace/TracerSuite.scala @@ -52,9 +52,9 @@ import org.typelevel.otel4s.context.propagation.{ PassThroughPropagator => SPassThroughPropagator } import org.typelevel.otel4s.context.propagation.ContextPropagators +import org.typelevel.otel4s.instances.local._ import org.typelevel.otel4s.oteljava.context.Context import org.typelevel.otel4s.oteljava.context.propagation.PropagatorConverters._ -import org.typelevel.otel4s.oteljava.instances._ import org.typelevel.otel4s.trace.Span import org.typelevel.otel4s.trace.Tracer import org.typelevel.otel4s.trace.TracerProvider diff --git a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTraceScopeSuite.scala b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTraceScopeSuite.scala index 7bf4747f7..a0563d997 100644 --- a/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTraceScopeSuite.scala +++ b/sdk/trace/src/test/scala/org/typelevel/otel4s/sdk/trace/SdkTraceScopeSuite.scala @@ -16,17 +16,13 @@ package org.typelevel.otel4s.sdk.trace -import cats.Applicative -import cats.Functor import cats.effect.IO import cats.effect.IOLocal -import cats.effect.LiftIO -import cats.effect.MonadCancelThrow -import cats.mtl.Local import munit.CatsEffectSuite import munit.ScalaCheckEffectSuite import org.scalacheck.Arbitrary import org.scalacheck.effect.PropF +import org.typelevel.otel4s.instances.local._ import org.typelevel.otel4s.sdk.context.Context import org.typelevel.otel4s.trace.SpanContext @@ -294,17 +290,4 @@ class SdkTraceScopeSuite extends CatsEffectSuite with ScalaCheckEffectSuite { SdkTraceScope.fromLocal[IO] } - private implicit def localForIoLocal[F[_]: MonadCancelThrow: LiftIO, E]( - implicit ioLocal: IOLocal[E] - ): Local[F, E] = - new Local[F, E] { - def applicative = - Applicative[F] - def ask[E2 >: E] = - 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]) - } }