All Downloads are FREE. Search and download functionalities are using the official Maven repository.

teststate.run.Report.scala Maven / Gradle / Ivy

The newest version!
package teststate.run

// import acyclic.file
import scala.annotation.elidable
import scala.util.control.NonFatal
import teststate.data.{Failure, Name}
import teststate.typeclass.DisplayError
import Report._

case class Report[+E](name: Option[Name], history: History[Failure[E]], stats: Stats) {

  @inline def failure = history.failure
  @inline def failed = history.failed
  @inline def result = history.result

  def failureReason[e >: E](implicit displayError: DisplayError[e]): Option[Failure[String]] =
    failure.map(_ map (err =>
      (history.rootFailurePath.lastOption, Option(displayError display err).filter(_.nonEmpty)) match {
        case (Some(f), Some(e)) => s"${f.name.value} -- $e"
        case (Some(f), None   ) => f.name.value
        case (None   , Some(e)) => e
        case (None   , None   ) => "Failed without an error message."
      }
    ))

  @elidable(elidable.ASSERTION)
  def assertF[EE >: E]()(implicit as: AssertionSettings, se: DisplayError[EE]): Unit =
    assert[EE]()(as.failSettingsOnPass, se)

  @elidable(elidable.ASSERTION)
  def assert[EE >: E]()(implicit as: AssertionSettings, se: DisplayError[EE]): Unit =
    failureReason(se) match {

      case None =>
        as.onPass.print[EE](this)

      case Some(fe) =>
        as.onFail.print[EE](this)

        throw fe.cause match {
          case Some(NonFatal(e)) =>
            e

          case Some(e) =>
            // Because UndefinedBehaviourErrors (and presumably other fatal errors) freeze Scala.JS
            val x = new RuntimeException(e.getMessage)
            x.setStackTrace(e.getStackTrace)
            x

          case None =>
            new AssertionError(fe.failure)
        }
    }

  def format[EE >: E](implicit as: AssertionSettings, s: DisplayError[EE]): String =
    format[EE](if (failed) as.onFail else as.onPass)(s)

  def format[EE >: E](f: Format)(implicit s: DisplayError[EE]): String =
    f.format[EE](this)(s) getOrElse ""

  def formatF[EE >: E](implicit as: AssertionSettings, s: DisplayError[EE]): String =
    format(as.failSettingsOnPass, s)
}

object Report {

  // Help keep Exports small

  type History[+E] = teststate.run.History[E]
  val  History     = teststate.run.History

  type Format = teststate.run.ReportFormat
  val  Format = teststate.run.ReportFormat

  type Stats = teststate.run.Stats
  val  Stats = teststate.run.Stats


  case class AssertionSettings(onPass: Format, onFail: Format) {
    def silenceOnPass: AssertionSettings =
      copy(onPass = Format.quiet)

    def failSettingsOnPass: AssertionSettings =
      copy(onPass = onFail)
  }

  object AssertionSettings {
    def uniform(format: Format): AssertionSettings =
      AssertionSettings(format, format)

    def uncoloured = AssertionSettings(
      onPass = Format.Default.uncoloured.apply,
      onFail = Format.Default.uncoloured.alwaysShowChildren.apply)

    def coloured = AssertionSettings(
      onPass = Format.Default.coloured.apply,
      onFail = Format.Default.coloured.alwaysShowChildren.apply)

    def default = coloured
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy