'''Stubs for aiohttp HTTP clients''' from __future__ import absolute_import import asyncio import functools import json from aiohttp import ClientResponse from vcr.request import Request class MockClientResponse(ClientResponse): # TODO: get encoding from header @asyncio.coroutine def json(self, *, encoding='utf-8', loads=json.loads): # NOQA: E999 return loads(self.content.decode(encoding)) @asyncio.coroutine def text(self, encoding='utf-8'): return self.content.decode(encoding) @asyncio.coroutine def release(self): pass def vcr_request(cassette, real_request): @functools.wraps(real_request) @asyncio.coroutine def new_request(self, method, url, **kwargs): headers = kwargs.get('headers') headers = self._prepare_headers(headers) data = kwargs.get('data') vcr_request = Request(method, url, data, headers) if cassette.can_play_response_for(vcr_request): vcr_response = cassette.play_response(vcr_request) response = MockClientResponse(method, vcr_response.get('url')) response.status = vcr_response['status']['code'] response.content = vcr_response['body']['string'] response.reason = vcr_response['status']['message'] response.headers = vcr_response['headers'] response.close() return response if cassette.write_protected and cassette.filter_request(vcr_request): response = MockClientResponse(method, url) response.status = 599 msg = ("No match for the request {!r} was found. Can't overwrite " "existing cassette {!r} in your current record mode {!r}.") msg = msg.format(vcr_request, cassette._path, cassette.record_mode) response.content = msg.encode() response.close() return response response = yield from real_request(self, method, url, **kwargs) # NOQA: E999 vcr_response = { 'status': { 'code': response.status, 'message': response.reason, }, 'headers': dict(response.headers), 'body': {'string': (yield from response.text())}, # NOQA: E999 'url': response.url, } cassette.append(vcr_request, vcr_response) return response return new_request