2016-12-30 19:50:12 +00:00
|
|
|
import pytest
|
2017-01-13 00:54:34 +00:00
|
|
|
from bs4 import BeautifulSoup
|
2016-12-30 19:50:12 +00:00
|
|
|
|
2016-10-14 11:37:40 +01:00
|
|
|
from sanic import Sanic
|
2016-10-14 23:36:58 +01:00
|
|
|
from sanic.response import text
|
2016-10-14 11:37:40 +01:00
|
|
|
from sanic.exceptions import InvalidUsage, ServerError, NotFound
|
|
|
|
|
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
class SanicExceptionTestException(Exception):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='module')
|
|
|
|
def exception_app():
|
|
|
|
app = Sanic('test_exceptions')
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/')
|
|
|
|
def handler(request):
|
|
|
|
return text('OK')
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/error')
|
|
|
|
def handler_error(request):
|
|
|
|
raise ServerError("OK")
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/404')
|
|
|
|
def handler_404(request):
|
|
|
|
raise NotFound("OK")
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/invalid')
|
|
|
|
def handler_invalid(request):
|
|
|
|
raise InvalidUsage("OK")
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2017-05-20 22:43:57 +01:00
|
|
|
@app.route('/abort')
|
|
|
|
def handler_invalid(request):
|
|
|
|
abort(500)
|
|
|
|
raise InvalidUsage("OK")
|
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/divide_by_zero')
|
|
|
|
def handle_unhandled_exception(request):
|
|
|
|
1 / 0
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.route('/error_in_error_handler_handler')
|
|
|
|
def custom_error_handler(request):
|
|
|
|
raise SanicExceptionTestException('Dummy message!')
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
@app.exception(SanicExceptionTestException)
|
|
|
|
def error_in_error_handler_handler(request, exception):
|
|
|
|
1 / 0
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
return app
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2017-03-08 00:22:23 +00:00
|
|
|
def test_catch_exception_list():
|
|
|
|
app = Sanic('exception_list')
|
|
|
|
@app.exception([SanicExceptionTestException, NotFound])
|
|
|
|
def exception_list(request, exception):
|
|
|
|
return text("ok")
|
|
|
|
|
|
|
|
@app.route('/')
|
|
|
|
def exception(request):
|
|
|
|
raise SanicExceptionTestException("You won't see me")
|
|
|
|
|
|
|
|
request, response = app.test_client.get('/random')
|
|
|
|
assert response.text == 'ok'
|
|
|
|
|
|
|
|
request, response = app.test_client.get('/')
|
|
|
|
assert response.text == 'ok'
|
2016-10-14 11:37:40 +01:00
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
def test_no_exception(exception_app):
|
|
|
|
"""Test that a route works without an exception"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get('/')
|
2016-10-14 23:36:58 +01:00
|
|
|
assert response.status == 200
|
|
|
|
assert response.text == 'OK'
|
2016-10-14 11:37:40 +01:00
|
|
|
|
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
def test_server_error_exception(exception_app):
|
|
|
|
"""Test the built-in ServerError exception works"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get('/error')
|
2016-10-14 23:36:58 +01:00
|
|
|
assert response.status == 500
|
2016-10-14 11:37:40 +01:00
|
|
|
|
|
|
|
|
2017-05-20 22:43:57 +01:00
|
|
|
def test_abort(exception_app):
|
2016-12-30 19:50:12 +00:00
|
|
|
"""Test the built-in InvalidUsage exception works"""
|
2017-05-20 22:43:57 +01:00
|
|
|
request, response = exception_app.test_client.get('/abort')
|
|
|
|
assert response.status == 500
|
2016-10-14 23:36:58 +01:00
|
|
|
|
|
|
|
|
2016-12-30 19:50:12 +00:00
|
|
|
def test_not_found_exception(exception_app):
|
|
|
|
"""Test the built-in NotFound exception works"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get('/404')
|
2016-10-14 23:36:58 +01:00
|
|
|
assert response.status == 404
|
2016-12-30 19:50:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_handled_unhandled_exception(exception_app):
|
|
|
|
"""Test that an exception not built into sanic is handled"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get('/divide_by_zero')
|
2016-12-30 19:50:12 +00:00
|
|
|
assert response.status == 500
|
2017-01-13 00:54:34 +00:00
|
|
|
soup = BeautifulSoup(response.body, 'html.parser')
|
|
|
|
assert soup.h1.text == 'Internal Server Error'
|
|
|
|
|
|
|
|
message = " ".join(soup.p.text.split())
|
|
|
|
assert message == (
|
|
|
|
"The server encountered an internal error and "
|
|
|
|
"cannot complete your request.")
|
2016-12-30 19:50:12 +00:00
|
|
|
|
|
|
|
def test_exception_in_exception_handler(exception_app):
|
|
|
|
"""Test that an exception thrown in an error handler is handled"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get(
|
|
|
|
'/error_in_error_handler_handler')
|
2016-12-30 19:50:12 +00:00
|
|
|
assert response.status == 500
|
|
|
|
assert response.body == b'An error occurred while handling an error'
|
2017-01-25 01:18:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_exception_in_exception_handler_debug_off(exception_app):
|
|
|
|
"""Test that an exception thrown in an error handler is handled"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get(
|
|
|
|
'/error_in_error_handler_handler',
|
2017-01-25 01:18:58 +00:00
|
|
|
debug=False)
|
|
|
|
assert response.status == 500
|
|
|
|
assert response.body == b'An error occurred while handling an error'
|
|
|
|
|
|
|
|
|
|
|
|
def test_exception_in_exception_handler_debug_off(exception_app):
|
|
|
|
"""Test that an exception thrown in an error handler is handled"""
|
2017-02-14 19:51:20 +00:00
|
|
|
request, response = exception_app.test_client.get(
|
|
|
|
'/error_in_error_handler_handler',
|
2017-01-25 01:18:58 +00:00
|
|
|
debug=True)
|
|
|
|
assert response.status == 500
|
|
|
|
assert response.body.startswith(b'Exception raised in exception ')
|