Skip to main content

Test framework for auto-generating libraries from OpenAPI specification file.

Project description

Roboswag

Introduction

:robot: Roboswag is a tool that automatically generates Python libraries out of your Swagger (OpenAPI specification file). These libraries can be used to create tests with various payload content and its validation. It also supports response validation against schema and verification of different status codes.

Note

The tool is in the Alpha state, which means it may be unstable and should be used at your own risk. Some features may be broken and there are still many things to be developed. Happy testing!

The OpenAPI Specification (OAS) defines a standard, language-agnostic interface to RESTful APIs. Click here for v3 documentation and here for v2 documentation.

Hosted on GitHub. :medal_military:

Installation

Note

The PyPI package will be released when Beta version is out.

First, you need to install Roboswag, and there are currently 2 ways to do it:

  • you can clone the repository, go to the main roboswag directory and install the tool locally:
pip install .
  • you can install the tool directly from GitHub's source code:
pip install -U git+https://github.com/MarketSquare/roboswag.git

Usage

Roboswag can be easily run from command line. To check if it's installed, run this to see the current version:

roboswag -v

To execute Roboswag with its full capabilities, run it with provided path to the Swagger (OpenAPI specification) file:

roboswag generate -s <path_to_swagger>

You can try out the tool using the example of swagger file located in swaggers/petstore.json.

Successful execution should result in printing the information about generated files and a whole new directory (named by the value of info.title from your Swagger file) consisting of:

  • endpoints directory with files representing each tag as a class with methods representing its endpoints,
  • models directory with API models represented as Python classes,
  • schemas directory with every possible schema from your API as JSON file used for validating payload and responses.

Now you can just create a test file, import desired endpoint and start automating the testing!

Limitations

The tool is already able to generate libraries but...

  • Not all fields from the swagger specification may be supported. This means that a specific file may break the tool and flood the terminal with stack trace (we will be really grateful to receive bug issues in our Github project!)
  • Authorization to access the API is not yet fully covered
  • There is not much to be configured here - it always works the same
  • There is no real documentation apart from this file

Please be forgiving and submit an issue, if you struggle with something or just contact us on our Slack channel. It's more than welcome also to support us by code contribution! :keyboard:

Project details


Download files

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

Source Distribution

roboswag-0.4.0.tar.gz (17.8 kB view details)

Uploaded Source

Built Distribution

roboswag-0.4.0-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file roboswag-0.4.0.tar.gz.

File metadata

  • Download URL: roboswag-0.4.0.tar.gz
  • Upload date:
  • Size: 17.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.15 CPython/3.10.6 Linux/5.15.0-1017-azure

File hashes

Hashes for roboswag-0.4.0.tar.gz
Algorithm Hash digest
SHA256 73baef55e563af30b4a491c2f288644e4f025010b9013caa7bdc0550f68f7430
MD5 40d8f73d90af9fa1a7fc45c5a64c2b0b
BLAKE2b-256 6a1efbe36884cc8b4f3da384e96a2ed98afac708678a11ecce94f2bf2a34666b

See more details on using hashes here.

Provenance

File details

Details for the file roboswag-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: roboswag-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 21.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.15 CPython/3.10.6 Linux/5.15.0-1017-azure

File hashes

Hashes for roboswag-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b8c005c7c0c62162400ee5df264305930c516a270ecb4e4787f96e8cffe076a9
MD5 78113cd030bc9f0d619ed220dff72b72
BLAKE2b-256 2a246d3c33bbabffeac597c1d9f26678051dd68643901b44eaa51e252865672c

See more details on using hashes here.

Provenance

Supported by

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