OpenAPI 2.0 (aka Swagger) and OpenAPI 3 spec validator
Project description
About
OpenAPI Spec Validator is a Python library that validates OpenAPI Specs against the OpenAPI 2.0 (aka Swagger), OpenAPI 3.0 and OpenAPI 3.1 specification. The validator aims to check for full compliance with the Specification.
Installation
$ pip install openapi-spec-validator
Alternatively you can download the code and install from the repository:
$ pip install -e git+https://github.com/p1c2u/openapi-spec-validator.git#egg=openapi_spec_validator
Usage
Command Line Interface
Straight forward way:
$ openapi-spec-validator openapi.yaml
pipes way:
$ cat openapi.yaml | openapi-spec-validator -
docker way:
$ docker run -v path/to/openapi.yaml:/openapi.yaml --rm p1c2u/openapi-spec-validator /openapi.yaml
or more pythonic way:
$ python -m openapi_spec_validator openapi.yaml
Examples
By default, OpenAPI spec version is detected. To validate spec:
from openapi_spec_validator import validate_spec
from openapi_spec_validator.readers import read_from_filename
spec_dict, spec_url = read_from_filename('openapi.yaml')
# If no exception is raised by validate_spec(), the spec is valid.
validate_spec(spec_dict)
validate_spec({'openapi': '3.1.0'})
Traceback (most recent call last):
...
OpenAPIValidationError: 'info' is a required property
Add spec_url to validate spec with relative files:
validate_spec(spec_dict, spec_url='file:///path/to/spec/openapi.yaml')
You can also validate spec from url:
from openapi_spec_validator import validate_spec_url
# If no exception is raised by validate_spec_url(), the spec is valid.
validate_spec_url('http://example.com/openapi.json')
In order to explicitly validate a:
Swagger / OpenAPI 2.0 spec, import openapi_v2_spec_validator
OpenAPI 3.0 spec, import openapi_v30_spec_validator
OpenAPI 3.1 spec, import openapi_v31_spec_validator
and pass the validator to validate_spec or validate_spec_url function:
validate_spec(spec_dict, validator=openapi_v31_spec_validator)
You can also explicitly import openapi_v3_spec_validator which is a shortcut to the latest v3 release.
If you want to iterate through validation errors:
from openapi_spec_validator import openapi_v3_spec_validator
errors_iterator = openapi_v3_spec_validator.iter_errors(spec)
License
Copyright (c) 2017-2022, Artur Maciag, All rights reserved. Apache v2
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
Built Distribution
File details
Details for the file openapi-spec-validator-0.5.0.tar.gz
.
File metadata
- Download URL: openapi-spec-validator-0.5.0.tar.gz
- Upload date:
- Size: 27.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.0 CPython/3.10.6 Linux/5.15.0-1017-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8026cd5c11a1556d4cdec56134c2ab8b64b588c10c9210d36a173b752291ad0d |
|
MD5 | 1ec8b2e07558e3a7667a410c2979c2f7 |
|
BLAKE2b-256 | aa250fbd4b12695ad851dff019cfb22596eac1e45ec796cfc2f13aeb005c34f4 |
File details
Details for the file openapi_spec_validator-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: openapi_spec_validator-0.5.0-py3-none-any.whl
- Upload date:
- Size: 31.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.0 CPython/3.10.6 Linux/5.15.0-1017-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0ace49b0bbcd0783164e3400976e80862ae3102cffbd88e9a29b9c1457bef6ff |
|
MD5 | 98d00455512a01cd24d4051d7e4dff21 |
|
BLAKE2b-256 | 7a6f896dee540f957d34bc1a89922bbd32a599aaec017e458cbf623fd189eea8 |