This is a Newman OpenAPI reporter for generating coverage reports from a Newman run based on an OpenAPI specification.
It was inspired by the openapi-backend projects route matching and a desire to see how much of the OpenAPI spec automated test generators were producing.
It determines coverage as how much of the path/method/response tree has requests made during the run.
├── path
| └── method
| ├── response
| ├── response
| └── response
└── path
└── method
├── response
└── response
npm install newman-reporter-openapi
or
npm install -g newman-reporter-openapi
Add the report as a custom Newman reporter:
newman --reporters openapi
You can include multiple Newman reporters like this:
newman --reporters "cli,openapi"
The only required parameter for the OpenAPI reporter is the OpenAPI spec using --reporter-openapi-spec:
--reporter-openapi-spec ./openapi.yaml
The reporter will check each Newman API call against the server list in your OpenAPI spec.
If the server isn't in that list, for local testing for example, you can specify it via --reporter-openapi-serverUrl
--reporter-openapi-serverUrl http://127.0.0.1/3000
The reporter has three different report styles with different layouts. The default is wide.
--reporter-openapi-reportstyle wide
--reporter-openapi-reportstyle tall
--reporter-openapi-reportstyle summary
Coming soon --exportFilename for a json based export of the coverage.
In the reports the response codes have the following symbols:
- + shows a response that was received
- - shows a response that was not received
- ? shows a received response that was not part of the spec
There are three different versions of the report.
wide - best for when your spec has many different paths (the default)
tall - an option for APIs with a small number of paths otherwise it can get too tall
summary - for a basic summary of the coverage without path or response details