Extend JUnitSuite to make sure the test is included in the report. After merging this, nothing would happen. We should then invoke `checkTestsHaveRun` from the jenkins nightly builds. That should then fail the build until we merge #28347 and switch the nightly builds to run on JDK11.
76 lines
2.8 KiB
Scala
76 lines
2.8 KiB
Scala
/*
|
|
* Copyright (C) 2016-2019 Lightbend Inc. <https://www.lightbend.com>
|
|
*/
|
|
|
|
package akka
|
|
|
|
import sbt.Keys._
|
|
import sbt._
|
|
|
|
object TestExtras {
|
|
|
|
object Filter {
|
|
object Keys {
|
|
val excludeTestNames = settingKey[Set[String]]("Names of tests to be excluded. Not supported by MultiJVM tests. Example usage: -Dakka.test.names.exclude=TimingSpec")
|
|
val excludeTestTags = settingKey[Set[String]]("Tags of tests to be excluded. It will not be used if you specify -Dakka.test.tags.only. Example usage: -Dakka.test.tags.exclude=long-running")
|
|
val onlyTestTags = settingKey[Set[String]]("Tags of tests to be ran. Example usage: -Dakka.test.tags.only=long-running")
|
|
|
|
val checkTestsHaveRun = taskKey[Unit]("Verify a number of notable tests have actually run");
|
|
}
|
|
|
|
import Keys._
|
|
|
|
private[Filter] object Params {
|
|
val testNamesExclude = systemPropertyAsSeq("akka.test.names.exclude").toSet
|
|
val testTagsExlcude = systemPropertyAsSeq("akka.test.tags.exclude").toSet
|
|
val testTagsOnly = systemPropertyAsSeq("akka.test.tags.only").toSet
|
|
}
|
|
|
|
def settings = {
|
|
Seq(
|
|
excludeTestNames := Params.testNamesExclude,
|
|
excludeTestTags := {
|
|
if (onlyTestTags.value.isEmpty) Params.testTagsExlcude
|
|
else Set.empty
|
|
},
|
|
onlyTestTags := Params.testTagsOnly,
|
|
|
|
// add filters for tests excluded by name
|
|
testOptions in Test ++= excludeTestNames.value.toSeq.map(exclude => Tests.Filter(test => !test.contains(exclude))),
|
|
|
|
// add arguments for tests excluded by tag
|
|
testOptions in Test ++= {
|
|
val tags = excludeTestTags.value
|
|
if (tags.isEmpty) Seq.empty else Seq(Tests.Argument("-l", tags.mkString(" ")))
|
|
},
|
|
|
|
// add arguments for running only tests by tag
|
|
testOptions in Test ++= {
|
|
val tags = onlyTestTags.value
|
|
if (tags.isEmpty) Seq.empty else Seq(Tests.Argument("-n", tags.mkString(" ")))
|
|
},
|
|
|
|
checkTestsHaveRun := {
|
|
require(
|
|
file("akka-stream-tests/target/test-reports/TEST-akka.stream.scaladsl.FlowPublisherSinkSpec.xml").exists,
|
|
"The jdk9-only FlowPublisherSinkSpec.scala should be run as part of the build"
|
|
)
|
|
require(
|
|
file("akka-stream-tests/target/test-reports/TEST-akka.stream.javadsl.JavaFlowSupportCompileTest.xml").exists,
|
|
"The jdk9-only JavaFlowSupportCompileTest.java should be run as part of the build"
|
|
)
|
|
}
|
|
)
|
|
}
|
|
|
|
def containsOrNotExcludesTag(tag: String) = {
|
|
Params.testTagsOnly.contains(tag) || !Params.testTagsExlcude(tag)
|
|
}
|
|
|
|
def systemPropertyAsSeq(name: String): Seq[String] = {
|
|
val prop = sys.props.get(name).getOrElse("")
|
|
if (prop.isEmpty) Seq.empty else prop.split(",").toSeq
|
|
}
|
|
}
|
|
|
|
}
|