mirror of
https://github.com/correl/openapi-core.git
synced 2024-12-29 11:09:25 +00:00
Merge pull request #239 from p1c2u/fix/unmarshalling-nullable-objects-fix
Unmarshalling nullable objects
This commit is contained in:
commit
39688c7252
2 changed files with 21 additions and 2 deletions
|
@ -157,9 +157,16 @@ class ObjectUnmarshaller(ComplexUnmarshaller):
|
|||
def model_factory(self):
|
||||
return ModelFactory()
|
||||
|
||||
def __call__(self, value=NoValue):
|
||||
value = super(ObjectUnmarshaller, self).__call__(value)
|
||||
def unmarshal(self, value):
|
||||
try:
|
||||
value = self.formatter.unmarshal(value)
|
||||
except ValueError as exc:
|
||||
raise InvalidSchemaFormatValue(
|
||||
value, self.schema.format, exc)
|
||||
else:
|
||||
return self._unmarshal_object(value)
|
||||
|
||||
def _unmarshal_object(self, value=NoValue):
|
||||
if self.schema.one_of:
|
||||
properties = None
|
||||
for one_of_schema in self.schema.one_of:
|
||||
|
|
|
@ -408,6 +408,18 @@ class TestSchemaUnmarshallerCall(object):
|
|||
|
||||
assert result == 1.2
|
||||
|
||||
def test_object_nullable(self, unmarshaller_factory):
|
||||
schema = Schema(
|
||||
'object',
|
||||
properties={
|
||||
'foo': Schema('object', nullable=True),
|
||||
},
|
||||
)
|
||||
value = {'foo': None}
|
||||
result = unmarshaller_factory(schema)(value)
|
||||
|
||||
assert result == {'foo': None}
|
||||
|
||||
def test_schema_any_one_of(self, unmarshaller_factory):
|
||||
schema = Schema(one_of=[
|
||||
Schema('string'),
|
||||
|
|
Loading…
Reference in a new issue