org.scalajs.junit.JUnitMasterRunner.scala Maven / Gradle / Ivy
package org.scalajs.junit
import com.novocode.junit.RunSettings
import sbt.testing._
import java.util.concurrent.atomic.AtomicInteger
final class JUnitMasterRunner(
args: Array[String],
remoteArgs: Array[String],
testClassLoader: ClassLoader,
runSettings: RunSettings)
extends JUnitBaseRunner(args, remoteArgs, testClassLoader, runSettings) {
private[this] var registeredCount = 0
private[this] var slaveCount = 0
def tasks(taskDefs: Array[TaskDef]): Array[Task] = {
registeredCount += taskDefs.length
taskDefs.map(newTask)
}
def done(): String = {
val slaves = slaveCount
val registered = registeredCount
val done = doneCount
if (slaves > 0)
throw new IllegalStateException(s"There are still $slaves slaves running")
if (registered != done) {
val msg = s"$registered task(s) were registered, $done were executed"
throw new IllegalStateException(msg)
} else {
""
}
}
def receiveMessage(msg: String): Option[String] = msg(0) match {
case 'd' =>
val slaveDone = JUnitBaseRunner.Done.deserialize(msg.tail)
doneCount += slaveDone.done
passedCount += slaveDone.passed
failedCount += slaveDone.failed
ignoredCount += slaveDone.skipped
skippedCount += slaveDone.skipped
totalCount += slaveDone.total
slaveCount -= 1
None
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy