2017-01-04 06:23:35 +00:00
|
|
|
import signal
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2018-03-16 04:28:52 +00:00
|
|
|
from sanic.testing import HOST, PORT
|
2017-01-04 06:23:35 +00:00
|
|
|
|
|
|
|
AVAILABLE_LISTENERS = [
|
2017-02-11 14:35:44 +00:00
|
|
|
'before_server_start',
|
|
|
|
'after_server_start',
|
|
|
|
'before_server_stop',
|
|
|
|
'after_server_stop'
|
2017-01-04 06:23:35 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def create_listener(listener_name, in_list):
|
|
|
|
async def _listener(app, loop):
|
|
|
|
print('DEBUG MESSAGE FOR PYTEST for {}'.format(listener_name))
|
|
|
|
in_list.insert(0, app.name + listener_name)
|
|
|
|
return _listener
|
|
|
|
|
|
|
|
|
|
|
|
def start_stop_app(random_name_app, **run_kwargs):
|
|
|
|
|
|
|
|
def stop_on_alarm(signum, frame):
|
|
|
|
raise KeyboardInterrupt('SIGINT for sanic to stop gracefully')
|
|
|
|
|
|
|
|
signal.signal(signal.SIGALRM, stop_on_alarm)
|
|
|
|
signal.alarm(1)
|
|
|
|
try:
|
2018-03-16 04:28:52 +00:00
|
|
|
random_name_app.run(HOST, PORT, **run_kwargs)
|
2017-01-04 06:23:35 +00:00
|
|
|
except KeyboardInterrupt:
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('listener_name', AVAILABLE_LISTENERS)
|
2018-08-26 15:43:14 +01:00
|
|
|
def test_single_listener(app, listener_name):
|
2017-01-04 06:23:35 +00:00
|
|
|
"""Test that listeners on their own work"""
|
2018-08-26 15:43:14 +01:00
|
|
|
output = []
|
2017-02-11 14:30:17 +00:00
|
|
|
# Register listener
|
2018-08-26 15:43:14 +01:00
|
|
|
app.listener(listener_name)(
|
2017-02-11 14:30:17 +00:00
|
|
|
create_listener(listener_name, output))
|
2018-08-26 15:43:14 +01:00
|
|
|
start_stop_app(app)
|
|
|
|
assert app.name + listener_name == output.pop()
|
2017-01-04 06:23:35 +00:00
|
|
|
|
|
|
|
|
2018-02-09 22:01:17 +00:00
|
|
|
@pytest.mark.parametrize('listener_name', AVAILABLE_LISTENERS)
|
2018-08-26 15:43:14 +01:00
|
|
|
def test_register_listener(app, listener_name):
|
2018-02-09 22:01:17 +00:00
|
|
|
"""
|
|
|
|
Test that listeners on their own work with
|
|
|
|
app.register_listener method
|
|
|
|
"""
|
2018-08-26 15:43:14 +01:00
|
|
|
output = []
|
2018-02-09 22:01:17 +00:00
|
|
|
# Register listener
|
|
|
|
listener = create_listener(listener_name, output)
|
2018-08-26 15:43:14 +01:00
|
|
|
app.register_listener(listener,
|
2018-02-09 22:01:17 +00:00
|
|
|
event=listener_name)
|
2018-08-26 15:43:14 +01:00
|
|
|
start_stop_app(app)
|
|
|
|
assert app.name + listener_name == output.pop()
|
2018-02-09 22:01:17 +00:00
|
|
|
|
|
|
|
|
2018-08-26 15:43:14 +01:00
|
|
|
def test_all_listeners(app):
|
|
|
|
output = []
|
2017-02-11 14:30:17 +00:00
|
|
|
for listener_name in AVAILABLE_LISTENERS:
|
|
|
|
listener = create_listener(listener_name, output)
|
2018-08-26 15:43:14 +01:00
|
|
|
app.listener(listener_name)(listener)
|
|
|
|
start_stop_app(app)
|
2017-01-04 06:23:35 +00:00
|
|
|
for listener_name in AVAILABLE_LISTENERS:
|
2018-08-26 15:43:14 +01:00
|
|
|
assert app.name + listener_name == output.pop()
|
2017-08-09 06:21:40 +01:00
|
|
|
|
|
|
|
|
2018-08-26 15:43:14 +01:00
|
|
|
async def test_trigger_before_events_create_server(app):
|
2017-08-09 06:21:40 +01:00
|
|
|
|
|
|
|
class MySanicDb:
|
|
|
|
pass
|
|
|
|
|
|
|
|
@app.listener('before_server_start')
|
|
|
|
async def init_db(app, loop):
|
|
|
|
app.db = MySanicDb()
|
|
|
|
|
|
|
|
await app.create_server()
|
|
|
|
|
|
|
|
assert hasattr(app, "db")
|
|
|
|
assert isinstance(app.db, MySanicDb)
|