From 53c1d9ac3343ab7fc4df418a685a317450818b9d Mon Sep 17 00:00:00 2001 From: James Daugherty Date: Sat, 21 Dec 2024 14:40:15 -0500 Subject: [PATCH 1/2] Fix grails-bom being overridden in json-testing-support, remove older gradle docs plugin, & remove unused build src libraries --- build.gradle | 13 ++++++++++++- buildSrc/build.gradle | 3 --- core/build.gradle | 1 - gradle-plugin/build.gradle | 1 - gradle/buildsrc.libs.versions.toml | 2 +- gradle/dependency-updates.gradle | 11 ----------- json-testing-support/build.gradle | 20 +++++++++++++++----- 7 files changed, 28 insertions(+), 23 deletions(-) delete mode 100644 gradle/dependency-updates.gradle diff --git a/build.gradle b/build.gradle index b7d5f6496..8b4bece5d 100644 --- a/build.gradle +++ b/build.gradle @@ -106,4 +106,15 @@ tasks.withType(InitializeNexusStagingRepository).configureEach { shouldRunAfter = tasks.withType(Sign) } -apply from: rootProject.layout.projectDirectory.file('gradle/dependency-updates.gradle') +subprojects { + apply plugin: 'groovy' + + dependencies { + implementation platform(libs.grails.bom), { + exclude group: 'org.grails.plugins', module: 'views-gradle' + exclude group: 'org.grails.plugins', module: 'views-json' + exclude group: 'org.grails', module: 'views-core' + exclude group: 'org.grails', module: 'views-json-testing-support' + } + } +} \ No newline at end of file diff --git a/buildSrc/build.gradle b/buildSrc/build.gradle index 31cf8e37f..7614b1611 100644 --- a/buildSrc/build.gradle +++ b/buildSrc/build.gradle @@ -26,7 +26,4 @@ dependencies { runtimeOnly buildsrcLibs.nexus.publish.gradle.plugin runtimeOnly buildsrcLibs.grails.gradle.plugin runtimeOnly buildsrcLibs.grails.views.gradle.plugin - runtimeOnly buildsrcLibs.groovydoc.gradle.plugin } - -apply from: rootProject.layout.projectDirectory.file('../gradle/dependency-updates.gradle') diff --git a/core/build.gradle b/core/build.gradle index c606a804e..b8c0e998f 100644 --- a/core/build.gradle +++ b/core/build.gradle @@ -10,7 +10,6 @@ ext.set('projectDesc', 'Grails Views Core') dependencies { - api platform(libs.grails.bom) api libs.caffeine // Used in public API api libs.grails.datastore.core // MappingContext is used in public API api libs.grails.mimetypes // MimeUtility is used in public API diff --git a/gradle-plugin/build.gradle b/gradle-plugin/build.gradle index eefb00e38..64a9cadaf 100644 --- a/gradle-plugin/build.gradle +++ b/gradle-plugin/build.gradle @@ -12,7 +12,6 @@ dependencies { // the gradle api is provided by java-gradle-plugin - implementation platform(libs.grails.bom) implementation libs.jakarta.annotation.api compileOnly libs.groovy.core // @CompileStatic diff --git a/gradle/buildsrc.libs.versions.toml b/gradle/buildsrc.libs.versions.toml index 9394d2d23..57a4e8c80 100644 --- a/gradle/buildsrc.libs.versions.toml +++ b/gradle/buildsrc.libs.versions.toml @@ -1,6 +1,6 @@ [versions] asciidoctor-gradle-jvm = '4.0.3' -grails-gradle-plugin = '7.0.0-M2' +grails-gradle-plugin = '7.0.0-SNAPSHOT' grails-views = '4.0.0-SNAPSHOT' groovy-doc = '1.0.1' nexus-publish-gradle-plugin = '1.3.0' diff --git a/gradle/dependency-updates.gradle b/gradle/dependency-updates.gradle deleted file mode 100644 index 784d8cdbc..000000000 --- a/gradle/dependency-updates.gradle +++ /dev/null @@ -1,11 +0,0 @@ -def groovyVersion = project.rootProject - .extensions - .getByType(VersionCatalogsExtension.class) - .named("libs") - .findVersion("groovy") - .get() - .displayName - -dependencies { - implementation(platform(libs.grails.bom)) -} \ No newline at end of file diff --git a/json-testing-support/build.gradle b/json-testing-support/build.gradle index 7feeea438..aad5ed915 100644 --- a/json-testing-support/build.gradle +++ b/json-testing-support/build.gradle @@ -10,14 +10,24 @@ ext.set('projectDesc', 'JSON Views Testing Support') dependencies { - api project(':views-json') // Used in public API + api project(':views-json'), { // Used in public API + exclude group: 'org.grails', module: 'grails-bom' + } api libs.spring.web // Used in public API - api libs.grails.datastore.core // Used in public API + api libs.grails.datastore.core, { // Used in public API + exclude group: 'org.grails', module: 'grails-bom' + } api libs.spock.core // Used in public API - implementation libs.grails.core - implementation libs.grails.testing.support.core - implementation libs.grails.web.urlmappings + implementation libs.grails.core, { + exclude group: 'org.grails', module: 'grails-bom' + } + implementation libs.grails.testing.support.core, { + exclude group: 'org.grails', module: 'grails-bom' + } + implementation libs.grails.web.urlmappings, { + exclude group: 'org.grails', module: 'grails-bom' + } implementation libs.groovy.core implementation libs.groovy.json implementation libs.groovy.templates From e802d16e9c4c219faee4e4406ac39a31af85a321 Mon Sep 17 00:00:00 2001 From: James Daugherty Date: Sat, 21 Dec 2024 14:44:42 -0500 Subject: [PATCH 2/2] Add comment for why grails-bom must be excluded --- json-testing-support/build.gradle | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/json-testing-support/build.gradle b/json-testing-support/build.gradle index aad5ed915..b5caa5585 100644 --- a/json-testing-support/build.gradle +++ b/json-testing-support/build.gradle @@ -10,6 +10,10 @@ ext.set('projectDesc', 'JSON Views Testing Support') dependencies { + // Note: the bom has to be excluded on grails dependencies otherwise it will be detected as snapshot + // (even though none of these projects have a version that is snapshot). + // This behavior is only seen on a non-buildsnapshot project version. + api project(':views-json'), { // Used in public API exclude group: 'org.grails', module: 'grails-bom' }