From 780abc163d0b91ec16a635ad1a3be4c59cd1bbc5 Mon Sep 17 00:00:00 2001 From: PJ Fanning Date: Mon, 30 Sep 2024 20:35:42 +0100 Subject: [PATCH] add test for context propagation for Pekko scheduled events --- .../pekko/SchedulerInstrumentationSpec.scala | 64 ++++++++++--------- 1 file changed, 33 insertions(+), 31 deletions(-) diff --git a/instrumentation/kamon-pekko/src/test/scala/kamon/instrumentation/pekko/SchedulerInstrumentationSpec.scala b/instrumentation/kamon-pekko/src/test/scala/kamon/instrumentation/pekko/SchedulerInstrumentationSpec.scala index be82b3f59..155f94f60 100644 --- a/instrumentation/kamon-pekko/src/test/scala/kamon/instrumentation/pekko/SchedulerInstrumentationSpec.scala +++ b/instrumentation/kamon-pekko/src/test/scala/kamon/instrumentation/pekko/SchedulerInstrumentationSpec.scala @@ -1,48 +1,50 @@ -/* ========================================================================================= - * Copyright © 2013-2022 the kamon project +/* =================================================== + * Copyright © 2013 the kamon project * - * 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 + * 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 + * 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. - * ========================================================================================= - */ + * 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 kamon.instrumentation.futures.scala -package kamon.instrumentation.pekko - -import org.apache.pekko.actor.ActorSystem -import org.apache.pekko.testkit.{ImplicitSender, TestKit} import kamon.Kamon +import kamon.context.Context import kamon.tag.Lookups.plain import kamon.testkit.InitAndStopKamonAfterAll -import org.scalatest.concurrent.Eventually +import org.apache.pekko.actor.ActorSystem +import org.apache.pekko.testkit.TestKit import org.scalatest.matchers.should.Matchers import org.scalatest.wordspec.AnyWordSpecLike -import scala.concurrent.Promise -import scala.concurrent.duration._ +import scala.concurrent.duration.DurationInt +import scala.concurrent.{Await, ExecutionContext, Promise} -class SchedulerInstrumentationSpec extends TestKit(ActorSystem("SchedulerInstrumentationSpec")) with AnyWordSpecLike - with Matchers with InitAndStopKamonAfterAll with ImplicitSender with Eventually { +class SchedulerInstrumentationSpec extends TestKit(ActorSystem("SchedulerInstrumentationSpec")) + with AnyWordSpecLike with Matchers with InitAndStopKamonAfterAll { - "the Pekko Scheduler instrumentation" should { - "propagate the current context in calls to scheduler.scheduleOnce" in { - val contextTagPromise = Promise[String]() - val tagValueFuture = contextTagPromise.future + private implicit val execContext: ExecutionContext = system.dispatcher - Kamon.runWithContextTag("key", "one") { - system.scheduler.scheduleOnce(100 millis) { - contextTagPromise.success(Kamon.currentContext().getTag(plain("key"))) - }(system.dispatcher) - } + "a Pekko scheduled task created when instrumentation is active" should { + "capture the Context available when created" which { + "must be available when executing the scheduled task" in { + + val context = Context.of("key", "value") + val promise = Promise[String]() + Kamon.runWithContext(context) { + system.scheduler.scheduleOnce(200.millis) { + promise.success(Kamon.currentContext().getTag(plain("key"))) + } + } - eventually(timeout(5 seconds)) { - tagValueFuture.value.get.get shouldBe "one" + Await.result(promise.future, 5.seconds) shouldBe "value" } } }