Merge branch '6.2.x'
This commit is contained in:
commit
50061dae35
|
|
@ -313,19 +313,22 @@ final class DefaultRestClient implements RestClient {
|
|||
|
||||
@Override
|
||||
public RequestBodySpec uri(String uriTemplate, Object... uriVariables) {
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriTemplate);
|
||||
UriBuilder uriBuilder = uriBuilderFactory.uriString(uriTemplate);
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriBuilder.toUriString());
|
||||
return uri(DefaultRestClient.this.uriBuilderFactory.expand(uriTemplate, uriVariables));
|
||||
}
|
||||
|
||||
@Override
|
||||
public RequestBodySpec uri(String uriTemplate, Map<String, ?> uriVariables) {
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriTemplate);
|
||||
UriBuilder uriBuilder = uriBuilderFactory.uriString(uriTemplate);
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriBuilder.toUriString());
|
||||
return uri(DefaultRestClient.this.uriBuilderFactory.expand(uriTemplate, uriVariables));
|
||||
}
|
||||
|
||||
@Override
|
||||
public RequestBodySpec uri(String uriTemplate, Function<UriBuilder, URI> uriFunction) {
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriTemplate);
|
||||
UriBuilder uriBuilder = uriBuilderFactory.uriString(uriTemplate);
|
||||
attribute(URI_TEMPLATE_ATTRIBUTE, uriBuilder.toUriString());
|
||||
return uri(uriFunction.apply(DefaultRestClient.this.uriBuilderFactory.uriString(uriTemplate)));
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -83,6 +83,7 @@ class RestClientObservationTests {
|
|||
|
||||
RestClient.Builder createBuilder() {
|
||||
return RestClient.builder()
|
||||
.baseUrl("https://example.com/base")
|
||||
.messageConverters(converters -> converters.add(0, this.converter))
|
||||
.requestFactory(this.requestFactory)
|
||||
.observationRegistry(this.observationRegistry);
|
||||
|
|
@ -90,26 +91,37 @@ class RestClientObservationTests {
|
|||
|
||||
@Test
|
||||
void shouldContributeTemplateWhenUriVariables() throws Exception {
|
||||
mockSentRequest(GET, "https://example.com/hotels/42/bookings/21");
|
||||
mockSentRequest(GET, "https://example.com/base/hotels/42/bookings/21");
|
||||
mockResponseStatus(HttpStatus.OK);
|
||||
|
||||
client.get().uri("https://example.com/hotels/{hotel}/bookings/{booking}", "42", "21")
|
||||
client.get().uri("/hotels/{hotel}/bookings/{booking}", "42", "21")
|
||||
.retrieve().toBodilessEntity();
|
||||
|
||||
assertThatHttpObservation().hasLowCardinalityKeyValue("uri", "/hotels/{hotel}/bookings/{booking}");
|
||||
assertThatHttpObservation().hasLowCardinalityKeyValue("uri", "/base/hotels/{hotel}/bookings/{booking}");
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldContributeTemplateWhenMap() throws Exception {
|
||||
mockSentRequest(GET, "https://example.com/hotels/42/bookings/21");
|
||||
mockSentRequest(GET, "https://example.com/base/hotels/42/bookings/21");
|
||||
mockResponseStatus(HttpStatus.OK);
|
||||
|
||||
Map<String, String> vars = Map.of("hotel", "42", "booking", "21");
|
||||
|
||||
client.get().uri("https://example.com/hotels/{hotel}/bookings/{booking}", vars)
|
||||
client.get().uri("/hotels/{hotel}/bookings/{booking}", vars)
|
||||
.retrieve().toBodilessEntity();
|
||||
|
||||
assertThatHttpObservation().hasLowCardinalityKeyValue("uri", "/hotels/{hotel}/bookings/{booking}");
|
||||
assertThatHttpObservation().hasLowCardinalityKeyValue("uri", "/base/hotels/{hotel}/bookings/{booking}");
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldContributeTemplateWhenFunction() throws Exception {
|
||||
mockSentRequest(GET, "https://example.com/base/hotels/42/bookings/21");
|
||||
mockResponseStatus(HttpStatus.OK);
|
||||
|
||||
client.get().uri("/hotels/{hotel}/bookings/{booking}", builder -> builder.build("42", "21"))
|
||||
.retrieve().toBodilessEntity();
|
||||
|
||||
assertThatHttpObservation().hasLowCardinalityKeyValue("uri", "/base/hotels/{hotel}/bookings/{booking}");
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
|||
Loading…
Reference in New Issue