mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-17 15:30:01 +08:00
Auto finding testing points
This commit is contained in:
parent
894b8a9c2e
commit
bb489601b7
@ -9,16 +9,20 @@
|
||||
|
||||
package net.mamoe.console.integrationtest
|
||||
|
||||
import net.mamoe.console.integrationtest.testpoints.DoNothingPoint
|
||||
import net.mamoe.console.integrationtest.testpoints.MCITBSelfAssertions
|
||||
import net.mamoe.console.integrationtest.testpoints.PluginSharedLibraries
|
||||
import net.mamoe.console.integrationtest.testpoints.plugin.PluginDataRenameToIdTest
|
||||
import net.mamoe.console.integrationtest.testpoints.terminal.TestTerminalLogging
|
||||
import org.junit.jupiter.api.Test
|
||||
import org.objectweb.asm.ClassReader
|
||||
import java.io.File
|
||||
import java.lang.management.ManagementFactory
|
||||
import java.nio.file.Files
|
||||
import java.nio.file.Paths
|
||||
import java.util.*
|
||||
import kotlin.io.path.inputStream
|
||||
import kotlin.io.path.isDirectory
|
||||
import kotlin.io.path.name
|
||||
import kotlin.reflect.KClass
|
||||
import kotlin.streams.toList
|
||||
import kotlin.test.assertTrue
|
||||
|
||||
|
||||
class MiraiConsoleIntegrationTestBootstrap {
|
||||
@ -32,22 +36,24 @@ class MiraiConsoleIntegrationTestBootstrap {
|
||||
val launcher = MiraiConsoleIntegrationTestLauncher()
|
||||
launcher.workingDir = workingDir
|
||||
launcher.plugins = readStringListFromEnv("IT_PLUGINS")
|
||||
launcher.points = listOf<Any>(
|
||||
DoNothingPoint,
|
||||
MCITBSelfAssertions,
|
||||
PluginDataRenameToIdTest,
|
||||
TestTerminalLogging,
|
||||
PluginSharedLibraries,
|
||||
).asSequence().map { v ->
|
||||
launcher.points = resolveTestPoints().also { points ->
|
||||
// Avoid error in resolving points
|
||||
assertTrue { points.contains("net.mamoe.console.integrationtest.testpoints.MCITBSelfAssertions") }
|
||||
assertTrue { points.contains("net.mamoe.console.integrationtest.testpoints.DoNothingPoint") }
|
||||
assertTrue { points.contains("net.mamoe.console.integrationtest.testpoints.terminal.TestTerminalLogging") }
|
||||
}.asSequence().map { v ->
|
||||
when (v) {
|
||||
is Class<*> -> v
|
||||
is KClass<*> -> v.java
|
||||
else -> v.javaClass
|
||||
is Class<*> -> v.name
|
||||
is KClass<*> -> v.java.name
|
||||
is String -> v
|
||||
else -> v.javaClass.name
|
||||
}
|
||||
}.map { it.name }.toMutableList()
|
||||
}.map { it.replace('/', '.') }.toMutableList()
|
||||
launcher.vmoptions = mutableListOf(
|
||||
*ManagementFactory.getRuntimeMXBean().inputArguments.filterNot {
|
||||
it.startsWith("-Djava.security.manager=")
|
||||
}.filterNot {
|
||||
it.startsWith("-Xmx")
|
||||
}.toTypedArray(),
|
||||
*System.getenv("IT_ARGS")!!.splitToSequence(",").map {
|
||||
Base64.getDecoder().decode(it).decodeToString()
|
||||
@ -55,4 +61,21 @@ class MiraiConsoleIntegrationTestBootstrap {
|
||||
)
|
||||
launcher.launch()
|
||||
}
|
||||
|
||||
private fun resolveTestPoints(): Collection<Any> {
|
||||
val ptloc = MCITBSelfAssertions.javaClass.getResource(MCITBSelfAssertions.javaClass.simpleName + ".class")
|
||||
ptloc ?: error("Failed to resolve test points")
|
||||
val path = Paths.get(ptloc.toURI()).parent
|
||||
return Files.walk(path)
|
||||
.filter { !it.isDirectory() }
|
||||
.filter { it.name.endsWith(".class") }
|
||||
.map { pt ->
|
||||
pt.inputStream().use {
|
||||
ClassReader(it).className
|
||||
}
|
||||
}
|
||||
.map { it.replace('/', '.') }
|
||||
.filter { AbstractTestPoint::class.java.isAssignableFrom(Class.forName(it)) }
|
||||
.use { it.toList() }
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user