Skip to main content

OpenAPI 2.0 (aka Swagger) and OpenAPI 3 spec validator

Project description

https://img.shields.io/docker/v/p1c2u/openapi-spec-validator.svg?color=%23086DD7&label=docker%20hub&sort=semver https://img.shields.io/pypi/v/openapi-spec-validator.svg https://travis-ci.org/python-openapi/openapi-spec-validator.svg?branch=master https://img.shields.io/codecov/c/github/python-openapi/openapi-spec-validator/master.svg?style=flat https://img.shields.io/pypi/pyversions/openapi-spec-validator.svg https://img.shields.io/pypi/format/openapi-spec-validator.svg https://img.shields.io/pypi/status/openapi-spec-validator.svg

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.

Documentation

Check documentation to see more details about the features. All documentation is in the “docs” directory and online at openapi-spec-validator.readthedocs.io

Installation

pip install openapi-spec-validator

Alternatively you can download the code and install from the repository:

pip install -e git+https://github.com/python-openapi/openapi-spec-validator.git#egg=openapi_spec_validator

Usage

CLI (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

For more details, read about CLI (Command Line Interface).

Python package

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

For more details, read about Python package.

License

Copyright (c) 2017-2023, Artur Maciag, All rights reserved. Apache v2

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

openapi_spec_validator-0.6.0a1.tar.gz (33.7 kB view details)

Uploaded Source

Built Distribution

openapi_spec_validator-0.6.0a1-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

Details for the file openapi_spec_validator-0.6.0a1.tar.gz.

File metadata

  • Download URL: openapi_spec_validator-0.6.0a1.tar.gz
  • Upload date:
  • Size: 33.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Linux/5.15.0-1039-azure

File hashes

Hashes for openapi_spec_validator-0.6.0a1.tar.gz
Algorithm Hash digest
SHA256 a146d51505103616e292333474bde90bc45b24be320675fad0e529c643aaa4bd
MD5 5b400633ffff511925adf741806084bd
BLAKE2b-256 cd69f17be3de82b1c4967c2fbe6458a36b9e35daecb79372f57806ae3b0745bd

See more details on using hashes here.

File details

Details for the file openapi_spec_validator-0.6.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for openapi_spec_validator-0.6.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 38e8c3d081fe33cfee717559c037df5755b012c728c61484ef7992ed806cfcbb
MD5 b900e7e0179d3a7cde9c1593c69e3805
BLAKE2b-256 e8c743dea3fb70e9cf6df732c119a416f77e4b96a8ff2c2149d6066c244c7cd8

See more details on using hashes here.

Supported by

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