Response Templating - Working with JSON
Working with JSON and JSONPath
Extracting data with JSONPath
WireMock Cloud provides the jsonPath
helper which will extract values from a JSON document
using the JSONPath expression language.
Similar in concept to XPath, JSONPath permits selection of individual values or sub-documents via a query expression.
For example, given the JSON
The following will render “Stuff” into the output:
And for the same JSON the following will render { "inner": "Stuff" }
:
Iterating over JSON elements
The jsonPath
helper outputs a “one or many” collection, which can either
be printed directly, or passed to further helpers such as each
or join
.
For instance, given a request body of the form:
And the following response body template:
The response body will contain:
The above will only work if the JSONPath expression selects an array from the
request JSON. However, each
can also be used to iterate over maps/objects, so given
the request JSON:
And the template:
The output would contain:
Adding to a JSON Array
The jsonArrayAdd
helper allows you to append an element to an existing json array.
Its simplest form just takes two parameters, the array to append to and the item to be added:
The above template will produce the following JSON:
You can also use it in block form to parse the contents of the block as the new item to add:
It may be convenient to default the array to an empty array if it does not exist:
The number of items in the array can be limited by using the maxItems
parameter:
The above template will produce the following JSON. The first item in the array has been removed to maintain the
number of items in the array as specified by the maxItems
parameter:
You can add arrays to the existing json array using this helper:
The above template will produce the following JSON:
If you want the end result to be a single json array, you can use the flatten
attribute:
The above template will produce the following JSON:
You can use the jsonArrayAdd
helper to add items to a nested array. This is achieved using the jsonPath
property
and referencing the array you want to add an item to:
The above template will produce the following JSON:
Removing from a JSON Array or Object
The jsonRemove
helper allows you to remove an element from an existing json array, or remove a key from an existing
json object, by identifying it using a json path expression.
For instance, given an existing array like this:
application of this helper, which selects the object with id 123
:
will return this array:
Given an object like this:
application of this helper, which selects the key name
:
will return this object:
Merging JSON objects
The jsonMerge
helper allows you to merge two json objects. Merging will recurse into any common keys where the values
are both objects, but not into any array values, where the value in the second object will overwrite that in the first.
Given these two objects:
will return this object:
Like the jsonArrayAdd
helper, the second object can be provided as a block:
Formatting JSON
The formatJson
helper allows you to output JSON in either a pretty or a compact format. The default is pretty:
emits:
Whereas
emits
The json to format can also be supplied as a block body:
Reading object as JSON
The parseJson
helper will take the string value of the provided variable (or the contents of the block) and parse it
into an object or array, and assign it to the given variable.
e.g.
will add an array called newVariableName
that can be used in subsequent helpers.
The contents to parse can also be supplied inline:
If no variable name is supplied the result of the parsing is output.
Writing data as a JSON string
The toJson
helper will convert any object into a JSON string.
emits