2017-03-28 10:50:09 +01:00
|
|
|
from sanic import Sanic
|
2017-03-31 08:53:46 +01:00
|
|
|
import asyncio
|
2017-03-28 10:50:09 +01:00
|
|
|
from sanic.response import text
|
2017-03-31 08:53:46 +01:00
|
|
|
from sanic.exceptions import RequestTimeout
|
|
|
|
from sanic.config import Config
|
2016-11-26 04:55:45 +00:00
|
|
|
|
|
|
|
Config.REQUEST_TIMEOUT = 1
|
|
|
|
request_timeout_app = Sanic('test_request_timeout')
|
|
|
|
request_timeout_default_app = Sanic('test_request_timeout_default')
|
|
|
|
|
|
|
|
|
|
|
|
@request_timeout_app.route('/1')
|
|
|
|
async def handler_1(request):
|
2016-12-06 01:44:08 +00:00
|
|
|
await asyncio.sleep(2)
|
2016-11-26 04:55:45 +00:00
|
|
|
return text('OK')
|
|
|
|
|
|
|
|
|
|
|
|
@request_timeout_app.exception(RequestTimeout)
|
|
|
|
def handler_exception(request, exception):
|
|
|
|
return text('Request Timeout from error_handler.', 408)
|
|
|
|
|
|
|
|
|
|
|
|
def test_server_error_request_timeout():
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = request_timeout_app.test_client.get('/1')
|
2016-11-26 04:55:45 +00:00
|
|
|
assert response.status == 408
|
|
|
|
assert response.text == 'Request Timeout from error_handler.'
|
|
|
|
|
|
|
|
|
|
|
|
@request_timeout_default_app.route('/1')
|
|
|
|
async def handler_2(request):
|
2016-12-06 01:44:08 +00:00
|
|
|
await asyncio.sleep(2)
|
2016-11-26 04:55:45 +00:00
|
|
|
return text('OK')
|
|
|
|
|
|
|
|
|
|
|
|
def test_default_server_error_request_timeout():
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = request_timeout_default_app.test_client.get('/1')
|
2016-11-26 04:55:45 +00:00
|
|
|
assert response.status == 408
|
|
|
|
assert response.text == 'Error: Request Timeout'
|