Web APIs testing for lazy cats.
API-Piki for Node.js helps you generate and write recurrent test skeletons to catch bugs in your APIs described by an OpenAPI Specification (fka Swagger) document.
If your Web/REST APIs are described by the OpenAPI Specification (fka Swagger), this tool generates some recurrent common test cases skeletons to extensively test your API.
API-Piki tools generate test cases written in JavaScript / Node.js, using Mocha and Chai / Should as foundation testing frameworks.
API-Piki is the perfect companion if you use arrest framework to design and build your Web APIs with Node.js.
Required: Node.js >= v7.7.4
npm install -g api-piki
The quickest way to get started is to use the piki
executable command-line tool to generate your tests, as shown below:
$ piki -o api-tests <OpenApi Spec File or URL>
where <OpenApi Spec File or URL>
is the OpenAPI Spec local file path or its remote URL.
API-Piki generates all the common test suites in the specified output directory. Then, your tests are runnable (please, read the Generated code & Philosophy section for more detailed info):
$ cd api-tests && npm i && npm test
The piki
tests generator tool can also be further configured with the following command line flags.
-h, --help output usage information
-V --version output the version number
-o, --out set output directory path
-f, --forceAuth force tests generation using Basic Authentication
Testing Web/REST APIs can be tedious and repetitive. API-Piki philosophy is to provide a simple tool to generate some "Black Box", recurrent and common test cases skeletons to test Web APIs described by OpenAPI Specification; then, the generated test skeletons can be edited and adapted in order to strictly match the particular API implementation/testing strategy.
API-Piki tool generates the code for a set of common Mocha/Chai test suites. A different JavaScript file is generated per method-endpoint-path. Generated code is not intended to be runnable as it is (despite it can be run). Instead, the ideal workflow is the following:
- Run
piki
tool against an OpenAPI spec document (file or URL); - Open and edit the generated test files in order to complete or adapt them (feel free to add new tests!). In particular, search for the code lines using Mocha's
describe.skip()
function (read more here) and choose which to remove and adapt to enable the single test cases. Also, please note that the current API-Piki version doesn't generate HTTP request bodies for POSTs/PUTs (it's on our roadmap). - Run the tests.
WARNING: Current version of the piki
tool overwrites existing tests if you run it specifying an existing directory. So, be careful running the tool again if you edited the code.
This version has the following limitations:
application/json
is the only supported format for endpoints;- only Basic Authentication is supported as security scheme;
- it doesn't generate tests for pagination path params;
- it doesn't generate tests for query params;
- it doesn't generate JSON Object bodies for HTTP requests (nor parses JSON Schemas);