Skip to main content

jj mocks validator for openapi specs

Project description

Usage

  1. Decorate your mocked function with @validate_spec(), providing a link to a YAML or JSON OpenAPI spec.
import jj
from jj.mock import mocked
from jj_spec_validator import validate_spec


@validate_spec(spec_link="http://example.com/api/users/spec.yml")
async def your_mocked_function():
    matcher = jj.match("GET", "/users")
    response = jj.Response(status=200, json=[])
    
    mock = await mocked(matcher, response)
  1. is_strict key allows choosing between strict and non-strict comparison. Non-strict comparison allows you to mock only some fields from the spec. False (= non-strict) by default.

  2. Use the prefix key to specify a prefix that should be removed from the paths in the mock function before matching them against the OpenAPI spec.

from jj_spec_validator import validate_spec


@validate_spec(spec_link="http://example.com/api/users/spec.yml", prefix='/__mocked_api__')  # Goes to validate `/users` instead of `/__mocked_api__/users`
async def your_mocked_function():
    matcher = jj.match("GET", "/__mocked_api__/users")
    ...
  1. is_raise_error key allows raising an error when a mismatch occurs. False by default.

  2. force_strict key allows enforcing strict validation against the downloaded spec. This is useful when the spec is occasionally have all dicts relaxed. False by default.

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

jj_spec_validator-0.1.16.tar.gz (8.0 kB view details)

Uploaded Source

Built Distribution

jj_spec_validator-0.1.16-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file jj_spec_validator-0.1.16.tar.gz.

File metadata

  • Download URL: jj_spec_validator-0.1.16.tar.gz
  • Upload date:
  • Size: 8.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.15

File hashes

Hashes for jj_spec_validator-0.1.16.tar.gz
Algorithm Hash digest
SHA256 b59b3cd698086b7052385e88f81cdb69bb8960ebf6cc73eaab2f1d5f21f00de1
MD5 df8203e7187ea0376826d60f4d969b1f
BLAKE2b-256 7254defaa0675a60df69716beb54a93db47f72d27bd7f0ad9b720a40f3f9b146

See more details on using hashes here.

File details

Details for the file jj_spec_validator-0.1.16-py3-none-any.whl.

File metadata

File hashes

Hashes for jj_spec_validator-0.1.16-py3-none-any.whl
Algorithm Hash digest
SHA256 6fe40bbbcad3c708b25eac51206b0ab61c6bd3476f9a21b011887531f14fbe7d
MD5 938cd3fae4ff21bc862cf1c55f19873d
BLAKE2b-256 9641b71cfc19fab4ed243a4a691cb0765a22c2731cf5477c833cf2bed4db8709

See more details on using hashes here.

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