Browser clients are able to post form data as application/x-www-form-urlencoded
key-value String to the Http server. The HTML forms use POST
method and build a
form urlencoded String of all form controls and their values as message payload. You can send and receive such form data in Citrus.
Http form data features are also described in detail in reference guide
The test will simulate client and server for form data exchange via Http POST. First of all we need client and server components in the Spring bean configuration:
@Bean
public HttpClient todoClient() {
return CitrusEndpoints
.http()
.client()
.requestUrl("http://localhost:8080")
.build();
}
@Bean
public HttpServer todoListServer() {
return CitrusEndpoints
.http()
.server()
.port(8080)
.timeout(10000)
.autoStart(true)
.build();
}
These components are normal Citrus Http client and server components. In this test we will use both client and server within the same test case in order to demonstrate both sides of the communication. In a real world scenario you may just have one side client or server in your test.
So lets start writing a client request that uses form urlencoded message content:
$(http()
.client(todoClient)
.send()
.post("/api/todo")
.fork(true)
.contentType(MediaType.APPLICATION_FORM_URLENCODED_VALUE)
.body("title=${todoName}&description=${todoDescription}"));
As you can see we are using a Http POST
request with form urlencoded message body. The form data uses two fields title
and description
with respective values. On the server side we are able
to receive this form data for validation:
$(http()
.server(todoListServer)
.receive()
.post("/api/todo")
.contentType(MediaType.APPLICATION_FORM_URLENCODED_VALUE)
.message()
.type(MessageType.PLAINTEXT)
.body("{description=[${todoDescription}], title=[${todoName}]}"));
$(http()
.server(todoListServer)
.respond(HttpStatus.OK));
The Citrus Http server is automatically handling the form data and converts the data to a list of fields with its values. We can use the plaintext message validation to check that the form data is as expected.
In order to use the special x-www-form-urlencoded
message validation features in Citrus we need to add a new message validator in the configuration.
@Bean
public FormUrlEncodedMessageValidator formUrlEncodedMessageValidator(MessageValidatorRegistry messageValidatorRegistry) {
FormUrlEncodedMessageValidator messageValidator = new FormUrlEncodedMessageValidator();
messageValidatorRegistry.getMessageValidators().add(messageValidator);
return messageValidator;
}
The org.citrusframework.http.validation.FormUrlEncodedMessageValidator
validator implementation provides convenient form data marshalling that we can use in our test cases when expecting form urlencoded message content.
$(http()
.server(todoListServer)
.receive()
.post("/api/todo")
.contentType(MediaType.APPLICATION_FORM_URLENCODED_VALUE)
.type(FormUrlEncodedMessageValidator.MESSAGE_TYPE)
.body(getFormData(), new FormMarshaller()));
$(http()
.server(todoListServer)
.respond(HttpStatus.OK));
As you can see we can now use the special message type x-www-form-urlencoded
which enables the FormUrlEncodedMessageValidator
mechanism. This allows us to specify the full form data as plain Java object.
private FormData getFormData() {
FormData formData = new FormData();
formData.setAction("/api/todo");
formData.setContentType(MediaType.APPLICATION_FORM_URLENCODED_VALUE);
Control description = new Control();
description.setName("description");
description.setValue("@ignore@");
formData.addControl(description);
Control title = new Control();
title.setName("title");
title.setValue("${todoName}");
formData.addControl(title);
return formData;
}
This is how to send and receive Http form data in Citrus.
The sample application uses Maven as build tool. So you can compile, package and test the sample with Maven.
mvn clean verify -Dsystem.under.test.mode=embedded
This executes the complete Maven build lifecycle.
During the build you will see Citrus performing some integration tests.
Execute all Citrus tests by calling
mvn verify
You can also pick a single test by calling
mvn verify -Dit.test=<testname>
You should see Citrus performing several tests with lots of debugging output in your terminal. And of course green tests at the very end of the build.
Of course you can also start the Citrus tests from your favorite IDE. Just start the Citrus test using the TestNG IDE integration in IntelliJ, Eclipse or Netbeans.
For more information on Citrus see www.citrusframework.org, including a complete reference manual.