A Swagger/OpenAPI specification may contain example payload values for request parameters and responses. Such examples are frequently used to enhance user documentation with current example payloads that can be used to run sample requests against the live service. The examples can be either inlined in the specification or provided in a separate file, referenced from the specification.
RESTler supports the following use cases for example payloads:
-
Help RESTler successfully execute a request If RESTler finds an example payload, it will use it to execute the request, instead of using a generated payload based on the full schema specified in the Swagger file. This can help the user specify valid values for the entire payload, which RESTler can use to successfully execute a request. This is often necessary when there are dependent request parameters, which is not expressed in the Swagger/OpenAPI spec, such as an enum value query parameter that can only be used with a subset of the body parameters.
-
Help RESTler fuzz the body payloads more effectively If RESTler finds one or more example payloads, it will use the values found to fuzz json bodies via the payload body checker.
Warning: this use case is currently intended to support a small number of examples. Providing many examples may cause issues generating the RESTler grammar, since they are embedded in the grammar.
RESTler does not currently support inferring the payload schema based on examples. Moreover, it requires that the example-provided parameters match the declared schema, and will discard the non-matching ones. This means that if your Swagger/OpenAPI specification is missing a schema for the parameters or response (e.g. an "object" for both), examples cannot be used to fix this quickly by overriding the specification.
RESTler only supports parameter payload examples. It does not currently use response payload examples.
A Swagger/OpenAPI specification supports specifying examples for individual parameters inline, or an external file specifying the entire payload. RESTler currently supports the latter, declared as follows:
{
"Examples": {
"First example": {
"$ref": "./examples/first.json"
},
"Second example": {
"$ref": "./examples/second.json"
}
}
}
Both the attribute Examples
and x-ms-examples
are supported.
For cases when it is desirable to augment the existing examples, the user can use the DiscoverExamples and ExamplesDirectory compilation parameters to copy all of the examples found in the OpenAPI/Swagger specification to a separate folder. An informational file named examples.json
will be output in the compilation output directory with all of the examples discovered. The format of this file is as follows:
{
"(/api/createResource, Put)": [
"examples1.json",
"example2.json"
],
}
Then, the user may modify this copy as desired.
Warning: the compilation directory, including examples, is overwritten on every compilation. By default, if the DiscoverExamples compilation parameter is set to true
, but an ExamplesDirectory is not set, RESTler will copy of all of the examples into an examples sub-directory in the compilation directory. Once you have discovered examples, move them to a different directory to modify them, and set the ExamplesDirectory to that directory on the next compilation (and the DiscoverExamples parameter to false
to use this copy of examples.)
An example payload is found, RESTler will use it to try executing the request, instead of the payload generated by the schema. Known issue: Only the first example listed in the OpenAPI/Swagger or external example file will be used, and if it fails, the other examples will not be tried. This means you must make sure that the first example in the list of examples will cause a successful (20*
) status code. The other examples will also be executed by RESTler but in a separate pass (via the examples checker), but they will not be used in full search mode. This means that if there are 3
examples for a request POST /api/database
, which create 3
different types of databases, a subsequent request PUT /api/databases/{databaseId}/backup
, the backup
request will only be executed once, for the first type of database (in the order listed in the examples file.)
This file is currently informational only, and cannot be used to specify new examples outside of the OpenAPI/Swagger spec (e.g. in the case the specification does not have examples at all, the user may want to provide a separate file that declares example payloads for each endpoint+method in the spec).