From 339bebc6d385239a69fdd22e9dcb320695c9c90a Mon Sep 17 00:00:00 2001 From: Joris Borgdorff Date: Mon, 3 Jul 2023 13:45:55 +0200 Subject: [PATCH 1/4] Fixed snyk test --- buildSrc/src/main/kotlin/Versions.kt | 1 + .../gradle/plugin/RadarDependencyManagementPlugin.kt | 2 +- radar-commons-testing/build.gradle.kts | 4 ++++ 3 files changed, 6 insertions(+), 1 deletion(-) diff --git a/buildSrc/src/main/kotlin/Versions.kt b/buildSrc/src/main/kotlin/Versions.kt index 4278713a..6e79d0b0 100644 --- a/buildSrc/src/main/kotlin/Versions.kt +++ b/buildSrc/src/main/kotlin/Versions.kt @@ -13,6 +13,7 @@ object Versions { const val java = 11 const val slf4j = "2.0.9" const val confluent = "7.5.0" + const val guava = "32.1.1-jre" const val kafka = "7.5.0-ce" const val avro = "1.11.3" const val jackson = "2.15.2" diff --git a/radar-commons-gradle/src/main/kotlin/org/radarbase/gradle/plugin/RadarDependencyManagementPlugin.kt b/radar-commons-gradle/src/main/kotlin/org/radarbase/gradle/plugin/RadarDependencyManagementPlugin.kt index 8baf32b6..f36993c2 100644 --- a/radar-commons-gradle/src/main/kotlin/org/radarbase/gradle/plugin/RadarDependencyManagementPlugin.kt +++ b/radar-commons-gradle/src/main/kotlin/org/radarbase/gradle/plugin/RadarDependencyManagementPlugin.kt @@ -22,7 +22,7 @@ interface RadarDependencyManagementExtension { class RadarDependencyManagementPlugin : Plugin { override fun apply(project: Project): Unit = with(project) { val extension = extensions.create("radarDependencies").apply { - regex.convention("(^[0-9,.v-]+(-r)?|RELEASE|FINAL|GA|-CE)$") + regex.convention("(^[0-9,.v-]+(-r)?|RELEASE|FINAL|GA|-CE|-JRE|-ANDROID)$") rejectMajorVersionUpdates.convention(false) } diff --git a/radar-commons-testing/build.gradle.kts b/radar-commons-testing/build.gradle.kts index 4c14246e..92a5117b 100644 --- a/radar-commons-testing/build.gradle.kts +++ b/radar-commons-testing/build.gradle.kts @@ -52,6 +52,10 @@ dependencies { } implementation("io.confluent:kafka-avro-serializer:${Versions.confluent}") + api("org.apache.avro:avro:${Versions.avro}") { + implementation("org.apache.commons:commons-compress:${Versions.commonsCompress}") + } + implementation(platform("io.ktor:ktor-bom:${Versions.ktor}")) implementation("io.ktor:ktor-serialization-kotlinx-json") From 67df87f23e419f5a9314d1b680f012a297ad13b0 Mon Sep 17 00:00:00 2001 From: Bastiaan Date: Thu, 7 Mar 2024 11:56:29 +0100 Subject: [PATCH 2/4] applied changes from joris' old branch --- .editorconfig | 4 ++++ buildSrc/src/main/kotlin/Versions.kt | 2 +- radar-commons-server/build.gradle.kts | 10 ++++++++-- radar-commons-testing/build.gradle.kts | 6 ++++-- 4 files changed, 17 insertions(+), 5 deletions(-) diff --git a/.editorconfig b/.editorconfig index d340b76d..ce7dcfe8 100644 --- a/.editorconfig +++ b/.editorconfig @@ -15,8 +15,12 @@ charset = utf-8 trim_trailing_whitespace = true insert_final_newline = true +[*.{kt,kts}] +ktlint_standard_no-wildcard-imports = disabled + [*.md] trim_trailing_whitespace = false [*.{json,yaml,yml}] +indent_style = space indent_size = 2 diff --git a/buildSrc/src/main/kotlin/Versions.kt b/buildSrc/src/main/kotlin/Versions.kt index 6e79d0b0..89c56a51 100644 --- a/buildSrc/src/main/kotlin/Versions.kt +++ b/buildSrc/src/main/kotlin/Versions.kt @@ -13,7 +13,6 @@ object Versions { const val java = 11 const val slf4j = "2.0.9" const val confluent = "7.5.0" - const val guava = "32.1.1-jre" const val kafka = "7.5.0-ce" const val avro = "1.11.3" const val jackson = "2.15.2" @@ -28,4 +27,5 @@ object Versions { const val coroutines = "1.7.3" const val commonsCompress = "1.24.0" const val snappy = "1.1.10.5" + const val guava = "32.1.1-jre" } diff --git a/radar-commons-server/build.gradle.kts b/radar-commons-server/build.gradle.kts index b8b03ea6..6abb2a41 100644 --- a/radar-commons-server/build.gradle.kts +++ b/radar-commons-server/build.gradle.kts @@ -39,7 +39,10 @@ dependencies { implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml") implementation("com.fasterxml.jackson.core:jackson-databind") - api("org.apache.avro:avro:${Versions.avro}") + + api("org.apache.avro:avro:${Versions.avro}") { + implementation("org.apache.commons:commons-compress:${Versions.commonsCompress}") + } implementation("org.apache.kafka:kafka-clients:${Versions.kafka}") { implementation("org.xerial.snappy:snappy-java:${Versions.snappy}") @@ -47,7 +50,10 @@ dependencies { testImplementation("org.mockito:mockito-core:${Versions.mockito}") // Direct producer uses KafkaAvroSerializer if initialized - testImplementation("io.confluent:kafka-avro-serializer:${Versions.confluent}") + + implementation("io.confluent:kafka-avro-serializer:${Versions.confluent}") { + runtimeOnly("com.google.guava:guava:${Versions.guava}") + } testImplementation("org.radarbase:radar-schemas-commons:${Versions.radarSchemas}") } diff --git a/radar-commons-testing/build.gradle.kts b/radar-commons-testing/build.gradle.kts index 92a5117b..f7a5ffad 100644 --- a/radar-commons-testing/build.gradle.kts +++ b/radar-commons-testing/build.gradle.kts @@ -40,7 +40,6 @@ dependencies { api(project(":radar-commons-server")) api(project(":radar-commons-kotlin")) - api("org.apache.avro:avro:${Versions.avro}") api("org.radarbase:radar-schemas-commons:${Versions.radarSchemas}") implementation("com.opencsv:opencsv:${Versions.opencsv}") @@ -50,7 +49,10 @@ dependencies { implementation("org.apache.kafka:kafka-clients:${Versions.kafka}") { implementation("org.xerial.snappy:snappy-java:${Versions.snappy}") } - implementation("io.confluent:kafka-avro-serializer:${Versions.confluent}") + + implementation("io.confluent:kafka-avro-serializer:${Versions.confluent}") { + runtimeOnly("com.google.guava:guava:${Versions.guava}") + } api("org.apache.avro:avro:${Versions.avro}") { implementation("org.apache.commons:commons-compress:${Versions.commonsCompress}") From c21f0b01df0b4d182463ebe47b8ddfd77afca066 Mon Sep 17 00:00:00 2001 From: Bastiaan Date: Thu, 7 Mar 2024 14:17:34 +0100 Subject: [PATCH 3/4] manually match radar-commons-gradle to Versions.kt --- buildSrc/src/main/kotlin/Versions.kt | 8 +++- radar-commons-gradle/build.gradle.kts | 57 +++++++++++++++++++++++---- 2 files changed, 55 insertions(+), 10 deletions(-) diff --git a/buildSrc/src/main/kotlin/Versions.kt b/buildSrc/src/main/kotlin/Versions.kt index 89c56a51..652d0492 100644 --- a/buildSrc/src/main/kotlin/Versions.kt +++ b/buildSrc/src/main/kotlin/Versions.kt @@ -3,14 +3,16 @@ object Versions { const val project = "1.1.2-SNAPSHOT" object Plugins { - const val kotlin = "1.9.10" + const val licenseReport = "2.5" + const val kotlin = "1.9.21" const val kotlinSerialization = kotlin const val kotlinAllOpen = kotlin const val avro = "1.8.0" const val gradle = "8.3" + const val publishPlugin = "2.0.0-rc-1" } - const val java = 11 + const val java = 17 const val slf4j = "2.0.9" const val confluent = "7.5.0" const val kafka = "7.5.0-ce" @@ -28,4 +30,6 @@ object Versions { const val commonsCompress = "1.24.0" const val snappy = "1.1.10.5" const val guava = "32.1.1-jre" + const val gradleVersionsPlugin = "0.50.0" + const val ktlint = "12.0.3" } diff --git a/radar-commons-gradle/build.gradle.kts b/radar-commons-gradle/build.gradle.kts index 88bb4611..0b5d92d7 100644 --- a/radar-commons-gradle/build.gradle.kts +++ b/radar-commons-gradle/build.gradle.kts @@ -23,12 +23,12 @@ repositories { } dependencies { - implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.21") - implementation("org.jetbrains.dokka:dokka-gradle-plugin:1.9.10") - implementation("com.github.ben-manes:gradle-versions-plugin:0.50.0") - implementation("io.github.gradle-nexus:publish-plugin:2.0.0-rc-1") - implementation("org.jlleitschuh.gradle:ktlint-gradle:12.0.3") - implementation("com.github.jk1.dependency-license-report:com.github.jk1.dependency-license-report.gradle.plugin:2.5") + implementation("org.jetbrains.kotlin:kotlin-gradle-plugin:${Versions.Plugins.kotlin}") + implementation("org.jetbrains.dokka:dokka-gradle-plugin:${Versions.Plugins.dokka}") + implementation("com.github.ben-manes:gradle-versions-plugin:${Versions.gradleVersionsPlugin}") + implementation("io.github.gradle-nexus:publish-plugin:${Versions.Plugins.publishPlugin}") + implementation("org.jlleitschuh.gradle:ktlint-gradle:${Versions.ktlint}") + implementation("com.github.jk1.dependency-license-report:com.github.jk1.dependency-license-report.gradle.plugin:${Versions.Plugins.licenseReport}") } gradlePlugin { @@ -53,11 +53,12 @@ gradlePlugin { } tasks.withType { - options.release.set(11) + options.release.set(Versions.java) } + tasks.withType { compilerOptions { - jvmTarget.set(JvmTarget.JVM_11) + jvmTarget.set(JvmTarget.JVM_17) languageVersion.set(org.jetbrains.kotlin.gradle.dsl.KotlinVersion.KOTLIN_1_9) apiVersion.set(org.jetbrains.kotlin.gradle.dsl.KotlinVersion.KOTLIN_1_9) } @@ -169,3 +170,43 @@ tasks.withType { tasks.withType { dependsOn(tasks.withType()) } + +// Because this project is where all the required plugins get built, we need to add the dependencies separately here. +// They should be copied from the Versions.kt file directly to maintain consistency. +@Suppress("ConstPropertyName", "MemberVisibilityCanBePrivate") +object Versions { + const val project = "1.1.2-SNAPSHOT" + + object Plugins { + const val licenseReport = "2.5" + const val kotlin = "1.9.21" + const val dokka = "1.9.10" + const val kotlinSerialization = kotlin + const val kotlinAllOpen = kotlin + const val avro = "1.8.0" + const val gradle = "8.3" + const val publishPlugin = "2.0.0-rc-1" + } + + const val java = 17 + const val slf4j = "2.0.9" + const val confluent = "7.5.0" + const val kafka = "7.5.0-ce" + const val avro = "1.11.3" + const val jackson = "2.15.2" + const val okhttp = "4.11.0" + const val junit = "5.10.0" + const val mockito = "5.5.0" + const val mockitoKotlin = "5.1.0" + const val hamcrest = "2.2" + const val radarSchemas = "0.8.4" + const val opencsv = "5.8" + const val ktor = "2.3.4" + const val coroutines = "1.7.3" + const val commonsCompress = "1.24.0" + const val snappy = "1.1.10.5" + const val guava = "32.1.1-jre" + const val gradleVersionsPlugin = "0.50.0" + const val ktlint = "12.0.3" +} + From 57888eea5582113c5d87561c1dc4a428a92391a8 Mon Sep 17 00:00:00 2001 From: Bastiaan Date: Thu, 7 Mar 2024 14:50:38 +0100 Subject: [PATCH 4/4] explicitly assign all dependency versions --- buildSrc/build.gradle.kts | 1 - buildSrc/src/main/kotlin/Versions.kt | 1 + radar-commons-gradle/build.gradle.kts | 1 + radar-commons-kotlin/build.gradle.kts | 8 ++++---- radar-commons-server/build.gradle.kts | 5 ++--- radar-commons-testing/build.gradle.kts | 4 ++-- radar-commons/build.gradle.kts | 10 +++++----- 7 files changed, 15 insertions(+), 15 deletions(-) diff --git a/buildSrc/build.gradle.kts b/buildSrc/build.gradle.kts index 5013cfcb..d4f14b3d 100644 --- a/buildSrc/build.gradle.kts +++ b/buildSrc/build.gradle.kts @@ -9,7 +9,6 @@ repositories { mavenCentral() } - tasks.withType { sourceCompatibility = "17" targetCompatibility = "17" diff --git a/buildSrc/src/main/kotlin/Versions.kt b/buildSrc/src/main/kotlin/Versions.kt index 652d0492..016e5e5d 100644 --- a/buildSrc/src/main/kotlin/Versions.kt +++ b/buildSrc/src/main/kotlin/Versions.kt @@ -5,6 +5,7 @@ object Versions { object Plugins { const val licenseReport = "2.5" const val kotlin = "1.9.21" + const val dokka = "1.9.10" const val kotlinSerialization = kotlin const val kotlinAllOpen = kotlin const val avro = "1.8.0" diff --git a/radar-commons-gradle/build.gradle.kts b/radar-commons-gradle/build.gradle.kts index 0b5d92d7..13a5be68 100644 --- a/radar-commons-gradle/build.gradle.kts +++ b/radar-commons-gradle/build.gradle.kts @@ -4,6 +4,7 @@ import org.jetbrains.kotlin.gradle.tasks.KotlinCompile plugins { `kotlin-dsl` `java-gradle-plugin` + // Match to the versions in the bottom of this file kotlin("jvm") version "1.9.21" `maven-publish` id("io.github.gradle-nexus.publish-plugin") version "2.0.0-rc-1" diff --git a/radar-commons-kotlin/build.gradle.kts b/radar-commons-kotlin/build.gradle.kts index a288b7cc..0ef365a0 100644 --- a/radar-commons-kotlin/build.gradle.kts +++ b/radar-commons-kotlin/build.gradle.kts @@ -6,12 +6,12 @@ description = "Library for Kotlin utility classes and functions" dependencies { api(platform("org.jetbrains.kotlinx:kotlinx-coroutines-bom:${Versions.coroutines}")) - api("org.jetbrains.kotlinx:kotlinx-coroutines-core") + api("org.jetbrains.kotlinx:kotlinx-coroutines-core:${Versions.coroutines}") api(platform("io.ktor:ktor-bom:${Versions.ktor}")) - api("io.ktor:ktor-client-auth") - implementation("io.ktor:ktor-client-content-negotiation") - implementation("io.ktor:ktor-serialization-kotlinx-json") + api("io.ktor:ktor-client-auth:${Versions.ktor}") + implementation("io.ktor:ktor-client-content-negotiation:${Versions.ktor}") + implementation("io.ktor:ktor-serialization-kotlinx-json:${Versions.ktor}") testImplementation("org.hamcrest:hamcrest:${Versions.hamcrest}") } diff --git a/radar-commons-server/build.gradle.kts b/radar-commons-server/build.gradle.kts index 6abb2a41..05ef72b0 100644 --- a/radar-commons-server/build.gradle.kts +++ b/radar-commons-server/build.gradle.kts @@ -36,9 +36,8 @@ dependencies { // For POJO classes and ConfigLoader implementation(platform("com.fasterxml.jackson:jackson-bom:${Versions.jackson}")) - implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml") - implementation("com.fasterxml.jackson.core:jackson-databind") - + implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:${Versions.jackson}") + implementation("com.fasterxml.jackson.core:jackson-databind:${Versions.jackson}") api("org.apache.avro:avro:${Versions.avro}") { implementation("org.apache.commons:commons-compress:${Versions.commonsCompress}") diff --git a/radar-commons-testing/build.gradle.kts b/radar-commons-testing/build.gradle.kts index f7a5ffad..5f64e645 100644 --- a/radar-commons-testing/build.gradle.kts +++ b/radar-commons-testing/build.gradle.kts @@ -44,7 +44,7 @@ dependencies { implementation("com.opencsv:opencsv:${Versions.opencsv}") implementation(platform("com.fasterxml.jackson:jackson-bom:${Versions.jackson}")) - implementation("com.fasterxml.jackson.core:jackson-databind") + implementation("com.fasterxml.jackson.core:jackson-databind:${Versions.jackson}") implementation("org.apache.kafka:kafka-clients:${Versions.kafka}") { implementation("org.xerial.snappy:snappy-java:${Versions.snappy}") @@ -59,7 +59,7 @@ dependencies { } implementation(platform("io.ktor:ktor-bom:${Versions.ktor}")) - implementation("io.ktor:ktor-serialization-kotlinx-json") + implementation("io.ktor:ktor-serialization-kotlinx-json:${Versions.ktor}") applicationRuntimeOnly("org.slf4j:slf4j-simple:${Versions.slf4j}") diff --git a/radar-commons/build.gradle.kts b/radar-commons/build.gradle.kts index da61630e..b5a55811 100644 --- a/radar-commons/build.gradle.kts +++ b/radar-commons/build.gradle.kts @@ -24,11 +24,11 @@ dependencies { implementation(project(":radar-commons-kotlin")) api(platform("io.ktor:ktor-bom:${Versions.ktor}")) - api("io.ktor:ktor-client-core") - api("io.ktor:ktor-client-cio") - api("io.ktor:ktor-client-auth") - implementation("io.ktor:ktor-client-content-negotiation") - implementation("io.ktor:ktor-serialization-kotlinx-json") + api("io.ktor:ktor-client-core:${Versions.ktor}") + api("io.ktor:ktor-client-cio:${Versions.ktor}") + api("io.ktor:ktor-client-auth:${Versions.ktor}") + implementation("io.ktor:ktor-client-content-negotiation:${Versions.ktor}") + implementation("io.ktor:ktor-serialization-kotlinx-json:${Versions.ktor}") api("org.jetbrains.kotlinx:kotlinx-coroutines-core:${Versions.coroutines}")