|
24 | 24 | import org.junit.jupiter.params.ParameterizedTest;
|
25 | 25 | import org.junit.jupiter.params.provider.Arguments;
|
26 | 26 | import org.junit.jupiter.params.provider.MethodSource;
|
| 27 | +import org.mockito.InOrder; |
27 | 28 |
|
28 | 29 | import org.springframework.util.PlaceholderParser.ParsedValue;
|
29 | 30 | import org.springframework.util.PlaceholderParser.TextPart;
|
|
33 | 34 | import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
|
34 | 35 | import static org.assertj.core.api.Assertions.assertThatThrownBy;
|
35 | 36 | import static org.mockito.BDDMockito.given;
|
| 37 | +import static org.mockito.Mockito.inOrder; |
36 | 38 | import static org.mockito.Mockito.mock;
|
37 | 39 | import static org.mockito.Mockito.verify;
|
38 | 40 | import static org.mockito.Mockito.verifyNoMoreInteractions;
|
@@ -220,20 +222,45 @@ static Stream<Arguments> nestedPlaceholders() {
|
220 | 222 | );
|
221 | 223 | }
|
222 | 224 |
|
| 225 | + @ParameterizedTest(name = "{0} -> {1}") |
| 226 | + @MethodSource("exactMatchPlaceholders") |
| 227 | + void placeholdersWithExactMatchAreConsidered(String text, String expected) { |
| 228 | + Properties properties = new Properties(); |
| 229 | + properties.setProperty("prefix://my-service", "example-service"); |
| 230 | + properties.setProperty("px", "prefix"); |
| 231 | + properties.setProperty("p1", "${prefix://my-service}"); |
| 232 | + assertThat(this.parser.replacePlaceholders(text, properties::getProperty)).isEqualTo(expected); |
| 233 | + } |
| 234 | + |
| 235 | + static Stream<Arguments> exactMatchPlaceholders() { |
| 236 | + return Stream.of( |
| 237 | + Arguments.of("${prefix://my-service}", "example-service"), |
| 238 | + Arguments.of("${p1}", "example-service") |
| 239 | + ); |
| 240 | + } |
| 241 | + |
| 242 | + @Test |
| 243 | + void parseWithKeyEqualsToText() { |
| 244 | + PlaceholderResolver resolver = mockPlaceholderResolver("firstName", "Steve"); |
| 245 | + assertThat(this.parser.replacePlaceholders("${firstName}", resolver)) |
| 246 | + .isEqualTo("Steve"); |
| 247 | + verifyPlaceholderResolutions(resolver, "firstName"); |
| 248 | + } |
| 249 | + |
223 | 250 | @Test
|
224 | 251 | void parseWithHardcodedFallback() {
|
225 | 252 | PlaceholderResolver resolver = mockPlaceholderResolver();
|
226 | 253 | assertThat(this.parser.replacePlaceholders("${firstName:Steve}", resolver))
|
227 | 254 | .isEqualTo("Steve");
|
228 |
| - verifyPlaceholderResolutions(resolver, "firstName"); |
| 255 | + verifyPlaceholderResolutions(resolver, "firstName:Steve", "firstName"); |
229 | 256 | }
|
230 | 257 |
|
231 | 258 | @Test
|
232 | 259 | void parseWithNestedPlaceholderInKeyUsingFallback() {
|
233 | 260 | PlaceholderResolver resolver = mockPlaceholderResolver("firstName", "John");
|
234 | 261 | assertThat(this.parser.replacePlaceholders("${first${invalid:Name}}", resolver))
|
235 | 262 | .isEqualTo("John");
|
236 |
| - verifyPlaceholderResolutions(resolver, "invalid", "firstName"); |
| 263 | + verifyPlaceholderResolutions(resolver, "invalid:Name", "invalid", "firstName"); |
237 | 264 | }
|
238 | 265 |
|
239 | 266 | @Test
|
@@ -348,8 +375,9 @@ PlaceholderResolver mockPlaceholderResolver(String... pairs) {
|
348 | 375 | }
|
349 | 376 |
|
350 | 377 | void verifyPlaceholderResolutions(PlaceholderResolver mock, String... placeholders) {
|
| 378 | + InOrder ordered = inOrder(mock); |
351 | 379 | for (String placeholder : placeholders) {
|
352 |
| - verify(mock).resolvePlaceholder(placeholder); |
| 380 | + ordered.verify(mock).resolvePlaceholder(placeholder); |
353 | 381 | }
|
354 | 382 | verifyNoMoreInteractions(mock);
|
355 | 383 | }
|
|
0 commit comments