diff options
author | Diego <diegolparra@gmail.com> | 2014-09-09 22:23:03 -0300 |
---|---|---|
committer | Diego <diegolparra@gmail.com> | 2014-09-09 22:23:03 -0300 |
commit | e3ce632beb18f4c1f69eff246ff5c646fd315c46 (patch) | |
tree | 190a2a2021b22b020ac327b8230cf1dc4295466a /kamon-play/src/main/scala/kamon | |
parent | 6884c0f3f7bf9376e9eaf4f330d7622c142399e3 (diff) | |
download | Kamon-e3ce632beb18f4c1f69eff246ff5c646fd315c46.tar.gz Kamon-e3ce632beb18f4c1f69eff246ff5c646fd315c46.tar.bz2 Kamon-e3ce632beb18f4c1f69eff246ff5c646fd315c46.zip |
= play: * fix tests
* use kamon default dispatcher
Diffstat (limited to 'kamon-play/src/main/scala/kamon')
-rw-r--r-- | kamon-play/src/main/scala/kamon/play/instrumentation/WSInstrumentation.scala | 29 |
1 files changed, 13 insertions, 16 deletions
diff --git a/kamon-play/src/main/scala/kamon/play/instrumentation/WSInstrumentation.scala b/kamon-play/src/main/scala/kamon/play/instrumentation/WSInstrumentation.scala index 3e4d6110..14bcd8c9 100644 --- a/kamon-play/src/main/scala/kamon/play/instrumentation/WSInstrumentation.scala +++ b/kamon-play/src/main/scala/kamon/play/instrumentation/WSInstrumentation.scala @@ -16,15 +16,16 @@ package kamon.play.instrumentation +import kamon.Kamon import kamon.metric.TraceMetrics.HttpClientRequest -import kamon.trace.{ TraceContext, TraceRecorder } +import kamon.play.Play +import kamon.trace.TraceRecorder import org.aspectj.lang.ProceedingJoinPoint import org.aspectj.lang.annotation.{ Around, Aspect, Pointcut } import play.api.libs.ws.ning.NingWSRequest import play.api.libs.ws.{ WSRequest, WSResponse } import play.libs.Akka -import scala.concurrent.ExecutionContext.Implicits.global import scala.concurrent.Future @Aspect @@ -38,16 +39,17 @@ class WSInstrumentation { import kamon.play.instrumentation.WSInstrumentation._ - withOrNewTraceContext(TraceRecorder.currentContext)(request) { - val response = pjp.proceed().asInstanceOf[Future[WSResponse]] - val segmentHandle = TraceRecorder.startSegment(HttpClientRequest(request.url), basicRequestAttributes(request)) + TraceRecorder.currentContext match { + case ctx @ Some(_) ⇒ + TraceRecorder.withTraceContext(ctx) { + val executor = Kamon(Play)(Akka.system()).defaultDispatcher + val segmentHandle = TraceRecorder.startSegment(HttpClientRequest(request.url), basicRequestAttributes(request)) + val response = pjp.proceed().asInstanceOf[Future[WSResponse]] - response.map { - r ⇒ - segmentHandle.map(_.finish()) - TraceRecorder.finish() - } - response + response.map(result ⇒ segmentHandle.map(_.finish()))(executor) + response + } + case None ⇒ pjp.proceed() } } } @@ -62,9 +64,4 @@ object WSInstrumentation { "path" -> uri(request).getPath, "method" -> request.method) } - - def withOrNewTraceContext[T](context: Option[TraceContext])(request: WSRequest)(thunk: ⇒ T): T = { - if (context.isDefined) TraceRecorder.withTraceContext(context) { thunk } - else TraceRecorder.withNewTraceContext(request.url, metadata = basicRequestAttributes(request)) { thunk }(Akka.system()) - } }
\ No newline at end of file |