diff --git a/spring-boot-project/spring-boot/src/main/java/org/springframework/boot/cloud/CloudFoundryVcapEnvironmentPostProcessor.java b/spring-boot-project/spring-boot/src/main/java/org/springframework/boot/cloud/CloudFoundryVcapEnvironmentPostProcessor.java index f038288f26f2..d02eda60e268 100644 --- a/spring-boot-project/spring-boot/src/main/java/org/springframework/boot/cloud/CloudFoundryVcapEnvironmentPostProcessor.java +++ b/spring-boot-project/spring-boot/src/main/java/org/springframework/boot/cloud/CloudFoundryVcapEnvironmentPostProcessor.java @@ -224,6 +224,9 @@ private String getPropertyName(String path, String key) { if (key.startsWith("[")) { return path + key; } + if (key.contains(".")) { + return path + "[" + key + "]"; + } return path + "." + key; } diff --git a/spring-boot-project/spring-boot/src/test/java/org/springframework/boot/cloud/cloudfoundry/CloudFoundryVcapEnvironmentPostProcessorTests.java b/spring-boot-project/spring-boot/src/test/java/org/springframework/boot/cloud/cloudfoundry/CloudFoundryVcapEnvironmentPostProcessorTests.java index f6e41593881b..e4185b01930d 100644 --- a/spring-boot-project/spring-boot/src/test/java/org/springframework/boot/cloud/cloudfoundry/CloudFoundryVcapEnvironmentPostProcessorTests.java +++ b/spring-boot-project/spring-boot/src/test/java/org/springframework/boot/cloud/cloudfoundry/CloudFoundryVcapEnvironmentPostProcessorTests.java @@ -116,6 +116,16 @@ void testServicePropertiesWithoutNA() { assertThat(getProperty("vcap.services.mysql.credentials.port")).isEqualTo("3306"); } + @Test + void testServicePropertiesContainingKeysWithDot() { + TestPropertySourceUtils.addInlinedPropertiesToEnvironment(this.context, + "VCAP_SERVICES={\"user-provided\":[{\"name\":\"test\",\"label\":\"test-label\"," + + "\"credentials\":{\"key.with.dots\":\"some-value\"}}]}"); + this.initializer.postProcessEnvironment(this.context.getEnvironment(), null); + assertThat(getProperty("vcap.services.test.name")).isEqualTo("test"); + assertThat(getProperty("vcap.services.test.credentials[key.with.dots]")).isEqualTo("some-value"); + } + private String getProperty(String key) { return this.context.getEnvironment().getProperty(key); }