From 5844800b369b5c58b557310ac0a0a36c2c3ff5a4 Mon Sep 17 00:00:00 2001 From: Zach Smith Date: Fri, 9 Mar 2018 10:59:28 -0800 Subject: Fix ServiceException classes to set Exception message for stack traces --- .../driver/core/rest/errors/serviceException.scala | 24 ++++++++++------------ 1 file changed, 11 insertions(+), 13 deletions(-) diff --git a/src/main/scala/xyz/driver/core/rest/errors/serviceException.scala b/src/main/scala/xyz/driver/core/rest/errors/serviceException.scala index d842c94..095936e 100644 --- a/src/main/scala/xyz/driver/core/rest/errors/serviceException.scala +++ b/src/main/scala/xyz/driver/core/rest/errors/serviceException.scala @@ -1,22 +1,20 @@ package xyz.driver.core.rest.errors -sealed abstract class ServiceException extends Exception { - def message: String -} +sealed abstract class ServiceException(val message: String) extends Exception(message) -final case class InvalidInputException(override val message: String = "Invalid input") extends ServiceException +final case class InvalidInputException(override val message: String = "Invalid input") extends ServiceException(message) final case class InvalidActionException(override val message: String = "This action is not allowed") - extends ServiceException + extends ServiceException(message) -final case class ResourceNotFoundException(override val message: String = "Resource not found") extends ServiceException +final case class ResourceNotFoundException(override val message: String = "Resource not found") + extends ServiceException(message) -final case class ExternalServiceException(serviceName: String, serviceMessage: String) extends ServiceException { - override def message = s"Error while calling '$serviceName': $serviceMessage" -} +final case class ExternalServiceException(serviceName: String, serviceMessage: String) + extends ServiceException(s"Error while calling '$serviceName': $serviceMessage") -final case class ExternalServiceTimeoutException(serviceName: String) extends ServiceException { - override def message = s"$serviceName took too long to respond" -} +final case class ExternalServiceTimeoutException(serviceName: String) + extends ServiceException(s"$serviceName took too long to respond") -final case class DatabaseException(override val message: String = "Database access error") extends ServiceException +final case class DatabaseException(override val message: String = "Database access error") + extends ServiceException(message) -- cgit v1.2.3