100% Coverage for Sanic Blueprint (#1419)
* add unit tests to completely cover blueprints Signed-off-by: Harsha Narayana <harsha2k4@gmail.com> * fix typo in the unit test code Signed-off-by: Harsha Narayana <harsha2k4@gmail.com>
This commit is contained in:
parent
822ced6294
commit
aa0874b6d8
@ -1,18 +1,31 @@
|
|||||||
import asyncio
|
import asyncio
|
||||||
import inspect
|
import inspect
|
||||||
import os
|
import os
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
|
from sanic.app import Sanic
|
||||||
from sanic.blueprints import Blueprint
|
from sanic.blueprints import Blueprint
|
||||||
from sanic.response import text
|
|
||||||
from sanic.exceptions import NotFound, ServerError, InvalidUsage
|
|
||||||
from sanic.constants import HTTP_METHODS
|
from sanic.constants import HTTP_METHODS
|
||||||
|
from sanic.exceptions import NotFound, ServerError, InvalidUsage
|
||||||
|
from sanic.request import Request
|
||||||
|
from sanic.response import text, json
|
||||||
|
from sanic.views import CompositionView
|
||||||
|
|
||||||
|
|
||||||
# ------------------------------------------------------------ #
|
# ------------------------------------------------------------ #
|
||||||
# GET
|
# GET
|
||||||
# ------------------------------------------------------------ #
|
# ------------------------------------------------------------ #
|
||||||
|
|
||||||
|
@pytest.fixture(scope='module')
|
||||||
|
def static_file_directory():
|
||||||
|
"""The static directory to serve"""
|
||||||
|
current_file = inspect.getfile(inspect.currentframe())
|
||||||
|
current_directory = os.path.dirname(os.path.abspath(current_file))
|
||||||
|
static_directory = os.path.join(current_directory, 'static')
|
||||||
|
return static_directory
|
||||||
|
|
||||||
|
|
||||||
def get_file_path(static_file_directory, file_name):
|
def get_file_path(static_file_directory, file_name):
|
||||||
return os.path.join(static_file_directory, file_name)
|
return os.path.join(static_file_directory, file_name)
|
||||||
|
|
||||||
@ -36,7 +49,7 @@ def test_versioned_routes_get(app, method):
|
|||||||
return text('OK')
|
return text('OK')
|
||||||
else:
|
else:
|
||||||
print(func)
|
print(func)
|
||||||
raise
|
raise Exception("{} is not callable".format(func))
|
||||||
|
|
||||||
app.blueprint(bp)
|
app.blueprint(bp)
|
||||||
|
|
||||||
@ -414,7 +427,7 @@ def test_bp_shorthand(app):
|
|||||||
assert request.stream is None
|
assert request.stream is None
|
||||||
return text('OK')
|
return text('OK')
|
||||||
|
|
||||||
@blueprint.websocket('/ws')
|
@blueprint.websocket('/ws/', strict_slashes=True)
|
||||||
async def websocket_handler(request, ws):
|
async def websocket_handler(request, ws):
|
||||||
assert request.stream is None
|
assert request.stream is None
|
||||||
ev.set()
|
ev.set()
|
||||||
@ -465,7 +478,7 @@ def test_bp_shorthand(app):
|
|||||||
request, response = app.test_client.get('/delete')
|
request, response = app.test_client.get('/delete')
|
||||||
assert response.status == 405
|
assert response.status == 405
|
||||||
|
|
||||||
request, response = app.test_client.get('/ws', headers={
|
request, response = app.test_client.get('/ws/', headers={
|
||||||
'Upgrade': 'websocket',
|
'Upgrade': 'websocket',
|
||||||
'Connection': 'upgrade',
|
'Connection': 'upgrade',
|
||||||
'Sec-WebSocket-Key': 'dGhlIHNhbXBsZSBub25jZQ==',
|
'Sec-WebSocket-Key': 'dGhlIHNhbXBsZSBub25jZQ==',
|
||||||
@ -515,7 +528,6 @@ def test_bp_group(app):
|
|||||||
|
|
||||||
|
|
||||||
def test_bp_group_with_default_url_prefix(app):
|
def test_bp_group_with_default_url_prefix(app):
|
||||||
|
|
||||||
from sanic.response import json
|
from sanic.response import json
|
||||||
bp_resources = Blueprint('bp_resources')
|
bp_resources = Blueprint('bp_resources')
|
||||||
|
|
||||||
@ -555,3 +567,109 @@ def test_bp_group_with_default_url_prefix(app):
|
|||||||
request, response = app.test_client.get(
|
request, response = app.test_client.get(
|
||||||
'/api/v1/resources/{0}'.format(resource_id))
|
'/api/v1/resources/{0}'.format(resource_id))
|
||||||
assert response.json == {'resource_id': resource_id}
|
assert response.json == {'resource_id': resource_id}
|
||||||
|
|
||||||
|
|
||||||
|
def test_blueprint_middleware_with_args(app: Sanic):
|
||||||
|
bp = Blueprint(name="with_args_bp", url_prefix="/wa")
|
||||||
|
|
||||||
|
@bp.middleware
|
||||||
|
def middleware_with_no_tag(request: Request):
|
||||||
|
if request.headers.get("content-type") == "application/json":
|
||||||
|
request.headers["accepts"] = "plain/text"
|
||||||
|
else:
|
||||||
|
request.headers["accepts"] = "application/json"
|
||||||
|
|
||||||
|
@bp.route("/")
|
||||||
|
def default_route(request):
|
||||||
|
if request.headers.get("accepts") == "application/json":
|
||||||
|
return json({"test": "value"})
|
||||||
|
else:
|
||||||
|
return text("value")
|
||||||
|
|
||||||
|
app.blueprint(bp)
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/wa", headers={"content-type": "application/json"})
|
||||||
|
assert response.text == "value"
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/wa", headers={"content-type": "plain/text"})
|
||||||
|
assert response.json.get("test") == "value"
|
||||||
|
d = {}
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.parametrize('file_name',
|
||||||
|
['test.file'])
|
||||||
|
def test_static_blueprint_name(app: Sanic, static_file_directory, file_name):
|
||||||
|
current_file = inspect.getfile(inspect.currentframe())
|
||||||
|
with open(current_file, 'rb') as file:
|
||||||
|
current_file_contents = file.read()
|
||||||
|
|
||||||
|
bp = Blueprint(name="static", url_prefix="/static", strict_slashes=False)
|
||||||
|
|
||||||
|
bp.static(
|
||||||
|
"/test.file/",
|
||||||
|
get_file_path(static_file_directory, file_name),
|
||||||
|
name="static.testing",
|
||||||
|
strict_slashes=True)
|
||||||
|
|
||||||
|
app.blueprint(bp)
|
||||||
|
|
||||||
|
uri = app.url_for('static', name='static.testing')
|
||||||
|
assert uri == "/static/test.file"
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/static/test.file")
|
||||||
|
assert response.status == 404
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/static/test.file/")
|
||||||
|
assert response.status == 200
|
||||||
|
|
||||||
|
|
||||||
|
def test_route_handler_add(app: Sanic):
|
||||||
|
view = CompositionView()
|
||||||
|
|
||||||
|
async def get_handler(request):
|
||||||
|
return json({
|
||||||
|
"response": "OK"
|
||||||
|
})
|
||||||
|
|
||||||
|
view.add(["GET"], get_handler, stream=False)
|
||||||
|
|
||||||
|
async def default_handler(request):
|
||||||
|
return text("OK")
|
||||||
|
|
||||||
|
bp = Blueprint(name="handler", url_prefix="/handler")
|
||||||
|
bp.add_route(
|
||||||
|
default_handler,
|
||||||
|
uri="/default/",
|
||||||
|
strict_slashes=True)
|
||||||
|
|
||||||
|
bp.add_route(view, uri="/view", name="test")
|
||||||
|
|
||||||
|
app.blueprint(bp)
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/handler/default/")
|
||||||
|
assert response.text == "OK"
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/handler/view")
|
||||||
|
assert response.json["response"] == "OK"
|
||||||
|
|
||||||
|
|
||||||
|
def test_websocket_route(app: Sanic):
|
||||||
|
event = asyncio.Event()
|
||||||
|
|
||||||
|
async def websocket_handler(request, ws):
|
||||||
|
assert ws.subprotocol is None
|
||||||
|
event.set()
|
||||||
|
|
||||||
|
bp = Blueprint(name="handler", url_prefix="/ws")
|
||||||
|
bp.add_websocket_route(websocket_handler, "/test", name="test")
|
||||||
|
|
||||||
|
app.blueprint(bp)
|
||||||
|
|
||||||
|
_, response = app.test_client.get("/ws/test", headers={
|
||||||
|
'Upgrade': 'websocket',
|
||||||
|
'Connection': 'upgrade',
|
||||||
|
'Sec-WebSocket-Key': 'dGhlIHNhbXBsZSBub25jZQ==',
|
||||||
|
'Sec-WebSocket-Version': '13'
|
||||||
|
})
|
||||||
|
assert response.status == 101
|
||||||
|
assert event.is_set()
|
||||||
|
1
tox.ini
1
tox.ini
@ -20,6 +20,7 @@ commands =
|
|||||||
pytest tests --cov sanic --cov-report= {posargs}
|
pytest tests --cov sanic --cov-report= {posargs}
|
||||||
- coverage combine --append
|
- coverage combine --append
|
||||||
coverage report -m
|
coverage report -m
|
||||||
|
coverage html -i
|
||||||
|
|
||||||
[testenv:lint]
|
[testenv:lint]
|
||||||
deps =
|
deps =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user