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 v3.1 syntax is expected. To validate an OpenAPI v3.1 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({})
Traceback (most recent call last):
...
OpenAPIValidationError: 'openapi' is a required property
In order to validate a Swagger / OpenAPI 2.0 spec file, import validate_v2_spec instead of validate_spec. In order to validate a OpenAPI 3.0 spec file, import validate_v30_spec instead of validate_spec.
You can also explicitly import validate_v31_spec if you want to disambiguate the expected version or explicitly import validate_v3_spec which is a shortcut to the latest v3 release.
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')
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-2021, 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.0a3.tar.gz
.
File metadata
- Download URL: openapi-spec-validator-0.5.0a3.tar.gz
- Upload date:
- Size: 26.4 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 | 3fce6c5533cf47ced956bafd9cd9fa6ff7d2b654bfc99591bd3009c7d7d34bf4 |
|
MD5 | a485270b831722b44925821c0f5240e5 |
|
BLAKE2b-256 | 15c9e76c1c13f6b78e96e751ee50cb99c2b4f4528936ce025263eb76056337de |
File details
Details for the file openapi_spec_validator-0.5.0a3-py3-none-any.whl
.
File metadata
- Download URL: openapi_spec_validator-0.5.0a3-py3-none-any.whl
- Upload date:
- Size: 28.6 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 | 0fc20c676e4b27258977ad393a8871c0f35439189f8c00a0a57dadd8cfef7d10 |
|
MD5 | ec35e638cfef07d66440de22cac72f1c |
|
BLAKE2b-256 | f95f4b2f3582d2c4d0f824345462f6d4dc9f457e48a6664b963e95289faf972f |