Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Requests chunk encoded request handling#556

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to ourterms of service andprivacy statement. We’ll occasionally send you account related emails.

Already on GitHub?Sign in to your account

Open
p1c2u wants to merge1 commit intomaster
base:master
Choose a base branch
Loading
fromfix/contrib-requests-chunk-encoded-request-handling-fix
Open
Show file tree
Hide file tree
Changes fromall commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 24 additions & 5 deletionsopenapi_core/contrib/requests/requests.py
View file
Open in desktop
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
"""OpenAPI core contrib requests requests module"""
from typing import Mapping
from typing import Optional
from typing import Union
from urllib.parse import parse_qs
Expand All@@ -7,6 +8,7 @@
from requests import PreparedRequest
from requests import Request
from requests.cookies import RequestsCookieJar
from requests.utils import rewind_body
from werkzeug.datastructures import Headers
from werkzeug.datastructures import ImmutableMultiDict

Expand All@@ -28,7 +30,9 @@ def __init__(self, request: Union[Request, PreparedRequest]):
"'request' argument is not type of "
f"{Request} or {PreparedRequest}"
)
self._request = None
if isinstance(request, Request):
self._request = request
request = request.prepare()

self.request = request
Expand DownExpand Up@@ -65,13 +69,28 @@ def method(self) -> str:

@property
def body(self) -> Optional[str]:
if self.request.body is None:
import ipdb; ipdb.set_trace()
body = self.request.body
if body is None:
return None
if isinstance(self.request.body, bytes):
return self.request.body.decode("utf-8")
assert isinstance(self.request.body, str)
chunks = None
is_stream = all(
[
hasattr(body, "__iter__"),
not isinstance(body, (bytes, str, list, tuple, Mapping)),
]
)
if is_stream:
chunks = list(body)
body = b"".join(chunks)
if isinstance(body, bytes):
body = body.decode("utf-8")
assert isinstance(body, str)
# recreate request stream from evaluated chunks
if chunks is not None:
self.request.body = (x for x in chunks)
# TODO: figure out if request._body_position is relevant
returnself.request.body
return body

@property
def mimetype(self) -> str:
Expand Down
View file
Open in desktop
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,5 @@
from types import GeneratorType

import pytest
import requests
import responses
Expand All@@ -9,6 +11,8 @@
from openapi_core.contrib.requests import RequestsOpenAPIRequest
from openapi_core.contrib.requests import RequestsOpenAPIResponse
from openapi_core.contrib.requests import RequestsOpenAPIWebhookRequest
from openapi_core.datatypes import Parameters
from openapi_core.datatypes import RequestParameters


class TestRequestsOpenAPIValidation:
Expand DownExpand Up@@ -72,6 +76,36 @@ def test_request_validator_path_pattern(self, request_unmarshaller):
result = request_unmarshaller.unmarshal(openapi_request)
assert not result.errors

def test_request_validator_encoded_chunks(self, request_unmarshaller):
request_chunks = [
b'{',
b'"param1": 1',
b'}',
]
def gen():
for chunk in request_chunks:
yield chunk

request = requests.Request(
"POST",
"http://localhost/browse/12/",
params={"q": "string"},
headers={"content-type": "application/json"},
data=gen(),
)
openapi_request = RequestsOpenAPIRequest(request)
result = request_unmarshaller.unmarshal(openapi_request)
assert not result.errors
assert result.body == {"param1": 1}
assert result.parameters == Parameters(
query={"q": "string"},
header={},
cookie={},
path={"id": 12},
)
assert isinstance(request.data, GeneratorType)
assert list(request.data) == request_chunks

def test_request_validator_prepared_request(self, request_unmarshaller):
request = requests.Request(
"POST",
Expand Down

[8]ページ先頭

©2009-2025 Movatter.jp