Browse Source

Improve Javadoc for ClientRequest#from

See gh-27220
pull/27248/head
Alexej Timonin 3 years ago committed by Rossen Stoyanchev
parent
commit
e290ae285c
  1. 6
      spring-webflux/src/main/java/org/springframework/web/reactive/function/client/ClientRequest.java
  2. 35
      spring-webflux/src/test/java/org/springframework/web/reactive/function/client/DefaultClientRequestBuilderTests.java

6
spring-webflux/src/main/java/org/springframework/web/reactive/function/client/ClientRequest.java

@ -1,5 +1,5 @@ @@ -1,5 +1,5 @@
/*
* Copyright 2002-2019 the original author or authors.
* Copyright 2002-2021 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -125,8 +125,8 @@ public interface ClientRequest { @@ -125,8 +125,8 @@ public interface ClientRequest {
// Static builder methods
/**
* Create a builder with the method, URI, headers, and cookies of the given request.
* @param other the request to copy the method, URI, headers, and cookies from
* Create a builder with the method, URI, headers, cookies, attributes, and body of the given request.
* @param other the request to copy the method, URI, headers, cookies, attributes, and body from
* @return the created builder
*/
static Builder from(ClientRequest other) {

35
spring-webflux/src/test/java/org/springframework/web/reactive/function/client/DefaultClientRequestBuilderTests.java

@ -1,5 +1,5 @@ @@ -1,5 +1,5 @@
/*
* Copyright 2002-2020 the original author or authors.
* Copyright 2002-2021 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -56,6 +56,8 @@ public class DefaultClientRequestBuilderTests { @@ -56,6 +56,8 @@ public class DefaultClientRequestBuilderTests {
ClientRequest other = ClientRequest.create(GET, URI.create("https://example.com"))
.header("foo", "bar")
.cookie("baz", "qux")
.attribute("attributeKey", "attributeValue")
.attribute("anotherAttributeKey", "anotherAttributeValue")
.httpRequest(request -> {})
.build();
ClientRequest result = ClientRequest.from(other)
@ -69,6 +71,37 @@ public class DefaultClientRequestBuilderTests { @@ -69,6 +71,37 @@ public class DefaultClientRequestBuilderTests {
assertThat(result.cookies().size()).isEqualTo(1);
assertThat(result.cookies().getFirst("baz")).isEqualTo("quux");
assertThat(result.httpRequest()).isNotNull();
assertThat(result.attributes().get("attributeKey")).isEqualTo("attributeValue");
assertThat(result.attributes().get("anotherAttributeKey")).isEqualTo("anotherAttributeValue");
}
@Test
public void fromCopiesBody() {
String body = "foo";
BodyInserter<String, ClientHttpRequest> inserter = (response, strategies) -> {
byte[] bodyBytes = body.getBytes(UTF_8);
DataBuffer buffer = DefaultDataBufferFactory.sharedInstance.wrap(bodyBytes);
return response.writeWith(Mono.just(buffer));
};
ClientRequest other = ClientRequest.create(POST, URI.create("https://example.com"))
.body(inserter).build();
ClientRequest result = ClientRequest.from(other).build();
List<HttpMessageWriter<?>> messageWriters = new ArrayList<>();
messageWriters.add(new EncoderHttpMessageWriter<>(CharSequenceEncoder.allMimeTypes()));
ExchangeStrategies strategies = mock(ExchangeStrategies.class);
given(strategies.messageWriters()).willReturn(messageWriters);
MockClientHttpRequest request = new MockClientHttpRequest(POST, "/");
result.writeTo(request, strategies).block();
String copiedBody = request.getBodyAsString().block();
assertThat(copiedBody).isEqualTo("foo");
}
@Test

Loading…
Cancel
Save