mirror of
https://github.com/correl/openapi-core.git
synced 2025-01-01 11:03:19 +00:00
Merge pull request #63 from rafaelcaricio/parse-examples
Makes it possible to access API examples
This commit is contained in:
commit
db37be8ac7
4 changed files with 25 additions and 3 deletions
|
@ -14,8 +14,15 @@ class MediaTypeGenerator(object):
|
||||||
for mimetype, media_type in iteritems(content):
|
for mimetype, media_type in iteritems(content):
|
||||||
schema_spec = media_type.get('schema')
|
schema_spec = media_type.get('schema')
|
||||||
|
|
||||||
|
example_spec = media_type.get('example')
|
||||||
|
example_type = type(example_spec)
|
||||||
|
if example_type is dict:
|
||||||
|
example = self.dereferencer.dereference(example_spec)
|
||||||
|
else:
|
||||||
|
example = example_spec
|
||||||
|
|
||||||
schema = None
|
schema = None
|
||||||
if schema_spec:
|
if schema_spec:
|
||||||
schema, _ = self.schemas_registry.get_or_create(schema_spec)
|
schema, _ = self.schemas_registry.get_or_create(schema_spec)
|
||||||
|
|
||||||
yield mimetype, MediaType(mimetype, schema)
|
yield mimetype, MediaType(mimetype, schema=schema, example=example)
|
||||||
|
|
|
@ -15,9 +15,10 @@ MEDIA_TYPE_DESERIALIZERS = {
|
||||||
class MediaType(object):
|
class MediaType(object):
|
||||||
"""Represents an OpenAPI MediaType."""
|
"""Represents an OpenAPI MediaType."""
|
||||||
|
|
||||||
def __init__(self, mimetype, schema=None):
|
def __init__(self, mimetype, schema=None, example=None):
|
||||||
self.mimetype = mimetype
|
self.mimetype = mimetype
|
||||||
self.schema = schema
|
self.schema = schema
|
||||||
|
self.example = example
|
||||||
|
|
||||||
def get_deserializer_mapping(self):
|
def get_deserializer_mapping(self):
|
||||||
mapping = MEDIA_TYPE_DESERIALIZERS.copy()
|
mapping = MEDIA_TYPE_DESERIALIZERS.copy()
|
||||||
|
|
|
@ -80,6 +80,9 @@ paths:
|
||||||
application/json:
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/PetCreate'
|
$ref: '#/components/schemas/PetCreate'
|
||||||
|
example:
|
||||||
|
name: "Pet"
|
||||||
|
wings: []
|
||||||
responses:
|
responses:
|
||||||
'201':
|
'201':
|
||||||
description: Null response
|
description: Null response
|
||||||
|
@ -106,6 +109,10 @@ paths:
|
||||||
application/json:
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: "#/components/schemas/PetData"
|
$ref: "#/components/schemas/PetData"
|
||||||
|
example: |
|
||||||
|
{
|
||||||
|
"data": []
|
||||||
|
}
|
||||||
image/*:
|
image/*:
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
@ -125,6 +132,9 @@ paths:
|
||||||
application/json:
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: "#/components/schemas/TagList"
|
$ref: "#/components/schemas/TagList"
|
||||||
|
example:
|
||||||
|
- dogs
|
||||||
|
- cats
|
||||||
default:
|
default:
|
||||||
$ref: "#/components/responses/ErrorResponse"
|
$ref: "#/components/responses/ErrorResponse"
|
||||||
post:
|
post:
|
||||||
|
|
|
@ -102,6 +102,10 @@ class TestPetstore(object):
|
||||||
assert media_type.mimetype == mimetype
|
assert media_type.mimetype == mimetype
|
||||||
|
|
||||||
content_spec = response_spec['content'][mimetype]
|
content_spec = response_spec['content'][mimetype]
|
||||||
|
|
||||||
|
example_spec = content_spec.get('example')
|
||||||
|
assert media_type.example == example_spec
|
||||||
|
|
||||||
schema_spec = content_spec.get('schema')
|
schema_spec = content_spec.get('schema')
|
||||||
assert bool(schema_spec) == bool(media_type.schema)
|
assert bool(schema_spec) == bool(media_type.schema)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue