From 00628f7471c8d77f974198783507f7d52a9276db Mon Sep 17 00:00:00 2001 From: Vfrolov Date: Tue, 5 Jul 2022 14:50:37 +0300 Subject: [PATCH] Migrate diktat smoke tests to SAVE-cli mechanism ### What's done: * migrated diktat smoke tests to SAVE-cli mechanism Closes #1383 --- .../kotlin/org/cqfn/diktat/util/FixTestBase.kt | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/diktat-rules/src/test/kotlin/org/cqfn/diktat/util/FixTestBase.kt b/diktat-rules/src/test/kotlin/org/cqfn/diktat/util/FixTestBase.kt index 9a038a2a48..92df185c38 100644 --- a/diktat-rules/src/test/kotlin/org/cqfn/diktat/util/FixTestBase.kt +++ b/diktat-rules/src/test/kotlin/org/cqfn/diktat/util/FixTestBase.kt @@ -14,8 +14,13 @@ import org.junit.jupiter.api.Assertions import java.io.File import java.io.FileOutputStream import java.nio.file.Path +import java.nio.file.Paths import kotlin.io.path.bufferedWriter import kotlin.io.path.div +import kotlin.io.path.exists +import kotlin.io.path.listDirectoryEntries +import kotlin.io.path.name +import kotlin.io.path.pathString /** * @property resourceFilePath path to files which will be compared in tests @@ -29,7 +34,6 @@ open class FixTestBase( private val testComparatorUnit = TestComparatorUnit(resourceFilePath) { text, fileName -> format(ruleSetProviderRef, text, fileName, rulesConfigList, cb = cb) } - private val diktatVersion = "1.2.1-SNAPSHOT" constructor(resourceFilePath: String, ruleSupplier: (rulesConfigList: List) -> Rule, @@ -86,6 +90,7 @@ open class FixTestBase( * @param testPath path to file with code that will be transformed by formatter, relative to [resourceFilePath] * @param configFilePath path of diktat-analysis file */ + @Suppress("TOO_LONG_FUNCTION") protected fun saveSmokeTest( configFilePath: String, expectedPath: String, @@ -93,10 +98,17 @@ open class FixTestBase( ) { val processBuilder = ProcessBuilder("src/test/resources/test/smoke/${getSaveForCurrentOs()}", "src/test/resources/test/smoke/src/main/kotlin", expectedPath, testPath) + val diktatDir: String = + Paths.get("../diktat-ruleset/target") + .takeIf { it.exists() } + ?.listDirectoryEntries() + ?.single { it.name.contains("diktat") } + ?.pathString ?: "" + val file = File("tmpSave.txt") val diktat = File("src/test/resources/test/smoke/diktat.jar") val configFile = File("src/test/resources/test/smoke/diktat-analysis.yml") - val diktatFrom = File("../diktat-ruleset/target/diktat-$diktatVersion.jar") + val diktatFrom = File(diktatDir) val save = File("src/test/resources/test/smoke/${getSaveForCurrentOs()}") val ktlint = File("src/test/resources/test/smoke/ktlint")