aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala
diff options
context:
space:
mode:
authorJohn St. John <jstjohn@users.noreply.github.com>2017-09-27 11:25:53 -0700
committerGitHub <noreply@github.com>2017-09-27 11:25:53 -0700
commitf384bfcf0870c3881a3a4c6afb6eca9baf163077 (patch)
tree84820824801474f680c79fd0373e373443f67a16 /src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala
parent26a5eb401c48c08812f1292664848595e7f74806 (diff)
parent8a66e1a0e62187d850e665af0d17431272775705 (diff)
downloaddriver-core-f384bfcf0870c3881a3a4c6afb6eca9baf163077.tar.gz
driver-core-f384bfcf0870c3881a3a4c6afb6eca9baf163077.tar.bz2
driver-core-f384bfcf0870c3881a3a4c6afb6eca9baf163077.zip
Merge pull request #68 from drivergroup/jstjohn/catch_and_log_google_exceptions_in_tracing
Catch and log google tracing exceptions rather than crashing the app
Diffstat (limited to 'src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala')
-rw-r--r--src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala b/src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala
new file mode 100644
index 0000000..64ae15a
--- /dev/null
+++ b/src/main/scala/xyz/driver/core/trace/ExceptionLoggingSizedBufferingTraceConsumer.scala
@@ -0,0 +1,26 @@
+package xyz.driver.core.trace
+
+import com.google.cloud.trace.v1.consumer.{FlushableTraceConsumer}
+import com.google.devtools.cloudtrace.v1.Traces
+import com.typesafe.scalalogging.Logger
+import scala.util.Try
+
+/**
+ * ExceptionLoggingFlushableTraceConsumer simply wraps a flushable trace consumer and catches/logs any exceptions
+ * @param traceConsumer the flusable trace consumer to wrap
+ * @param log where to log any exceptions
+ */
+class ExceptionLoggingFlushableTraceConsumer(traceConsumer: FlushableTraceConsumer, log: Logger)
+ extends FlushableTraceConsumer {
+
+ private val flushableTraceConsumer = traceConsumer
+
+ private def exceptionLogger(exception: Throwable): Unit =
+ log.error(s"Encountered exception logging to google $exception")
+
+ override def receive(trace: Traces): Unit =
+ Try(flushableTraceConsumer.receive(trace)).fold(exceptionLogger, identity)
+
+ override def flush(): Unit =
+ Try(flushableTraceConsumer.flush()).fold(exceptionLogger, identity)
+}