1
0
Fork 0
mirror of https://github.com/ethauvin/kobalt.git synced 2025-04-27 00:38:11 -07:00

Pass TaskResult better in tests.

This commit is contained in:
Cedric Beust 2015-11-18 23:16:13 -08:00
parent 521dfc327b
commit 2746f57b9a
2 changed files with 36 additions and 26 deletions

View file

@ -36,9 +36,13 @@ abstract class GenericTestRunner(open val project: Project, open val classpath:
return result return result
} }
fun runTests() { /**
* @return true if all the tests passed
*/
fun runTests() : Boolean {
val jvm = JavaInfo.create(File(SystemProperties.javaBase)) val jvm = JavaInfo.create(File(SystemProperties.javaBase))
val java = jvm.javaExecutable val java = jvm.javaExecutable
if (args.size > 0) {
val allArgs = arrayListOf<String>().apply { val allArgs = arrayListOf<String>().apply {
add(java!!.absolutePath) add(java!!.absolutePath)
add("-classpath") add("-classpath")
@ -59,7 +63,11 @@ abstract class GenericTestRunner(open val project: Project, open val classpath:
} else { } else {
log(1, "Test failures") log(1, "Test failures")
} }
return errorCode == 0
} else {
log(2, "Couldn't find any test classes")
return true
}
} }
} }

View file

@ -64,18 +64,20 @@ abstract class JvmCompilerPlugin @Inject constructor(
result.addAll(dependencyManager.calculateDependencies(project, context, it)) result.addAll(dependencyManager.calculateDependencies(project, context, it))
} }
} }
return dependencyManager.reorderDependencies(result) val result2 = dependencyManager.reorderDependencies(result)
return result2
} }
@Task(name = TASK_TEST, description = "Run the tests", runAfter = arrayOf("compile", "compileTest")) @Task(name = TASK_TEST, description = "Run the tests", runAfter = arrayOf("compile", "compileTest"))
fun taskTest(project: Project) : TaskResult { fun taskTest(project: Project) : TaskResult {
lp(project, "Running tests") lp(project, "Running tests")
val success =
if (project.testDependencies.any { it.id.contains("testng")} ) { if (project.testDependencies.any { it.id.contains("testng")} ) {
TestNgRunner(project, testDependencies(project)).runTests() TestNgRunner(project, testDependencies(project)).runTests()
} else { } else {
JUnitRunner(project, testDependencies(project)).runTests() JUnitRunner(project, testDependencies(project)).runTests()
} }
return TaskResult() return TaskResult(success)
} }
@Task(name = TASK_CLEAN, description = "Clean the project", runBefore = arrayOf("compile")) @Task(name = TASK_CLEAN, description = "Clean the project", runBefore = arrayOf("compile"))