sanic/sanic/testing.py

110 lines
3.6 KiB
Python
Raw Normal View History

2017-04-11 22:02:57 +01:00
import traceback
from json import JSONDecodeError
2017-04-11 22:02:57 +01:00
2017-02-14 19:51:20 +00:00
from sanic.log import log
HOST = '127.0.0.1'
PORT = 42101
2017-03-08 00:39:26 +00:00
class SanicTestClient:
2017-02-14 19:51:20 +00:00
def __init__(self, app):
self.app = app
async def _local_request(self, method, uri, cookies=None, *args, **kwargs):
import aiohttp
if uri.startswith(('http:', 'https:', 'ftp:', 'ftps://' '//')):
url = uri
else:
url = 'http://{host}:{port}{uri}'.format(
host=HOST, port=PORT, uri=uri)
log.info(url)
2017-03-03 16:44:50 +00:00
conn = aiohttp.TCPConnector(verify_ssl=False)
2017-03-03 16:49:35 +00:00
async with aiohttp.ClientSession(
cookies=cookies, connector=conn) as session:
2017-02-14 19:51:20 +00:00
async with getattr(
session, method.lower())(url, *args, **kwargs) as response:
try:
response.text = await response.text()
except UnicodeDecodeError as e:
response.text = None
try:
response.json = await response.json()
2017-06-20 12:22:28 +01:00
except (JSONDecodeError,
UnicodeDecodeError,
aiohttp.ClientResponseError):
response.json = None
2017-02-14 19:51:20 +00:00
response.body = await response.read()
return response
def _sanic_endpoint_test(
self, method='get', uri='/', gather_request=True,
debug=False, server_kwargs={},
*request_args, **request_kwargs):
results = [None, None]
exceptions = []
if gather_request:
def _collect_request(request):
if results[0] is None:
results[0] = request
self.app.request_middleware.appendleft(_collect_request)
@self.app.listener('after_server_start')
async def _collect_response(sanic, loop):
try:
response = await self._local_request(
method, uri, *request_args,
**request_kwargs)
results[-1] = response
except Exception as e:
2017-04-11 22:02:57 +01:00
log.error(
'Exception:\n{}'.format(traceback.format_exc()))
2017-02-23 02:39:14 +00:00
exceptions.append(e)
2017-02-14 19:51:20 +00:00
self.app.stop()
self.app.run(host=HOST, debug=debug, port=PORT, **server_kwargs)
self.app.listeners['after_server_start'].pop()
if exceptions:
raise ValueError("Exception during request: {}".format(exceptions))
if gather_request:
try:
request, response = results
return request, response
except:
raise ValueError(
"Request and response object expected, got ({})".format(
results))
else:
try:
return results[-1]
except:
raise ValueError(
"Request object expected, got ({})".format(results))
def get(self, *args, **kwargs):
return self._sanic_endpoint_test('get', *args, **kwargs)
def post(self, *args, **kwargs):
return self._sanic_endpoint_test('post', *args, **kwargs)
def put(self, *args, **kwargs):
return self._sanic_endpoint_test('put', *args, **kwargs)
def delete(self, *args, **kwargs):
return self._sanic_endpoint_test('delete', *args, **kwargs)
def patch(self, *args, **kwargs):
return self._sanic_endpoint_test('patch', *args, **kwargs)
def options(self, *args, **kwargs):
return self._sanic_endpoint_test('options', *args, **kwargs)
def head(self, *args, **kwargs):
return self._sanic_endpoint_test('head', *args, **kwargs)