diff --git a/src/main/groovy/com/avast/gradle/dockercompose/ComposeSettings.groovy b/src/main/groovy/com/avast/gradle/dockercompose/ComposeSettings.groovy index dfd5d8e..5b6ca27 100644 --- a/src/main/groovy/com/avast/gradle/dockercompose/ComposeSettings.groovy +++ b/src/main/groovy/com/avast/gradle/dockercompose/ComposeSettings.groovy @@ -101,7 +101,10 @@ abstract class ComposeSettings { else { return "${safeProjectNamePrefix}_${nestedName}" } - }) + }).map{ String projectName -> + // docker-compose project names must be lowercase + projectName.toLowerCase() + } useComposeFiles.empty() startedServices.empty() diff --git a/src/test/groovy/com/avast/gradle/dockercompose/DockerComposePluginTest.groovy b/src/test/groovy/com/avast/gradle/dockercompose/DockerComposePluginTest.groovy index b0174c8..d9d9c42 100644 --- a/src/test/groovy/com/avast/gradle/dockercompose/DockerComposePluginTest.groovy +++ b/src/test/groovy/com/avast/gradle/dockercompose/DockerComposePluginTest.groovy @@ -81,6 +81,32 @@ class DockerComposePluginTest extends Specification { up.composeExecutor.get().parameters.useComposeFiles.get() == ['test.yml'] } + def "project name should always be lowercase"() { + def project = ProjectBuilder.builder().build() + when: + project.plugins.apply 'docker-compose' + project.dockerCompose { + nestedUppercaseTask { + useComposeFiles = ['docker-compose.yml'] + } + nestedUppercaseProjectName { + projectNamePrefix = "UPPERCASE" + } + nestedUppercaseProjectNamePrefix { + projectNamePrefix = "UPPERCASE" + } + } + + then: + + ['nestedUppercaseTask', 'nestedUppercaseProjectName'].forEach{ String config -> + def projectName = project.dockerCompose."$config".projectName.get() + assert projectName.toLowerCase() == projectName + } + + + } + def "is possible to access servicesInfos of nested setting"() { def project = ProjectBuilder.builder().build() when: