Skip to content

Latest commit

 

History

History

sample-http-form-data

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Http form data sample Logo

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

Objectives

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.

Run

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.

Citrus test

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.

Further information

For more information on Citrus see www.citrusframework.org, including a complete reference manual.