2017-04-11 22:02:57 +01:00
|
|
|
import traceback
|
2017-06-07 09:57:07 +01:00
|
|
|
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:
|
2017-03-23 07:22:00 +00:00
|
|
|
try:
|
|
|
|
response.text = await response.text()
|
|
|
|
except UnicodeDecodeError as e:
|
|
|
|
response.text = None
|
2017-06-07 09:57:07 +01:00
|
|
|
|
|
|
|
try:
|
|
|
|
response.json = await response.json()
|
2017-06-20 12:22:28 +01:00
|
|
|
except (JSONDecodeError,
|
|
|
|
UnicodeDecodeError,
|
|
|
|
aiohttp.ClientResponseError):
|
2017-06-07 09:57:07 +01:00
|
|
|
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)
|