mirror of
https://github.com/correl/openapi-core.git
synced 2024-11-22 03:00:10 +00:00
Merge pull request #303 from p1c2u/feature/deserialize-data-form-media-type
deserialize data form media type
This commit is contained in:
commit
cfe4a7ce4e
3 changed files with 49 additions and 5 deletions
|
@ -1,4 +1,6 @@
|
||||||
from openapi_core.deserializing.media_types.util import json_loads, form_loads
|
from openapi_core.deserializing.media_types.util import (
|
||||||
|
json_loads, urlencoded_form_loads, data_form_loads,
|
||||||
|
)
|
||||||
|
|
||||||
from openapi_core.deserializing.media_types.deserializers import (
|
from openapi_core.deserializing.media_types.deserializers import (
|
||||||
PrimitiveDeserializer,
|
PrimitiveDeserializer,
|
||||||
|
@ -9,7 +11,8 @@ class MediaTypeDeserializersFactory(object):
|
||||||
|
|
||||||
MEDIA_TYPE_DESERIALIZERS = {
|
MEDIA_TYPE_DESERIALIZERS = {
|
||||||
'application/json': json_loads,
|
'application/json': json_loads,
|
||||||
'application/x-www-form-urlencoded': form_loads,
|
'application/x-www-form-urlencoded': urlencoded_form_loads,
|
||||||
|
'multipart/form-data': data_form_loads,
|
||||||
}
|
}
|
||||||
|
|
||||||
def __init__(self, custom_deserializers=None):
|
def __init__(self, custom_deserializers=None):
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
from email.parser import Parser
|
||||||
from json import loads
|
from json import loads
|
||||||
|
|
||||||
from six import binary_type
|
from six import binary_type
|
||||||
|
@ -11,5 +12,19 @@ def json_loads(value):
|
||||||
return loads(value)
|
return loads(value)
|
||||||
|
|
||||||
|
|
||||||
def form_loads(value):
|
def urlencoded_form_loads(value):
|
||||||
return dict(parse_qsl(value))
|
return dict(parse_qsl(value))
|
||||||
|
|
||||||
|
|
||||||
|
def data_form_loads(value):
|
||||||
|
if issubclass(type(value), binary_type):
|
||||||
|
value = value.decode('ASCII', errors='surrogateescape')
|
||||||
|
parser = Parser()
|
||||||
|
parts = parser.parsestr(value, headersonly=False)
|
||||||
|
return dict(
|
||||||
|
(
|
||||||
|
part.get_param('name', header='content-disposition'),
|
||||||
|
part.get_payload(decode=True),
|
||||||
|
)
|
||||||
|
for part in parts.get_payload()
|
||||||
|
)
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
|
from six import b, u
|
||||||
|
|
||||||
from openapi_core.deserializing.exceptions import DeserializeError
|
from openapi_core.deserializing.exceptions import DeserializeError
|
||||||
from openapi_core.deserializing.media_types.factories import (
|
from openapi_core.deserializing.media_types.factories import (
|
||||||
MediaTypeDeserializersFactory,
|
MediaTypeDeserializersFactory,
|
||||||
|
@ -31,7 +33,7 @@ class TestMediaTypeDeserializer(object):
|
||||||
|
|
||||||
assert result == {}
|
assert result == {}
|
||||||
|
|
||||||
def test_form_urlencoded_empty(self, deserializer_factory):
|
def test_urlencoded_form_empty(self, deserializer_factory):
|
||||||
media_type = MediaType('application/x-www-form-urlencoded')
|
media_type = MediaType('application/x-www-form-urlencoded')
|
||||||
value = ''
|
value = ''
|
||||||
|
|
||||||
|
@ -39,7 +41,7 @@ class TestMediaTypeDeserializer(object):
|
||||||
|
|
||||||
assert result == {}
|
assert result == {}
|
||||||
|
|
||||||
def test_form_urlencoded_simple(self, deserializer_factory):
|
def test_urlencoded_form_simple(self, deserializer_factory):
|
||||||
media_type = MediaType('application/x-www-form-urlencoded')
|
media_type = MediaType('application/x-www-form-urlencoded')
|
||||||
value = 'param1=test'
|
value = 'param1=test'
|
||||||
|
|
||||||
|
@ -47,6 +49,30 @@ class TestMediaTypeDeserializer(object):
|
||||||
|
|
||||||
assert result == {'param1': 'test'}
|
assert result == {'param1': 'test'}
|
||||||
|
|
||||||
|
@pytest.mark.parametrize('value', [b(''), u('')])
|
||||||
|
def test_data_form_empty(self, deserializer_factory, value):
|
||||||
|
media_type = MediaType('multipart/form-data')
|
||||||
|
|
||||||
|
result = deserializer_factory(media_type)(value)
|
||||||
|
|
||||||
|
assert result == {}
|
||||||
|
|
||||||
|
def test_data_form_simple(self, deserializer_factory):
|
||||||
|
media_type = MediaType('multipart/form-data')
|
||||||
|
value = b(
|
||||||
|
'Content-Type: multipart/form-data; boundary="'
|
||||||
|
'===============2872712225071193122=="\n'
|
||||||
|
'MIME-Version: 1.0\n\n'
|
||||||
|
'--===============2872712225071193122==\n'
|
||||||
|
'Content-Type: text/plain\nMIME-Version: 1.0\n'
|
||||||
|
'Content-Disposition: form-data; name="param1"\n\ntest\n'
|
||||||
|
'--===============2872712225071193122==--\n'
|
||||||
|
)
|
||||||
|
|
||||||
|
result = deserializer_factory(media_type)(value)
|
||||||
|
|
||||||
|
assert result == {'param1': b('test')}
|
||||||
|
|
||||||
def test_custom_simple(self, deserializer_factory):
|
def test_custom_simple(self, deserializer_factory):
|
||||||
custom_mimetype = 'application/custom'
|
custom_mimetype = 'application/custom'
|
||||||
media_type = MediaType(custom_mimetype)
|
media_type = MediaType(custom_mimetype)
|
||||||
|
|
Loading…
Reference in a new issue