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

org.scalajs.junit.JUnitTask.scala Maven / Gradle / Ivy

package org.scalajs.junit

import com.novocode.junit.{Ansi, RichLogger}
import Ansi._
import sbt.testing._
import org.scalajs.testinterface.TestUtils
import scala.util.{Try, Success, Failure}

final class JUnitTask(val taskDef: TaskDef, runner: JUnitBaseRunner)
    extends sbt.testing.Task {

  def tags: Array[String] = Array.empty

  def execute(eventHandler: EventHandler, loggers: Array[Logger],
      continuation: Array[Task] => Unit): Unit = {
    continuation(execute(eventHandler, loggers))
  }

  def execute(eventHandler: EventHandler, loggers: Array[Logger]): Array[Task] = {
    val fullClassName = taskDef.fullyQualifiedName
    val richLogger = new RichLogger(loggers, runner.runSettings, fullClassName)

    def infoOrDebug(msg: String): Unit = {
      if (runner.runSettings.verbose)
        richLogger.info(msg)
      else
        richLogger.debug(msg)
    }

    infoOrDebug(c("Test run started", INFO))

    val bootstrapperName = fullClassName + "$scalajs$junit$bootstrapper"

    val startTime = System.nanoTime

    def errorWhileLoadingClass(t: Throwable): Unit = {
      richLogger.error("Error while loading test class: " + fullClassName, t)
      val selector = new TestSelector(fullClassName)
      val optThrowable = new OptionalThrowable(t)
      val ev = new JUnitEvent(taskDef, Status.Failure, selector, optThrowable)
      eventHandler.handle(ev)
    }

    Try(TestUtils.loadModule(bootstrapperName, runner.testClassLoader)) match {
      case Success(classMetadata: JUnitTestBootstrapper) =>
        new JUnitExecuteTest(taskDef, runner, classMetadata,
            richLogger, eventHandler).executeTests()

      case Success(_) =>
        val msg = s"Expected $bootstrapperName to extend JUnitTestBootstrapper"
        errorWhileLoadingClass(new Exception(msg))

      case Failure(exception) =>
        errorWhileLoadingClass(exception)
    }

    runner.taskDone()

    val time = System.nanoTime - startTime
    val failed = runner.testFailedCount
    val ignored = runner.testIgnoredCount
    val total = runner.testTotalCount

    val msg = {
      c("Test run finished: ", INFO) +
      c(s"$failed failed", if (failed == 0) INFO else ERRCOUNT) +
      c(s", ", INFO) +
      c(s"$ignored ignored", if (ignored == 0) INFO else IGNCOUNT) +
      c(s", $total total, ${time.toDouble / 1000000000}s", INFO)
    }

    infoOrDebug(msg)
    runner.resetTestCounts()

    Array()
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy