From 2915d48295d711715ca2e10b3a523f4c2fdfc6c7 Mon Sep 17 00:00:00 2001 From: Puneet Behl Date: Mon, 21 Mar 2022 11:37:45 +0530 Subject: [PATCH 1/6] Use the pre-installed Chrome driver when running on GitHub The GitHub virtual environment already provides a Chrome and a matching Chrome driver. For installed software see: https://github.com/actions/virtual-environments/blob/ubuntu20/20220207.1/images/linux/Ubuntu2004-Readme.md#environment-variables-1 For available environment variables see: https://docs.github.com/en/actions/learn-github-actions/environment-variables Thanks to @darxriggs for suggesting the same in grails/grails-cache#123 plugin. --- gradle/geb.gradle | 13 +++++++++++-- micronaut/build.gradle | 15 +++++++++++---- 2 files changed, 22 insertions(+), 6 deletions(-) diff --git a/gradle/geb.gradle b/gradle/geb.gradle index 0b116ce1..e96b7481 100644 --- a/gradle/geb.gradle +++ b/gradle/geb.gradle @@ -16,9 +16,18 @@ dependencies { tasks.withType(Test) { systemProperty "geb.env", System.getProperty('geb.env') systemProperty "geb.build.reportsDir", reporting.file("geb/integrationTest") + if (!System.getenv().containsKey('CI')) { + systemProperty 'webdriver.chrome.driver', System.getProperty('webdriver.chrome.driver') + systemProperty 'webdriver.gecko.driver', System.getProperty('webdriver.gecko.driver') + } else { + systemProperty 'webdriver.chrome.driver', "${System.getenv('CHROMEWEBDRIVER')}/chromedriver" + systemProperty 'webdriver.gecko.driver', "${System.getenv('GECKOWEBDRIVER')}/geckodriver" + } } webdriverBinaries { - chromedriver "$chromeDriverVersion" - geckodriver "$geckodriverVersion" + if (!System.getenv().containsKey('CI')) { + chromedriver "$chromeDriverVersion" + geckodriver "$geckodriverVersion" + } } diff --git a/micronaut/build.gradle b/micronaut/build.gradle index 7e5d608d..03f4b5e6 100644 --- a/micronaut/build.gradle +++ b/micronaut/build.gradle @@ -85,15 +85,22 @@ bootRun { } webdriverBinaries { - chromedriver '2.45.0' - geckodriver '0.24.0' + if (!System.getenv().containsKey('CI')) { + chromedriver "$chromeDriverVersion" + geckodriver "$geckodriverVersion" + } } tasks.withType(Test) { systemProperty "geb.env", System.getProperty('geb.env') systemProperty "geb.build.reportsDir", reporting.file("geb/integrationTest") - systemProperty "webdriver.chrome.driver", System.getProperty('webdriver.chrome.driver') - systemProperty "webdriver.gecko.driver", System.getProperty('webdriver.gecko.driver') + if (!System.getenv().containsKey('CI')) { + systemProperty 'webdriver.chrome.driver', System.getProperty('webdriver.chrome.driver') + systemProperty 'webdriver.gecko.driver', System.getProperty('webdriver.gecko.driver') + } else { + systemProperty 'webdriver.chrome.driver', "${System.getenv('CHROMEWEBDRIVER')}/chromedriver" + systemProperty 'webdriver.gecko.driver', "${System.getenv('GECKOWEBDRIVER')}/geckodriver" + } } From eea445e90bd1c0d107d7d101bf7dc3a4e150e44d Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 14 Apr 2022 14:31:40 +0530 Subject: [PATCH 2/6] Update dependency org.hibernate:hibernate-core to v5.6.5.Final (#101) Co-authored-by: Renovate Bot --- micronaut/build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/micronaut/build.gradle b/micronaut/build.gradle index 03f4b5e6..8d8fd6ad 100644 --- a/micronaut/build.gradle +++ b/micronaut/build.gradle @@ -52,7 +52,7 @@ dependencies { implementation "org.grails.plugins:scaffolding" implementation "org.grails.plugins:events" implementation "org.grails.plugins:hibernate5" - implementation "org.hibernate:hibernate-core:5.6.3.Final" + implementation "org.hibernate:hibernate-core:5.6.5.Final" implementation "org.grails.plugins:gsp" compileOnly "io.micronaut:micronaut-inject-groovy" console "org.grails:grails-console" From ed1e586ec16caa340b93ce8656bbd344e089c1aa Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 1 May 2022 10:59:37 +0530 Subject: [PATCH 3/6] Update dependency org.grails:grails-gradle-plugin to v5.1.4 (#102) * Use the pre-installed Chrome driver when running on GitHub (#106) The GitHub virtual environment already provides a Chrome and a matching Chrome driver. For installed software see: https://github.com/actions/virtual-environments/blob/ubuntu20/20220207.1/images/linux/Ubuntu2004-Readme.md#environment-variables-1 For available environment variables see: https://docs.github.com/en/actions/learn-github-actions/environment-variables Thanks to @darxriggs for suggesting the same in grails/grails-cache#123 plugin. * Update dependency org.grails:grails-gradle-plugin to v5.1.4 Co-authored-by: Puneet Behl Co-authored-by: Renovate Bot --- gradle.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gradle.properties b/gradle.properties index 317b4fdd..132824de 100644 --- a/gradle.properties +++ b/gradle.properties @@ -12,7 +12,7 @@ viewsVersion=2.2.0 micronautVersion=3.2.6 servletApiVersion=4.0.1 springSecurityCoreVersion=4.0.4 -grailsGradlePluginVersion=5.1.1 +grailsGradlePluginVersion=5.1.4 groovyVersion=3.0.9 org.gradle.caching=true From b84ce181539fc22a3910f15474948bb697e1e2af Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sun, 1 May 2022 11:00:08 +0530 Subject: [PATCH 4/6] Update plugin com.gradle.common-custom-user-data-gradle-plugin to v1.6.5 (#105) * Use the pre-installed Chrome driver when running on GitHub (#106) The GitHub virtual environment already provides a Chrome and a matching Chrome driver. For installed software see: https://github.com/actions/virtual-environments/blob/ubuntu20/20220207.1/images/linux/Ubuntu2004-Readme.md#environment-variables-1 For available environment variables see: https://docs.github.com/en/actions/learn-github-actions/environment-variables Thanks to @darxriggs for suggesting the same in grails/grails-cache#123 plugin. * Update plugin com.gradle.common-custom-user-data-gradle-plugin to v1.6.5 Co-authored-by: Puneet Behl Co-authored-by: Renovate Bot --- settings.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/settings.gradle b/settings.gradle index e6e12c5b..8e2bac60 100644 --- a/settings.gradle +++ b/settings.gradle @@ -1,6 +1,6 @@ plugins { id "com.gradle.enterprise" version "3.8.1" - id 'com.gradle.common-custom-user-data-gradle-plugin' version '1.6.2' + id 'com.gradle.common-custom-user-data-gradle-plugin' version '1.6.5' } gradleEnterprise { From 08a44d18ebc8e17bc180ef849e7a0792b44719b3 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 16 Jun 2022 12:43:32 +0530 Subject: [PATCH 5/6] Update assetPipelineVersion to v3.4.6 (#64) * Use the pre-installed Chrome driver when running on GitHub (#106) The GitHub virtual environment already provides a Chrome and a matching Chrome driver. For installed software see: https://github.com/actions/virtual-environments/blob/ubuntu20/20220207.1/images/linux/Ubuntu2004-Readme.md#environment-variables-1 For available environment variables see: https://docs.github.com/en/actions/learn-github-actions/environment-variables Thanks to @darxriggs for suggesting the same in grails/grails-cache#123 plugin. * Update assetPipelineVersion to v3.4.6 * Remove asset-pipeline plugin from uneccessary projects. Co-authored-by: Puneet Behl Co-authored-by: Renovate Bot --- gradle.properties | 2 +- plugins/issue11005/build.gradle | 2 -- plugins/loadafter/build.gradle | 3 --- plugins/loadfirst/build.gradle | 2 -- plugins/loadsecond/build.gradle | 2 -- 5 files changed, 1 insertion(+), 10 deletions(-) diff --git a/gradle.properties b/gradle.properties index 132824de..8d8befa9 100644 --- a/gradle.properties +++ b/gradle.properties @@ -7,7 +7,7 @@ geckodriverVersion=0.24.0 seleniumSafariDriverVersion=3.141.59 scaffoldingVersion=4.0.0 fieldsVersion=3.0.0.RC1 -assetPipelineVersion=3.3.3 +assetPipelineVersion=3.4.6 viewsVersion=2.2.0 micronautVersion=3.2.6 servletApiVersion=4.0.1 diff --git a/plugins/issue11005/build.gradle b/plugins/issue11005/build.gradle index 50db4f03..224ff122 100644 --- a/plugins/issue11005/build.gradle +++ b/plugins/issue11005/build.gradle @@ -4,12 +4,10 @@ buildscript { } dependencies { classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" - classpath "com.bertramlabs.plugins:asset-pipeline-gradle:$assetPipelineVersion" } } apply plugin: "java-library" -apply plugin: "asset-pipeline" apply plugin: "org.grails.grails-plugin" apply plugin: "org.grails.grails-gsp" apply plugin: 'maven-publish' diff --git a/plugins/loadafter/build.gradle b/plugins/loadafter/build.gradle index 14ac989a..78578033 100755 --- a/plugins/loadafter/build.gradle +++ b/plugins/loadafter/build.gradle @@ -4,12 +4,10 @@ buildscript { } dependencies { classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" - classpath "com.bertramlabs.plugins:asset-pipeline-gradle:$assetPipelineVersion" } } apply plugin: "java-library" -apply plugin: "asset-pipeline" apply plugin: "org.grails.grails-plugin" apply plugin: "org.grails.grails-gsp" apply plugin: 'maven-publish' @@ -39,7 +37,6 @@ dependencies { api "org.grails:grails-dependencies" api "javax.servlet:javax.servlet-api:$servletApiVersion" - //testCompile "org.grails:grails-plugin-testing" implementation "org.grails.plugins:spring-security-core:$springSecurityCoreVersion" console "org.grails:grails-console" diff --git a/plugins/loadfirst/build.gradle b/plugins/loadfirst/build.gradle index 5abf5f01..c292ed06 100644 --- a/plugins/loadfirst/build.gradle +++ b/plugins/loadfirst/build.gradle @@ -4,12 +4,10 @@ buildscript { } dependencies { classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" - classpath "com.bertramlabs.plugins:asset-pipeline-gradle:$assetPipelineVersion" } } apply plugin: "java-library" -apply plugin: "asset-pipeline" apply plugin: "org.grails.grails-plugin" apply plugin: "org.grails.grails-gsp" apply plugin: 'maven-publish' diff --git a/plugins/loadsecond/build.gradle b/plugins/loadsecond/build.gradle index 97fc78f9..aaebdea0 100644 --- a/plugins/loadsecond/build.gradle +++ b/plugins/loadsecond/build.gradle @@ -4,12 +4,10 @@ buildscript { } dependencies { classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" - classpath "com.bertramlabs.plugins:asset-pipeline-gradle:$assetPipelineVersion" } } apply plugin: "java-library" -apply plugin: "asset-pipeline" apply plugin: "org.grails.grails-plugin" apply plugin: "org.grails.grails-gsp" apply plugin: 'maven-publish' From 85e7d812be5cffde5f849f719cad4b35fe5a9443 Mon Sep 17 00:00:00 2001 From: Mattias Reichel Date: Thu, 7 Mar 2024 14:06:07 +0100 Subject: [PATCH 6/6] test: Add functional test for grails-core#11767 (#208) Related to https://github.com/grails/grails-core/issues/11767 --- issue-11767/build.gradle | 50 +++++++++++++++++++ issue-11767/grails-app/conf/application.yml | 43 ++++++++++++++++ issue-11767/grails-app/conf/logback.xml | 21 ++++++++ .../issue11767/app/AppController.groovy | 32 ++++++++++++ .../issue11767/app/UrlMappings.groovy | 11 ++++ .../init/issue11767/app/Application.groovy | 12 +++++ .../issue11767/app/ConfigLoadingSpec.groovy | 42 ++++++++++++++++ .../app/AppGroovyMicronautBean.groovy | 9 ++++ plugins/issue-11767-plugin/build.gradle | 35 +++++++++++++ .../grails-app/conf/plugin.yml | 3 ++ .../init/issue11767/plugin/Application.groovy | 16 ++++++ .../plugin/MyPluginGrailsPlugin.groovy | 15 ++++++ .../plugin/PluginGroovyMicronautBean.groovy | 11 ++++ .../plugin/PluginGroovySpringBean.groovy | 13 +++++ .../plugin/PluginJavaMicronautBean.java | 26 ++++++++++ settings.gradle | 4 ++ 16 files changed, 343 insertions(+) create mode 100644 issue-11767/build.gradle create mode 100644 issue-11767/grails-app/conf/application.yml create mode 100644 issue-11767/grails-app/conf/logback.xml create mode 100644 issue-11767/grails-app/controllers/issue11767/app/AppController.groovy create mode 100644 issue-11767/grails-app/controllers/issue11767/app/UrlMappings.groovy create mode 100644 issue-11767/grails-app/init/issue11767/app/Application.groovy create mode 100644 issue-11767/src/integration-test/groovy/issue11767/app/ConfigLoadingSpec.groovy create mode 100644 issue-11767/src/main/groovy/issue11767/app/AppGroovyMicronautBean.groovy create mode 100644 plugins/issue-11767-plugin/build.gradle create mode 100644 plugins/issue-11767-plugin/grails-app/conf/plugin.yml create mode 100644 plugins/issue-11767-plugin/grails-app/init/issue11767/plugin/Application.groovy create mode 100644 plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/MyPluginGrailsPlugin.groovy create mode 100644 plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovyMicronautBean.groovy create mode 100644 plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovySpringBean.groovy create mode 100644 plugins/issue-11767-plugin/src/main/java/issue11767/plugin/PluginJavaMicronautBean.java diff --git a/issue-11767/build.gradle b/issue-11767/build.gradle new file mode 100644 index 00000000..b4e5297c --- /dev/null +++ b/issue-11767/build.gradle @@ -0,0 +1,50 @@ +buildscript { + repositories { + maven { url = 'https://repo.grails.org/grails/core' } + } + dependencies { + classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" + } +} + +group = 'issue11767.app' + +apply plugin: 'application' +apply plugin: 'groovy' +apply plugin: 'org.grails.grails-web' + +repositories { + mavenCentral() + maven { url = 'https://repo.grails.org/grails/core' } +} + +dependencyManagement { + imports { mavenBom "org.grails:grails-bom:$grailsVersion" } + applyMavenExclusions false +} + +dependencies { + + implementation project(':issue-11767-plugin') + + implementation 'org.grails:grails-core' + implementation 'org.grails:grails-logging' + implementation 'org.grails:grails-plugin-url-mappings' + implementation 'org.springframework.boot:spring-boot-starter-tomcat' + + compileOnly 'io.micronaut:micronaut-inject-groovy' + + testImplementation 'io.micronaut:micronaut-http-client' + testImplementation 'io.micronaut:micronaut-inject-groovy' + testImplementation 'org.grails:grails-web-testing-support' + testImplementation 'org.spockframework:spock-core' + +} + +application { + mainClass = 'issue11767.Application' +} + +java { + sourceCompatibility = JavaVersion.VERSION_11 +} \ No newline at end of file diff --git a/issue-11767/grails-app/conf/application.yml b/issue-11767/grails-app/conf/application.yml new file mode 100644 index 00000000..66b746d8 --- /dev/null +++ b/issue-11767/grails-app/conf/application.yml @@ -0,0 +1,43 @@ +my: + value1: 'this is value 1 from application.yml' + +--- + +info: + app: + name: '@info.app.name@' + version: '@info.app.version@' + grailsVersion: '@info.app.grailsVersion@' +grails: + mime: + disable: + accept: + header: + userAgents: + - Gecko + - WebKit + - Presto + - Trident + types: + all: '*/*' + atom: application/atom+xml + css: text/css + csv: text/csv + form: application/x-www-form-urlencoded + html: + - text/html + - application/xhtml+xml + js: text/javascript + json: + - application/json + - text/json + multipartForm: multipart/form-data + pdf: application/pdf + rss: application/rss+xml + text: text/plain + hal: + - application/hal+json + - application/hal+xml + xml: + - text/xml + - application/xml \ No newline at end of file diff --git a/issue-11767/grails-app/conf/logback.xml b/issue-11767/grails-app/conf/logback.xml new file mode 100644 index 00000000..b7d4957e --- /dev/null +++ b/issue-11767/grails-app/conf/logback.xml @@ -0,0 +1,21 @@ + + + + + + + + true + + UTF-8 + %clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wex + + + + + + + + + + diff --git a/issue-11767/grails-app/controllers/issue11767/app/AppController.groovy b/issue-11767/grails-app/controllers/issue11767/app/AppController.groovy new file mode 100644 index 00000000..e943bbad --- /dev/null +++ b/issue-11767/grails-app/controllers/issue11767/app/AppController.groovy @@ -0,0 +1,32 @@ +package issue11767.app + +import issue11767.plugin.PluginGroovyMicronautBean +import issue11767.plugin.PluginGroovySpringBean +import issue11767.plugin.PluginJavaMicronautBean +import org.springframework.beans.factory.annotation.Autowired + +class AppController { + + PluginGroovySpringBean pluginGroovySpringBean + @Autowired PluginGroovyMicronautBean pluginGroovyMicronautConfigBean + @Autowired PluginJavaMicronautBean pluginJavaMicronautConfigBean + @Autowired AppGroovyMicronautBean appGroovyMicronautConfigBean + + def index() { + render """ +
+                Plugin Groovy Spring Bean - my.value1: ${pluginGroovySpringBean.value1}
+                Plugin Groovy Spring Bean - my.value2: ${pluginGroovySpringBean.value2}
+                
+ Plugin Groovy Micronaut Bean - my.value1: ${pluginGroovyMicronautConfigBean.value1} + Plugin Groovy Micronaut Bean - my.value2: ${pluginGroovyMicronautConfigBean.value2} +
+ Plugin Java Micronaut Bean - my.value1: ${pluginJavaMicronautConfigBean.value1} + Plugin Java Micronaut Bean - my.value2: ${pluginJavaMicronautConfigBean.value2} +
+ App Groovy Micronaut Bean - my.value1: ${appGroovyMicronautConfigBean.value1} + App Groovy Micronaut Bean - my.value2: ${appGroovyMicronautConfigBean.value2} +
+ """.stripIndent() + } +} \ No newline at end of file diff --git a/issue-11767/grails-app/controllers/issue11767/app/UrlMappings.groovy b/issue-11767/grails-app/controllers/issue11767/app/UrlMappings.groovy new file mode 100644 index 00000000..c36a5e95 --- /dev/null +++ b/issue-11767/grails-app/controllers/issue11767/app/UrlMappings.groovy @@ -0,0 +1,11 @@ +package issue11767.app + +class UrlMappings { + static mappings = { + "/$controller/$action?/$id?(.$format)?"{ + constraints { + // apply constraints here + } + } + } +} diff --git a/issue-11767/grails-app/init/issue11767/app/Application.groovy b/issue-11767/grails-app/init/issue11767/app/Application.groovy new file mode 100644 index 00000000..90602cd3 --- /dev/null +++ b/issue-11767/grails-app/init/issue11767/app/Application.groovy @@ -0,0 +1,12 @@ +package issue11767.app + +import grails.boot.GrailsApp +import grails.boot.config.GrailsAutoConfiguration +import groovy.transform.CompileStatic + +@CompileStatic +class Application extends GrailsAutoConfiguration { + static void main(String[] args) { + GrailsApp.run(Application, args) + } +} diff --git a/issue-11767/src/integration-test/groovy/issue11767/app/ConfigLoadingSpec.groovy b/issue-11767/src/integration-test/groovy/issue11767/app/ConfigLoadingSpec.groovy new file mode 100644 index 00000000..0403e3e9 --- /dev/null +++ b/issue-11767/src/integration-test/groovy/issue11767/app/ConfigLoadingSpec.groovy @@ -0,0 +1,42 @@ +package issue11767.app + +import grails.testing.mixin.integration.Integration +import grails.testing.spock.OnceBefore +import io.micronaut.http.HttpRequest +import io.micronaut.http.client.HttpClient +import spock.lang.AutoCleanup +import spock.lang.Shared +import spock.lang.Specification +import spock.lang.Unroll + +@Integration +class ConfigLoadingSpec extends Specification { + + @Shared + @AutoCleanup + HttpClient httpClient + + @OnceBefore + void init() { + def baseUrl = "http://localhost:$serverPort" + httpClient = HttpClient.create(baseUrl.toURL()) + } + + @Unroll + void '#beanType beans can load plugin config values'(String beanType, String expectedResponseValue) { + + when: 'The app controller is visited' + def request = HttpRequest.GET('/app') + String response = httpClient.toBlocking().retrieve(request, String) + + then: 'The value from the plugin is found' + response.contains(expectedResponseValue) + + where: + beanType || expectedResponseValue + 'Plugin Groovy Spring' || 'Plugin Groovy Spring Bean - my.value2: this is value 2 from plugin.yml' + 'Plugin Groovy Micronaut' || 'Plugin Groovy Micronaut Bean - my.value2: this is value 2 from plugin.yml' + 'Plugin Java Micronaut' || 'Plugin Java Micronaut Bean - my.value2: this is value 2 from plugin.yml' + 'App Groovy Micronaut' || 'App Groovy Micronaut Bean - my.value2: this is value 2 from plugin.yml' + } +} diff --git a/issue-11767/src/main/groovy/issue11767/app/AppGroovyMicronautBean.groovy b/issue-11767/src/main/groovy/issue11767/app/AppGroovyMicronautBean.groovy new file mode 100644 index 00000000..2d4a3785 --- /dev/null +++ b/issue-11767/src/main/groovy/issue11767/app/AppGroovyMicronautBean.groovy @@ -0,0 +1,9 @@ +package issue11767.app + +import io.micronaut.context.annotation.ConfigurationProperties + +@ConfigurationProperties('my') +class AppGroovyMicronautBean { + String value1 + String value2 +} diff --git a/plugins/issue-11767-plugin/build.gradle b/plugins/issue-11767-plugin/build.gradle new file mode 100644 index 00000000..c9c64284 --- /dev/null +++ b/plugins/issue-11767-plugin/build.gradle @@ -0,0 +1,35 @@ +buildscript { + repositories { + maven { url = 'https://repo.grails.org/grails/core' } + } + dependencies { + classpath "org.grails:grails-gradle-plugin:$grailsGradlePluginVersion" + } +} + +apply plugin: 'groovy' +apply plugin: 'org.grails.grails-plugin' + +group = 'issue11767.plugin' + +repositories { + mavenCentral() + maven { url = 'https://repo.grails.org/grails/core' } +} + +dependencyManagement { + imports { + mavenBom "org.grails:grails-bom:$grailsVersion" + } + applyMavenExclusions false +} + +dependencies { + annotationProcessor 'io.micronaut:micronaut-inject-java' + implementation 'org.grails:grails-core' + compileOnly 'io.micronaut:micronaut-inject-groovy' +} + +java { + sourceCompatibility = JavaVersion.VERSION_11 +} \ No newline at end of file diff --git a/plugins/issue-11767-plugin/grails-app/conf/plugin.yml b/plugins/issue-11767-plugin/grails-app/conf/plugin.yml new file mode 100644 index 00000000..d3c99d27 --- /dev/null +++ b/plugins/issue-11767-plugin/grails-app/conf/plugin.yml @@ -0,0 +1,3 @@ +my: + value1: 'this is value 1 from plugin.yml' + value2: 'this is value 2 from plugin.yml' \ No newline at end of file diff --git a/plugins/issue-11767-plugin/grails-app/init/issue11767/plugin/Application.groovy b/plugins/issue-11767-plugin/grails-app/init/issue11767/plugin/Application.groovy new file mode 100644 index 00000000..d9b78557 --- /dev/null +++ b/plugins/issue-11767-plugin/grails-app/init/issue11767/plugin/Application.groovy @@ -0,0 +1,16 @@ +package issue11767.plugin + +import grails.boot.GrailsApp +import grails.boot.config.GrailsAutoConfiguration +import groovy.transform.CompileStatic +import grails.plugins.metadata.* +import org.springframework.context.annotation.ComponentScan + +@CompileStatic +@PluginSource +@ComponentScan(basePackages = 'issue11767.plugin') +class Application extends GrailsAutoConfiguration { + static void main(String[] args) { + GrailsApp.run(Application, args) + } +} diff --git a/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/MyPluginGrailsPlugin.groovy b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/MyPluginGrailsPlugin.groovy new file mode 100644 index 00000000..6c678882 --- /dev/null +++ b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/MyPluginGrailsPlugin.groovy @@ -0,0 +1,15 @@ +package issue11767.plugin + +import grails.plugins.* + +class Issue11767GrailsPlugin extends Plugin { + + def title = 'Issue 11767' + def author = 'Mattias Reichel' + def authorEmail = '' + def description = '' + + Closure doWithSpring() {{ -> + pluginGroovySpringBean(PluginGroovySpringBean) + }} +} \ No newline at end of file diff --git a/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovyMicronautBean.groovy b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovyMicronautBean.groovy new file mode 100644 index 00000000..684a97cc --- /dev/null +++ b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovyMicronautBean.groovy @@ -0,0 +1,11 @@ +package issue11767.plugin + +import groovy.transform.CompileStatic +import io.micronaut.context.annotation.ConfigurationProperties + +@CompileStatic +@ConfigurationProperties('my') +class PluginGroovyMicronautBean { + String value1 + String value2 +} diff --git a/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovySpringBean.groovy b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovySpringBean.groovy new file mode 100644 index 00000000..03f319bd --- /dev/null +++ b/plugins/issue-11767-plugin/src/main/groovy/issue11767/plugin/PluginGroovySpringBean.groovy @@ -0,0 +1,13 @@ +package issue11767.plugin + +import groovy.transform.CompileStatic +import org.springframework.boot.context.properties.ConfigurationProperties +import org.springframework.context.annotation.Configuration + +@CompileStatic +@Configuration +@ConfigurationProperties(prefix = 'my') +class PluginGroovySpringBean { + String value1 + String value2 +} diff --git a/plugins/issue-11767-plugin/src/main/java/issue11767/plugin/PluginJavaMicronautBean.java b/plugins/issue-11767-plugin/src/main/java/issue11767/plugin/PluginJavaMicronautBean.java new file mode 100644 index 00000000..19a259ca --- /dev/null +++ b/plugins/issue-11767-plugin/src/main/java/issue11767/plugin/PluginJavaMicronautBean.java @@ -0,0 +1,26 @@ +package issue11767.plugin; + +import io.micronaut.context.annotation.ConfigurationProperties; + +@ConfigurationProperties("my") +public class PluginJavaMicronautBean { + + private String value1; + private String value2; + + public String getValue1() { + return value1; + } + + public void setValue1(String value1) { + this.value1 = value1; + } + + public String getValue2() { + return value2; + } + + public void setValue2(String value2) { + this.value2 = value2; + } +} diff --git a/settings.gradle b/settings.gradle index 25afc47e..99cf6c9f 100644 --- a/settings.gradle +++ b/settings.gradle @@ -50,3 +50,7 @@ project(':loadafter').projectDir = new File('plugins/loadafter') include 'issue11005' project(':issue11005').projectDir = new File('plugins/issue11005') + +include 'issue-11767' +include 'issue-11767-plugin' +project(':issue-11767-plugin').projectDir = new File('plugins/issue-11767-plugin')