mirror of
https://github.com/kevin1024/vcrpy.git
synced 2025-12-09 09:13:23 +00:00
Drop support to asyncio.coroutine (py34 async/await syntax)
This commit is contained in:
@@ -2,23 +2,32 @@
|
|||||||
import asyncio
|
import asyncio
|
||||||
|
|
||||||
import aiohttp
|
import aiohttp
|
||||||
|
from aiohttp.test_utils import TestClient
|
||||||
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
async def aiohttp_request(loop, method, url, output='text', encoding='utf-8', content_type=None, **kwargs):
|
||||||
def aiohttp_request(loop, method, url, output='text', encoding='utf-8', content_type=None, **kwargs):
|
|
||||||
session = aiohttp.ClientSession(loop=loop)
|
session = aiohttp.ClientSession(loop=loop)
|
||||||
response_ctx = session.request(method, url, **kwargs)
|
response_ctx = session.request(method, url, **kwargs)
|
||||||
|
|
||||||
response = yield from response_ctx.__aenter__()
|
response = await response_ctx.__aenter__()
|
||||||
if output == 'text':
|
if output == 'text':
|
||||||
content = yield from response.text()
|
content = await response.text()
|
||||||
elif output == 'json':
|
elif output == 'json':
|
||||||
content_type = content_type or 'application/json'
|
content_type = content_type or 'application/json'
|
||||||
content = yield from response.json(encoding=encoding, content_type=content_type)
|
content = await response.json(encoding=encoding, content_type=content_type)
|
||||||
elif output == 'raw':
|
elif output == 'raw':
|
||||||
content = yield from response.read()
|
content = await response.read()
|
||||||
|
|
||||||
response_ctx._resp.close()
|
response_ctx._resp.close()
|
||||||
yield from session.close()
|
await session.close()
|
||||||
|
|
||||||
return response, content
|
return response, content
|
||||||
|
|
||||||
|
|
||||||
|
def aiohttp_app():
|
||||||
|
async def hello(request):
|
||||||
|
return aiohttp.web.Response(text='hello')
|
||||||
|
|
||||||
|
app = aiohttp.web.Application()
|
||||||
|
app.router.add_get('/', hello)
|
||||||
|
return app
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ asyncio = pytest.importorskip("asyncio")
|
|||||||
aiohttp = pytest.importorskip("aiohttp")
|
aiohttp = pytest.importorskip("aiohttp")
|
||||||
|
|
||||||
import vcr # noqa: E402
|
import vcr # noqa: E402
|
||||||
from .aiohttp_utils import aiohttp_request # noqa: E402
|
from .aiohttp_utils import aiohttp_app, aiohttp_request # noqa: E402
|
||||||
|
|
||||||
|
|
||||||
def run_in_loop(fn):
|
def run_in_loop(fn):
|
||||||
@@ -156,13 +156,24 @@ def test_params_on_url(tmpdir, scheme):
|
|||||||
assert cassette.play_count == 1
|
assert cassette.play_count == 1
|
||||||
|
|
||||||
|
|
||||||
async def test_aiohttp_client_does_not_break_with_patching_request(aiohttp_client, tmpdir):
|
def test_aiohttp_test_client(aiohttp_client, tmpdir):
|
||||||
async def hello(request):
|
loop = asyncio.get_event_loop()
|
||||||
return aiohttp.web.Response(text='Hello, world')
|
app = aiohttp_app()
|
||||||
|
url = '/'
|
||||||
app = aiohttp.web.Application()
|
client = loop.run_until_complete(aiohttp_client(app))
|
||||||
app.router.add_get('/', hello)
|
|
||||||
client = await aiohttp_client(app)
|
|
||||||
|
|
||||||
with vcr.use_cassette(str(tmpdir.join('get.yaml'))):
|
with vcr.use_cassette(str(tmpdir.join('get.yaml'))):
|
||||||
await client.get('/')
|
response = loop.run_until_complete(client.get(url))
|
||||||
|
|
||||||
|
assert response.status == 200
|
||||||
|
response_text = loop.run_until_complete(response.text())
|
||||||
|
assert response_text == 'hello'
|
||||||
|
|
||||||
|
with vcr.use_cassette(str(tmpdir.join('get.yaml'))) as cassette:
|
||||||
|
response = loop.run_until_complete(client.get(url))
|
||||||
|
|
||||||
|
request = cassette.requests[0]
|
||||||
|
assert request.url == str(client.make_url(url))
|
||||||
|
response_text = loop.run_until_complete(response.text())
|
||||||
|
assert response_text == 'hello'
|
||||||
|
assert cassette.play_count == 1
|
||||||
|
|||||||
@@ -1,7 +1,3 @@
|
|||||||
import asyncio
|
async def handle_coroutine(vcr, fn): # noqa: E999
|
||||||
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def handle_coroutine(vcr, fn):
|
|
||||||
with vcr as cassette:
|
with vcr as cassette:
|
||||||
return (yield from fn(cassette)) # noqa: E999
|
return (await fn(cassette)) # noqa: E999
|
||||||
|
|||||||
@@ -25,21 +25,16 @@ class MockClientResponse(ClientResponse):
|
|||||||
session=None,
|
session=None,
|
||||||
)
|
)
|
||||||
|
|
||||||
# TODO: get encoding from header
|
async def json(self, *, encoding='utf-8', loads=json.loads, **kwargs): # NOQA: E999
|
||||||
@asyncio.coroutine
|
|
||||||
def json(self, *, encoding='utf-8', loads=json.loads, **kwargs): # NOQA: E999
|
|
||||||
return loads(self._body.decode(encoding))
|
return loads(self._body.decode(encoding))
|
||||||
|
|
||||||
@asyncio.coroutine
|
async def text(self, encoding='utf-8'):
|
||||||
def text(self, encoding='utf-8'):
|
|
||||||
return self._body.decode(encoding)
|
return self._body.decode(encoding)
|
||||||
|
|
||||||
@asyncio.coroutine
|
async def read(self):
|
||||||
def read(self):
|
|
||||||
return self._body
|
return self._body
|
||||||
|
|
||||||
@asyncio.coroutine
|
async def release(self):
|
||||||
def release(self):
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user