diff options
Diffstat (limited to 'core/test-api')
-rw-r--r-- | core/test-api/src/main/kotlin/testApi/testRunner/TestRunner.kt | 43 |
1 files changed, 28 insertions, 15 deletions
diff --git a/core/test-api/src/main/kotlin/testApi/testRunner/TestRunner.kt b/core/test-api/src/main/kotlin/testApi/testRunner/TestRunner.kt index de0cd896..44353535 100644 --- a/core/test-api/src/main/kotlin/testApi/testRunner/TestRunner.kt +++ b/core/test-api/src/main/kotlin/testApi/testRunner/TestRunner.kt @@ -28,22 +28,28 @@ abstract class AbstractTest<M : TestMethods, T : TestBuilder<M>, D : DokkaTestGe File("src/test/resources/$name").takeIf { it.exists() }?.toPath() ?: throw InvalidPathException(name, "Cannot be found") + /** + * @param useOutputLocationFromConfig if set to true, output location specified in [DokkaConfigurationImpl.outputDir] + * will be used. If set to false, a temporary folder will be used instead. + */ protected fun testFromData( configuration: DokkaConfigurationImpl, cleanupOutput: Boolean = true, - preserveOutputLocation: Boolean = false, + useOutputLocationFromConfig: Boolean = false, pluginOverrides: List<DokkaPlugin> = emptyList(), block: T.() -> Unit ) { val testMethods = testBuilder().apply(block).build() - val configurationToUse = if (!preserveOutputLocation) { - val tempDir = getTempDir(cleanupOutput) - if (!cleanupOutput) - logger.info("Output generated under: ${tempDir.root.absolutePath}") - configuration.copy( - outputDir = tempDir.root - ) - } else configuration + val configurationToUse = + if (useOutputLocationFromConfig) { + configuration + } else { + val tempDir = getTempDir(cleanupOutput) + if (!cleanupOutput) { + logger.info("Output generated under: ${tempDir.root.absolutePath}") + } + configuration.copy(outputDir = tempDir.root) + } dokkaTestGenerator( configurationToUse, @@ -131,12 +137,19 @@ abstract class AbstractTest<M : TestMethods, T : TestBuilder<M>, D : DokkaTestGe Files.write(file, content.toByteArray(charset)) } - private fun getTempDir(cleanupOutput: Boolean) = if (cleanupOutput) { - TemporaryFolder().apply { create() } - } else { - object : TemporaryFolder() { - override fun after() {} - }.apply { create() } + private fun getTempDir(cleanupOutput: Boolean) = + if (cleanupOutput) { + TemporaryFolder().apply { create() } + } else { + TemporaryFolderWithoutCleanup().apply { create() } + } + + /** + * Creates a temporary folder, but doesn't delete files + * right after it's been used, delegating it to the OS + */ + private class TemporaryFolderWithoutCleanup : TemporaryFolder() { + override fun after() { } } protected fun dokkaConfiguration(block: TestDokkaConfigurationBuilder.() -> Unit): DokkaConfigurationImpl = |