mirror of
https://github.com/correl/openapi-core.git
synced 2025-01-04 03:00:15 +00:00
Schema nullable value
This commit is contained in:
parent
01e7a5b688
commit
1ca11c9d19
4 changed files with 84 additions and 7 deletions
|
@ -26,7 +26,7 @@ class Schema(object):
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
self, schema_type, model=None, properties=None, items=None,
|
self, schema_type, model=None, properties=None, items=None,
|
||||||
spec_format=None, required=False, default=None):
|
spec_format=None, required=False, default=None, nullable=False):
|
||||||
self.type = schema_type
|
self.type = schema_type
|
||||||
self.model = model
|
self.model = model
|
||||||
self.properties = properties and dict(properties) or {}
|
self.properties = properties and dict(properties) or {}
|
||||||
|
@ -34,6 +34,7 @@ class Schema(object):
|
||||||
self.format = spec_format
|
self.format = spec_format
|
||||||
self.required = required
|
self.required = required
|
||||||
self.default = default
|
self.default = default
|
||||||
|
self.nullable = nullable
|
||||||
|
|
||||||
def __getitem__(self, name):
|
def __getitem__(self, name):
|
||||||
return self.properties[name]
|
return self.properties[name]
|
||||||
|
@ -50,7 +51,11 @@ class Schema(object):
|
||||||
def cast(self, value):
|
def cast(self, value):
|
||||||
"""Cast value to schema type"""
|
"""Cast value to schema type"""
|
||||||
if value is None:
|
if value is None:
|
||||||
return None
|
if not self.nullable:
|
||||||
|
raise InvalidValueType(
|
||||||
|
"Failed to cast value of %s to %s", value, self.type,
|
||||||
|
)
|
||||||
|
return self.default
|
||||||
|
|
||||||
cast_mapping = self.get_cast_mapping()
|
cast_mapping = self.get_cast_mapping()
|
||||||
|
|
||||||
|
@ -98,6 +103,8 @@ class Schema(object):
|
||||||
if prop_name in self.required:
|
if prop_name in self.required:
|
||||||
raise MissingPropertyError(
|
raise MissingPropertyError(
|
||||||
"Missing schema property {0}".format(prop_name))
|
"Missing schema property {0}".format(prop_name))
|
||||||
|
if not prop.nullable and not prop.default:
|
||||||
|
continue
|
||||||
prop_value = prop.default
|
prop_value = prop.default
|
||||||
properties[prop_name] = prop.unmarshal(prop_value)
|
properties[prop_name] = prop.unmarshal(prop_value)
|
||||||
return ModelFactory().create(properties, name=self.model)
|
return ModelFactory().create(properties, name=self.model)
|
||||||
|
@ -130,6 +137,7 @@ class SchemaFactory(object):
|
||||||
required = schema_deref.get('required', False)
|
required = schema_deref.get('required', False)
|
||||||
properties_spec = schema_deref.get('properties', None)
|
properties_spec = schema_deref.get('properties', None)
|
||||||
items_spec = schema_deref.get('items', None)
|
items_spec = schema_deref.get('items', None)
|
||||||
|
nullable = schema_deref.get('nullable', False)
|
||||||
|
|
||||||
properties = None
|
properties = None
|
||||||
if properties_spec:
|
if properties_spec:
|
||||||
|
@ -141,7 +149,7 @@ class SchemaFactory(object):
|
||||||
|
|
||||||
return Schema(
|
return Schema(
|
||||||
schema_type, model=model, properties=properties, items=items,
|
schema_type, model=model, properties=properties, items=items,
|
||||||
required=required,
|
required=required, nullable=nullable,
|
||||||
)
|
)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|
|
@ -27,6 +27,7 @@ paths:
|
||||||
schema:
|
schema:
|
||||||
type: integer
|
type: integer
|
||||||
format: int32
|
format: int32
|
||||||
|
nullable: true
|
||||||
- name: ids
|
- name: ids
|
||||||
in: query
|
in: query
|
||||||
description: Filter pets with Ids
|
description: Filter pets with Ids
|
||||||
|
|
|
@ -323,8 +323,8 @@ class TestPetstore(object):
|
||||||
pet_model = schemas['PetCreate']['x-model']
|
pet_model = schemas['PetCreate']['x-model']
|
||||||
assert body.__class__.__name__ == pet_model
|
assert body.__class__.__name__ == pet_model
|
||||||
assert body.name == pet_name
|
assert body.name == pet_name
|
||||||
assert body.tag is None
|
assert not hasattr(body, 'tag')
|
||||||
assert body.address is None
|
assert not hasattr(body, 'address')
|
||||||
|
|
||||||
def test_get_pets_wrong_body_type(self, spec):
|
def test_get_pets_wrong_body_type(self, spec):
|
||||||
host_url = 'http://petstore.swagger.io/v1'
|
host_url = 'http://petstore.swagger.io/v1'
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import mock
|
import mock
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
|
from openapi_core.exceptions import InvalidValueType
|
||||||
from openapi_core.schemas import Schema
|
from openapi_core.schemas import Schema
|
||||||
|
|
||||||
|
|
||||||
class TestSchemas(object):
|
class TestSchemaIteritems(object):
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def schema(self):
|
def schema(self):
|
||||||
|
@ -15,6 +16,73 @@ class TestSchemas(object):
|
||||||
return Schema('object', properties=properties)
|
return Schema('object', properties=properties)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def test_iteritems(self, schema):
|
def test_valid(self, schema):
|
||||||
for name in schema.properties.keys():
|
for name in schema.properties.keys():
|
||||||
assert schema[name] == schema.properties[name]
|
assert schema[name] == schema.properties[name]
|
||||||
|
|
||||||
|
|
||||||
|
class TestSchemaUnmarshal(object):
|
||||||
|
|
||||||
|
def test_string_valid(self):
|
||||||
|
schema = Schema('string')
|
||||||
|
value = 'test'
|
||||||
|
|
||||||
|
result = schema.unmarshal(value)
|
||||||
|
|
||||||
|
assert result == value
|
||||||
|
|
||||||
|
def test_string_none(self):
|
||||||
|
schema = Schema('string')
|
||||||
|
value = None
|
||||||
|
|
||||||
|
with pytest.raises(InvalidValueType):
|
||||||
|
schema.unmarshal(value)
|
||||||
|
|
||||||
|
def test_string_default(self):
|
||||||
|
default_value = 'default'
|
||||||
|
schema = Schema('string', default=default_value)
|
||||||
|
value = None
|
||||||
|
|
||||||
|
with pytest.raises(InvalidValueType):
|
||||||
|
schema.unmarshal(value)
|
||||||
|
|
||||||
|
def test_string_default_nullable(self):
|
||||||
|
default_value = 'default'
|
||||||
|
schema = Schema('string', default=default_value, nullable=True)
|
||||||
|
value = None
|
||||||
|
|
||||||
|
result = schema.unmarshal(value)
|
||||||
|
|
||||||
|
assert result == default_value
|
||||||
|
|
||||||
|
def test_integer_valid(self):
|
||||||
|
schema = Schema('integer')
|
||||||
|
value = '123'
|
||||||
|
|
||||||
|
result = schema.unmarshal(value)
|
||||||
|
|
||||||
|
assert result == int(value)
|
||||||
|
|
||||||
|
def test_integer_default(self):
|
||||||
|
default_value = '123'
|
||||||
|
schema = Schema('integer', default=default_value)
|
||||||
|
value = None
|
||||||
|
|
||||||
|
with pytest.raises(InvalidValueType):
|
||||||
|
schema.unmarshal(value)
|
||||||
|
|
||||||
|
def test_integer_default_nullable(self):
|
||||||
|
default_value = '123'
|
||||||
|
schema = Schema('integer', default=default_value, nullable=True)
|
||||||
|
value = None
|
||||||
|
|
||||||
|
result = schema.unmarshal(value)
|
||||||
|
|
||||||
|
assert result == default_value
|
||||||
|
|
||||||
|
def test_integer_invalid(self):
|
||||||
|
schema = Schema('integer')
|
||||||
|
value = 'abc'
|
||||||
|
|
||||||
|
with pytest.raises(InvalidValueType):
|
||||||
|
schema.unmarshal(value)
|
||||||
|
|
Loading…
Reference in a new issue