diff --git a/sanic/mixins/listeners.py b/sanic/mixins/listeners.py index bcb56988c6..90e4895baa 100644 --- a/sanic/mixins/listeners.py +++ b/sanic/mixins/listeners.py @@ -63,6 +63,12 @@ def register_listener(listener, event): else: return partial(register_listener, event=listener_or_event) + def main_process_start(self, listener): + return self.listener(listener, "main_process_start") + + def main_process_stop(self, listener): + return self.listener(listener, "main_process_stop") + def before_server_start(self, listener): return self.listener(listener, "before_server_start") diff --git a/tests/test_app.py b/tests/test_app.py index 84a41bae07..941556ea4a 100644 --- a/tests/test_app.py +++ b/tests/test_app.py @@ -89,6 +89,20 @@ def test_create_server_main(app, caplog): ) in caplog.record_tuples +def test_create_server_main_convenience(app, caplog): + app.main_process_start(lambda *_: ...) + loop = asyncio.get_event_loop() + with caplog.at_level(logging.INFO): + asyncio_srv_coro = app.create_server(return_asyncio_server=True) + loop.run_until_complete(asyncio_srv_coro) + assert ( + "sanic.root", + 30, + "Listener events for the main process are not available with " + "create_server()", + ) in caplog.record_tuples + + def test_app_loop_not_running(app): with pytest.raises(SanicException) as excinfo: app.loop diff --git a/tests/test_multiprocessing.py b/tests/test_multiprocessing.py index ec29b3aed1..066b89ac9b 100644 --- a/tests/test_multiprocessing.py +++ b/tests/test_multiprocessing.py @@ -131,14 +131,22 @@ def main_process_start(app, loop): def main_process_stop(app, loop): logger.info("main_process_stop") + @app.main_process_start + def main_process_start(app, loop): + logger.info("main_process_start") + + @app.main_process_stop + def main_process_stop(app, loop): + logger.info("main_process_stop") + with caplog.at_level(logging.INFO): app.run(HOST, PORT, workers=num_workers) assert ( caplog.record_tuples.count(("sanic.root", 20, "main_process_start")) - == 1 + == 2 ) assert ( caplog.record_tuples.count(("sanic.root", 20, "main_process_stop")) - == 1 + == 2 )