Skip to main content

Robot Framework test library for (RESTful) JSON APIs

Project description

Robot Framework test library for (RESTful) JSON APIs

Why?

  1. RESTinstance relies on Robot Framework’s language-agnostic, natural language syntax for API tests. It is neither tied to any particular programming language nor development framework. Using RESTinstance requires little, if any, programming knowledge. It builts on long-term technologies with well established communities, such as HTTP, JSON (Schema), OpenAPI and Robot Framework.

  2. It validates JSON using JSON Schema, guiding you to write API tests to base on constraints rather than on specific values (e.g. “email must be valid” vs “email is foo@bar.com”). This approach reduces test maintenance when the values responded by the API are prone to change. Although values are not required, you can still test them whenever they make sense (e.g. GET response body from one endpoint, then POST some of its values to another endpoint).

  3. It generates JSON Schema for requests and responses automatically, and the schema gets more accurate by your tests. The schema is a contract between different teams, or functions (backend, frontend, test developers), to agree on what kind of data the API handles. Additionally, you can mark validations to be skipped and rather use the tests to define how the API should work - then the schema also acts as a design. The schema can be further extended to an OpenAPI specification (manually for now, generating also this is planned), which RESTinstance can also test requests and responses against. This leads to very clean looking tests.

Installation

Python

On 3.x and 2.7, you can install the package from PyPi:

pip install --upgrade RESTinstance

Docker

The image has Python 3.6 and the latest Robot Framework:

docker pull asyrjasalo/restinstance
docker run --rm -ti --env HOST_UID=$(id -u) --env HOST_GID=$(id -g) \
  --volume "$PWD/tests":/home/robot/tests \
  --volume "$PWD/results":/home/robot/results \
  asyrjasalo/restinstance tests

rfdocker

If you are already using rfdocker, just add RESTinstance to your requirements.txt and remove the commented lines in Dockerfile. It will be installed automatically the next time you run ./rfdocker.

Usage

Tip: You can run this README.rst as a test with Robot Framework.

The most common use cases for library are:

  1. Writing the classic value based API tests

*** Settings ***
Library         REST              https://jsonplaceholder.typicode.com

*** Variables ***
${json}=        { "id": 11, "name": "Gil Alexander" }
&{dict}=        name=Julie Langford

*** Test Cases ***
GET existing users
    GET         /users?limit=5
    Array       response body
    Object      response body 0
    Integer     response body 0 id        1
    [Teardown]  Output  response body 0

GET an existing user
    GET         /users/1
    Integer     response body id          1
    String      response body name        Leanne Graham

POST with valid params to create an user
    POST        /users                    ${json}
    Integer     response status           201

PUT with valid params to update existing
    PUT         /users/2                  { "isCoding": true }
    Boolean     response body isCoding    true
    PUT         /users/2                  { "sleep": null }
    Null        response body sleep
    PUT         /users/2                  { "pockets": "", "money": 0.02 }
    String      response body pockets     ${EMPTY}
    Number      response body money       0.02
    Missing     response body moving

PATCH with valid params and using response as the new payload
    &{res}=     GET   /users/3
    String      response body name        Clementine Bauch
    PATCH       /users/4                  { "name": "${res.body['name']}" }
    String      response body name        Clementine Bauch
    PATCH       /users/5                  ${dict}
    String      response body name        ${dict.name}

DELETE existing successfully
    DELETE      /users/6
    Integer     response status           200    202     204
  1. Testing for JSON types and constraints using JSON Schema validations. Examples.

  2. Testing API requests and responses against a schema or a specification. Examples for testing against JSON schema and examples for testing against Swagger 2.0 specification.

See keyword documentation.

Development

Bug reports and feature requests are tracked in GitHub.

We do respect pull request(er)s. Please mention if you do not want to be listed below as contributors.

Library’s own tests

For simplicity, Docker is required for running the library’s own tests. No other requirements are needed.

To spin up the environment and run the tests:

./test

To run them on Python 2.7:

BUILD_ARGS="-f Dockerfile.python2" BUILD_NAME="restinstance-python2" ./test

System under test

The test API is implemented by mounterest, which in turn bases on mountebank.

In the scope of library’s tests, mounterest acts as a HTTP proxy to Typicode’s live JSON server and uses mountebank’s injections to enrich responses slightly, so that they better match to this library’s testing needs. Particularly, it allows to test the library with non-safe HTTP methods (POST, PUT, PATCH, DELETE) by mimicking their changes, instead of trying to issue them on the live server. The changes are cleared between the test runs.

Releasing

To generate keyword documentation:

./genlibdoc

To build and release Python package to PyPi:

./release_pypi

To release the Docker image to private Docker registry:

./release https://your.private.registry.com:5000/restinstance

To release the Docker image to DockerHub:

./release {{organization}}/restinstance

Credits

RESTinstance is licensed under Apache License 2.0 and was originally written by Anssi Syrjäsalo.

It was presented at (the first) RoboCon 2018.

Contributors:

We use the following Python excellence under the hood:

  • Flex, by Piper Merriam, for Swagger 2.0 validation

  • GenSON, by Jon “wolverdude” Wolverton, for JSON Schema generator

  • jsonpath-ng, by Tomas Aparicio and Kenneth Knowles, for handling JSONPath queries

  • jsonschema, by Julian Berman, for JSON Schema draft-04 validation

  • pygments, by Georg Brandl et al., for JSON syntax coloring, in console Output

  • requests, by Kenneth Reitz et al., for making HTTP requests

See requirements.txt for all the direct dependencies.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

RESTinstance-1.0.0b32.tar.gz (66.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

RESTinstance-1.0.0b32-py2.py3-none-any.whl (17.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file RESTinstance-1.0.0b32.tar.gz.

File metadata

File hashes

Hashes for RESTinstance-1.0.0b32.tar.gz
Algorithm Hash digest
SHA256 5412524f1cdd6fc042f957b78c91d82a239d92f5a662b238e387595f9040d8bf
MD5 00fb0eddda571c59d02e8c80c521fa4a
BLAKE2b-256 f0347cdd73660195ad427e1b0be150c247d98e642113f7614b62fc8e5dd156ce

See more details on using hashes here.

File details

Details for the file RESTinstance-1.0.0b32-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for RESTinstance-1.0.0b32-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a00d92ff35c67d97e9b090399302d273a28e82c7b36a91b2ca8f1d04f3f21510
MD5 f06e45021bc5e1679e221b2fe9bde61f
BLAKE2b-256 a6c22bb56e497d068276a62567d0edb2eb0bd780ea2847876c2f4060273d0835

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page