REST Resources and Methods

PDF Print E-mail
User Rating:  / 21
Rate this article: PoorBest 

1. Adding REST Services, Resources and Methods

NOTE: As of version 4.6 of SoapUI, the functionality described in this article has been revised and improved. If you're using an earlier version, please upgrade!

A REST Service contains any number of resources available on their corresponding path. Resources themselves can have as many levels of child resources as desired; a child resources path will be the concatenation of all its parents’ path with its own.

We’ll start with a new REST service to make exemplifying a bit easier, start by creating a new REST Service in your project (from the Project Popup) for the Googel Maps API as follows:

new_rest_service_4_6_0

Once created adding our first resource is straight forward; select the corresponding option from the REST Service popup menu:

navigation_to_add_resource_4_6

Selecting this opens the following dialog:

new_rest_resource_4_6_0

Start by adding a name and the search URL above (http://maps.googleapis.com/maps/api/geocode/xml?address=Rio&sensor=false) now press the “Extract Params” button which will extract the Query parameters from the URL to the Parameters table and normalize the URL relative to the one of the defined Service:

new_rest_resource_extract_param_4_6_0

As you can see the query parameter has been extracted as a standard QUERY parameter (more on parameters below), pressing OK now asks us to define a method for the Resource:

new_rest_method_4_6_0

Rename it to “Simple Search” and press OK. Now we get the following in the navigator tree:

rest_navigation_tree_4_6_0

And the “Request 1” request window has been opened for you, submit the request with the top left green arrow and you will get:

rest_request_response_4_6_0

Before digging in to the REST Request editor we need to back up a bit and look at the generated objects in our project. Let’s start by double-clicking the created Search resource, which will open the following window:

rest_resource_editor_4_6_0

In the toolbar you can see and change the path that the resource is mapped to. Under it is a “Resource Parameters” tab in which we can see the “address” and “sensor” parameters extracted during the resource-creation process. Since these are defined at the Resource level, the parameters will be available for all child resources, methods and requests below the resource in the hierarchy. Use the toolbar at the top to manage parameters, selecting a parameter enables the fields at the bottom of the window which allow you to enter detailed information for the parameter.

This data can be specified for several purposes:

  1. For correct parameter definitions in the generated WADL  (see below)
  2. For presenting a nicer input Form in the Form editor for REST Requests (see below)
  3. For custom encoding handling when setting a parameter value (the “Disable Encoding” setting)

Let’s set the parameter to be required and add a nice description (as shown above), this will give a nicer WADL in the end (as you’ll see below).

Next in the REST Service hierarchy is the GET Method we defined for the resource (which is highlighted in the screenshot above). You can define any number of methods for a resource with the “New Method” option on the resource popup menu, which opens the same dialog we saw above when creating the initial method. Double-clicking the method opens its editor window:

rest_method_editor_4_6_0

The toolbar at the top allows you to change the HTTP Method to use (GET, POST, PUT, DELETE, OPTIONS and TRACE are supported) and the “Method Parameters” tab is similar to the “Resource Parameters” tab we saw above; parameters defined here are available for all requests created for the method. Since we defined our parameters at the Resource level this table is empty and the corresponding detail fields at the bottom are disabled.

Specific for the Method window is the “Representations” tab:

rest_method_editor_representation

Here you can see the representations defined for the method, in our case soapUI automatically generated a representation for the response we received when submitting our first request, and it will continue to add new representations for each unique response content-type and status-code received. Using the toolbar buttons you can add and remove representations as desired.

Tip: The defined Representations for a Method are also visible in the corresponding Representations tabs available in the REST Request/Response editors described below.

2. Generated WADLs

When defining a REST Service “manually” as we have done above, soapUI automatically generates a corresponding WADL for us. If you now double-click the original REST Service we defined for Twitter and select the WADL-Content tab, you will get the following:

rest_service_wadl_content_4_6_0

Voila! A nicely defined and formatted WADL for the Twitter search API! Just as for a REST Service originating from a WADL we can now generate both code and documentation for the service as shown above.

One thing that is missing here is the XML Schema for the response messages returned by Google API, and later on we’ll have a look at the Schema Inference functionality in soapUI that can generate this for you as well, based on the actual messages received from the service during testing.