Added blueprint exception and middleware support, and tests
This commit is contained in:
		| @@ -1,6 +1,4 @@ | ||||
|  | ||||
|  | ||||
| class BlueprintSetup(): | ||||
| class BlueprintSetup: | ||||
|     """ | ||||
|     """ | ||||
|  | ||||
| @@ -17,26 +15,41 @@ class BlueprintSetup(): | ||||
|         #: blueprint. | ||||
|         self.url_prefix = url_prefix | ||||
|  | ||||
|     def add_url_rule(self, uri, methods=None, handler=None, **options): | ||||
|         """A helper method to register a handler to the application url routes. | ||||
|  | ||||
|     def add_route(self, handler, uri, methods): | ||||
|         """ | ||||
|         A helper method to register a handler to the application url routes. | ||||
|         """ | ||||
|         if self.url_prefix: | ||||
|             uri = self.url_prefix + uri | ||||
|  | ||||
|         self.app.router.add(uri, methods, handler) | ||||
|  | ||||
|     def add_exception(self, handler, *args, **kwargs): | ||||
|         """ | ||||
|         Registers exceptions to sanic | ||||
|         """ | ||||
|         self.app.exception(*args, **kwargs)(handler) | ||||
|  | ||||
| class Blueprint(): | ||||
|     def add_middleware(self, middleware, *args, **kwargs): | ||||
|         """ | ||||
|         Registers middleware to sanic | ||||
|         """ | ||||
|         if args or kwargs: | ||||
|             self.app.middleware(*args, **kwargs)(middleware) | ||||
|         else: | ||||
|             self.app.middleware(middleware) | ||||
|  | ||||
|  | ||||
| class Blueprint: | ||||
|     def __init__(self, name, url_prefix=None): | ||||
|         self.name = name | ||||
|         self.url_prefix = url_prefix | ||||
|         self.deferred_functions = [] | ||||
|  | ||||
|     def record(self, func): | ||||
|         """Registers a callback function that is invoked when the blueprint is | ||||
|         """ | ||||
|         Registers a callback function that is invoked when the blueprint is | ||||
|         registered on the application. | ||||
|  | ||||
|         """ | ||||
|         self.deferred_functions.append(func) | ||||
|  | ||||
| @@ -57,12 +70,30 @@ class Blueprint(): | ||||
|         """ | ||||
|         """ | ||||
|         def decorator(handler): | ||||
|             self.add_url_rule(uri=uri, methods=methods, handler=handler) | ||||
|             self.record(lambda s: s.add_route(handler, uri, methods)) | ||||
|             return handler | ||||
|         return decorator | ||||
|  | ||||
|     def add_url_rule(self, uri, methods=None, handler=None): | ||||
|     def middleware(self, *args, **kwargs): | ||||
|         """ | ||||
|         """ | ||||
|         self.record(lambda s: | ||||
|             s.add_url_rule(uri, methods, handler)) | ||||
|  | ||||
|         def register_middleware(middleware): | ||||
|             self.record(lambda s: s.add_middleware(middleware, *args, **kwargs)) | ||||
|             return middleware | ||||
|  | ||||
|         # Detect which way this was called, @middleware or @middleware('AT') | ||||
|         if len(args) == 1 and len(kwargs) == 0 and callable(args[0]): | ||||
|             args = [] | ||||
|             return register_middleware(args[0]) | ||||
|         else: | ||||
|             return register_middleware | ||||
|  | ||||
|     def exception(self, *args, **kwargs): | ||||
|         """ | ||||
|         """ | ||||
|         def decorator(handler): | ||||
|             self.record(lambda s: s.add_exception(handler, *args, **kwargs)) | ||||
|             return handler | ||||
|         return decorator | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,8 @@ | ||||
| from json import loads as json_loads, dumps as json_dumps | ||||
| from sanic import Sanic | ||||
| from sanic import Blueprint | ||||
| from sanic.blueprints import Blueprint | ||||
| from sanic.response import json, text | ||||
| from sanic.utils import sanic_endpoint_test | ||||
| from sanic.exceptions import SanicException | ||||
| from sanic.exceptions import NotFound, ServerError, InvalidUsage | ||||
|  | ||||
|  | ||||
| # ------------------------------------------------------------ # | ||||
| @@ -58,3 +57,55 @@ def test_several_bp_with_url_prefix(): | ||||
|     request, response = sanic_endpoint_test(app, uri='/test2/') | ||||
|     assert response.text == 'Hello2' | ||||
|  | ||||
|  | ||||
| def test_bp_middleware(): | ||||
|     app = Sanic('test_middleware') | ||||
|     blueprint = Blueprint('test_middleware') | ||||
|  | ||||
|     @blueprint.middleware('response') | ||||
|     async def process_response(request, response): | ||||
|         return text('OK') | ||||
|  | ||||
|     @app.route('/') | ||||
|     async def handler(request): | ||||
|         return text('FAIL') | ||||
|  | ||||
|     app.register_blueprint(blueprint) | ||||
|  | ||||
|     request, response = sanic_endpoint_test(app) | ||||
|  | ||||
|     assert response.status == 200 | ||||
|     assert response.text == 'OK' | ||||
|  | ||||
| def test_bp_exception_handler(): | ||||
|     app = Sanic('test_middleware') | ||||
|     blueprint = Blueprint('test_middleware') | ||||
|  | ||||
|     @blueprint.route('/1') | ||||
|     def handler_1(request): | ||||
|         raise InvalidUsage("OK") | ||||
|  | ||||
|     @blueprint.route('/2') | ||||
|     def handler_2(request): | ||||
|         raise ServerError("OK") | ||||
|  | ||||
|     @blueprint.route('/3') | ||||
|     def handler_3(request): | ||||
|         raise NotFound("OK") | ||||
|  | ||||
|     @blueprint.exception(NotFound, ServerError) | ||||
|     def handler_exception(request, exception): | ||||
|         return text("OK") | ||||
|  | ||||
|     app.register_blueprint(blueprint) | ||||
|  | ||||
|     request, response = sanic_endpoint_test(app, uri='/1') | ||||
|     assert response.status == 400 | ||||
|  | ||||
|  | ||||
|     request, response = sanic_endpoint_test(app, uri='/2') | ||||
|     assert response.status == 200 | ||||
|     assert response.text == 'OK' | ||||
|  | ||||
|     request, response = sanic_endpoint_test(app, uri='/3') | ||||
|     assert response.status == 200 | ||||
		Reference in New Issue
	
	Block a user
	 Channel Cat
					Channel Cat