From be38fccd8261183fcd053218df90a542c8cc1850 Mon Sep 17 00:00:00 2001 From: Robert Stoll Date: Fri, 1 Nov 2024 16:47:01 +0100 Subject: [PATCH] only apply java-base instead of java to get rid of MPP issues moreover: - solve the double gradle test error message printing caused by vlsi-gradle-extension --- .../main/kotlin/build-logic.java.gradle.kts | 8 +++--- ...-logic.junit-jacoco-conventions.gradle.kts | 14 +++++++--- .../build-logic.kotlin-conventions.gradle.kts | 1 + ...ld-logic.kotlin-jvm-conventions.gradle.kts | 5 ++-- .../kotlin/build-logic.kotlin-jvm.gradle.kts | 8 ------ ...otlin-multiplatform-conventions.gradle.kts | 26 +++++++++++++++++++ ...uild-logic.kotlin-multiplatform.gradle.kts | 19 +------------- ....published-kotlin-multiplatform.gradle.kts | 3 +-- gradle/buildLibs.versions.toml | 2 +- 9 files changed, 47 insertions(+), 39 deletions(-) delete mode 100644 gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm.gradle.kts create mode 100644 gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform-conventions.gradle.kts diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.java.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.java.gradle.kts index a20f007..b8d3907 100644 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.java.gradle.kts +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.java.gradle.kts @@ -1,5 +1,5 @@ plugins { - id("java") + id("java-base") id("build-logic.gradle-conventions") } @@ -8,8 +8,10 @@ java { // reading JAVA_VERSION from env to enable jdk17 build in CI languageVersion.set(JavaLanguageVersion.of(buildParameters.java.version)) } - consistentResolution { - useCompileClasspathVersions() + project.afterEvaluate { + consistentResolution { + useCompileClasspathVersions() + } } } diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.junit-jacoco-conventions.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.junit-jacoco-conventions.gradle.kts index 8774e48..d721cf1 100644 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.junit-jacoco-conventions.gradle.kts +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.junit-jacoco-conventions.gradle.kts @@ -1,9 +1,15 @@ +import org.gradle.api.tasks.testing.logging.TestLogEvent + plugins { id("ch.tutteli.gradle.plugins.junitjacoco") } -dependencies { - // used to run the samples - testImplementation("org.junit.jupiter:junit-jupiter-api") - testImplementation("org.junit.jupiter:junit-jupiter-params") +// adjust because we use com.github.vlsi.gradle-extensions which prints tests differently, otherwise we print +// the failed tests twice. +tasks.withType().configureEach { + testLogging { + // Empty enum throws "Collection is empty", so we use Iterable method + setEvents((events - TestLogEvent.FAILED) as Iterable) + showStackTraces = false + } } diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-conventions.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-conventions.gradle.kts index af20ff7..81bd3c4 100644 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-conventions.gradle.kts +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-conventions.gradle.kts @@ -4,6 +4,7 @@ import org.jetbrains.kotlin.gradle.tasks.KotlinCompilationTask plugins { id("build-logic.gradle-conventions") } + tasks.configureEach> { compilerOptions { freeCompilerArgs.add("-opt-in=kotlin.RequiresOptIn") diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm-conventions.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm-conventions.gradle.kts index 2720953..fb89f5a 100644 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm-conventions.gradle.kts +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm-conventions.gradle.kts @@ -3,15 +3,14 @@ import org.jetbrains.kotlin.gradle.tasks.KotlinCompile plugins { id("build-logic.kotlin-conventions") - id("build-logic.junit-jacoco-conventions") // this plugin sets inter alia toolchain and source/targetCompatibility // but also applies common plugins such as gradle-convention, build-params id("build-logic.java") - id("ch.tutteli.gradle.plugins.kotlin.module.info") + id("build-logic.junit-jacoco-conventions") } tasks.configureEach { - compilerOptions{ + compilerOptions { jvmTarget.set(JvmTarget.fromTarget(buildParameters.defaultJdkVersion.toString())) } } diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm.gradle.kts deleted file mode 100644 index 521802c..0000000 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-jvm.gradle.kts +++ /dev/null @@ -1,8 +0,0 @@ -plugins { - kotlin("jvm") - id("build-logic.kotlin-jvm-conventions") -} - -dependencies { - testImplementation("org.jetbrains.kotlin:kotlin-test-junit5") -} diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform-conventions.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform-conventions.gradle.kts new file mode 100644 index 0000000..ac6a8dd --- /dev/null +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform-conventions.gradle.kts @@ -0,0 +1,26 @@ +import org.gradle.kotlin.dsl.kotlin + +plugins { + kotlin("multiplatform") + id("build-logic.gradle-conventions") +} + +kotlin { + sourceSets { + // necessary due to https://youtrack.jetbrains.com/issue/KT-65352/KMP-Gradle-impossible-to-set-language-apiVersion-for-common-to-1.4 + all { + languageSettings { + languageVersion = buildParameters.kotlin.version + apiVersion = buildParameters.kotlin.version + } + } + } +} + +// this is necessary due to some crazy kotlin plugin voodoo. If we define this in the rootProject itself, +// then it does not work. +rootProject.plugins.withType { + rootProject.configure { + lockFileDirectory = rootProject.projectDir.resolve("gradle") + } +} diff --git a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform.gradle.kts b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform.gradle.kts index 89d2f49..3801b3b 100644 --- a/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform.gradle.kts +++ b/gradle/build-logic/dev/src/main/kotlin/build-logic.kotlin-multiplatform.gradle.kts @@ -1,9 +1,8 @@ plugins { - kotlin("multiplatform") + id("build-logic.kotlin-multiplatform-conventions") id("build-logic.kotlin-jvm-conventions") } - kotlin { jvm { // for module-info.java @@ -18,21 +17,5 @@ kotlin { implementation(kotlin("test")) } } - - // necessary due to https://youtrack.jetbrains.com/issue/KT-65352/KMP-Gradle-impossible-to-set-language-apiVersion-for-common-to-1.4 - all { - languageSettings { - languageVersion = buildParameters.kotlin.version - apiVersion = buildParameters.kotlin.version - } - } - } -} - -// this is necessary due to some crazy kotlin plugin voodoo. If we define this in the rootProject itself, -// then it does not work. -rootProject.plugins.withType { - rootProject.configure { - lockFileDirectory = rootProject.projectDir.resolve("gradle") } } diff --git a/gradle/build-logic/publishing/src/main/kotlin/build-logic.published-kotlin-multiplatform.gradle.kts b/gradle/build-logic/publishing/src/main/kotlin/build-logic.published-kotlin-multiplatform.gradle.kts index 80a9343..fa94e60 100644 --- a/gradle/build-logic/publishing/src/main/kotlin/build-logic.published-kotlin-multiplatform.gradle.kts +++ b/gradle/build-logic/publishing/src/main/kotlin/build-logic.published-kotlin-multiplatform.gradle.kts @@ -1,7 +1,6 @@ -import ch.tutteli.gradle.plugins.publish.PublishPluginExtension - plugins { id("build-logic.kotlin-multiplatform") id("build-logic.dokka") id("ch.tutteli.gradle.plugins.publish") + id("ch.tutteli.gradle.plugins.kotlin.module.info") } diff --git a/gradle/buildLibs.versions.toml b/gradle/buildLibs.versions.toml index f4a7354..84362b6 100644 --- a/gradle/buildLibs.versions.toml +++ b/gradle/buildLibs.versions.toml @@ -3,7 +3,7 @@ dokka = "1.9.20" jacocoTool = "0.8.9" kotlin = "2.0.21" task-tree = "4.0.0" -tutteli = "5.0.1" +tutteli = "5.0.3" vlsi = "1.90" [libraries]