Skip to content

Commit

Permalink
Add test for client usage of @RestHeader on the Reactive REST Client
Browse files Browse the repository at this point in the history
Closes: quarkusio#13665
(cherry picked from commit d93345c)
  • Loading branch information
geoand authored and gsmet committed Oct 28, 2022
1 parent 3fb7490 commit 4f7a426
Showing 1 changed file with 12 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,11 @@
import javax.ws.rs.GET;
import javax.ws.rs.HeaderParam;
import javax.ws.rs.Path;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.HttpHeaders;

import org.eclipse.microprofile.rest.client.RestClientBuilder;
import org.jboss.resteasy.reactive.RestHeader;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.RegisterExtension;

Expand All @@ -27,22 +30,26 @@ public class HeaderTest {
@Test
void testHeadersWithSubresource() {
Client client = RestClientBuilder.newBuilder().baseUri(baseUri).build(Client.class);
assertThat(client.cookieSub("bar", "bar2").send("bar3", "bar4")).isEqualTo("bar:bar2:bar3:bar4");
assertThat(client.cookieSub("bar", "bar2").send("bar3", "bar4", "dummy"))
.isEqualTo("bar:bar2:bar3:bar4:X-My-Header/dummy");
}

@Test
void testNullHeaders() {
Client client = RestClientBuilder.newBuilder().baseUri(baseUri).build(Client.class);
assertThat(client.cookieSub("bar", null).send(null, "bar4")).isEqualTo("bar:null:null:bar4");
assertThat(client.cookieSub("bar", null).send(null, "bar4", "dummy")).isEqualTo("bar:null:null:bar4:X-My-Header/dummy");
}

@Path("/")
@ApplicationScoped
public static class Resource {
@GET
public String returnHeaders(@HeaderParam("foo") String header, @HeaderParam("foo2") String header2,
@HeaderParam("foo3") String header3, @HeaderParam("foo4") String header4) {
return header + ":" + header2 + ":" + header3 + ":" + header4;
@HeaderParam("foo3") String header3, @HeaderParam("foo4") String header4, @Context HttpHeaders headers) {
String myHeaderName = headers.getRequestHeaders().keySet().stream().filter(s -> s.equalsIgnoreCase("X-My-Header"))
.findFirst().orElse("");
return header + ":" + header2 + ":" + header3 + ":" + header4 + ":" + myHeaderName + "/"
+ headers.getHeaderString("X-My-Header");
}
}

Expand All @@ -55,7 +62,7 @@ public interface Client {
public interface SubClient {

@GET
String send(@HeaderParam("foo3") String cookie3, @HeaderParam("foo4") String cookie4);
String send(@HeaderParam("foo3") String cookie3, @HeaderParam("foo4") String cookie4, @RestHeader String xMyHeader);
}

}

0 comments on commit 4f7a426

Please sign in to comment.