2018-10-09 14:47:51 +00:00
|
|
|
|
|
|
|
Starlette applications can register multiple event handlers for dealing with
|
2018-10-20 12:53:11 +00:00
|
|
|
code that needs to run before the application starts up, or when the application
|
2018-10-09 14:47:51 +00:00
|
|
|
is shutting down.
|
|
|
|
|
|
|
|
## Registering events
|
|
|
|
|
|
|
|
These event handlers can either be `async` coroutines, or regular syncronous
|
|
|
|
functions.
|
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
The event handlers should be included on the application like so:
|
2018-10-09 14:47:51 +00:00
|
|
|
|
|
|
|
```python
|
|
|
|
from starlette.applications import Starlette
|
|
|
|
|
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
async def some_startup_task():
|
|
|
|
pass
|
2018-10-09 14:47:51 +00:00
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
async def some_shutdown_task():
|
|
|
|
pass
|
2018-10-21 07:37:29 +00:00
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
routes = [
|
2018-10-21 07:37:29 +00:00
|
|
|
...
|
2019-11-13 12:25:18 +00:00
|
|
|
]
|
2018-10-21 07:37:29 +00:00
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
app = Starlette(
|
|
|
|
routes=routes,
|
|
|
|
on_startup=[some_startup_task],
|
|
|
|
on_shutdown=[some_shutdown_task]
|
|
|
|
)
|
2018-10-09 14:47:51 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Starlette will not start serving any incoming requests until all of the
|
|
|
|
registered startup handlers have completed.
|
|
|
|
|
2018-10-22 14:08:04 +00:00
|
|
|
The shutdown handlers will run once all connections have been closed, and
|
2018-10-09 14:47:51 +00:00
|
|
|
any in-process background tasks have completed.
|
|
|
|
|
2018-12-04 20:21:36 +00:00
|
|
|
## Running event handlers in tests
|
2018-10-09 14:47:51 +00:00
|
|
|
|
|
|
|
You might want to explicitly call into your event handlers in any test setup
|
|
|
|
or test teardown code.
|
|
|
|
|
2018-11-28 11:49:28 +00:00
|
|
|
Alternatively, you can use `TestClient` as a context manager, to ensure that
|
|
|
|
startup and shutdown events are called.
|
2018-10-09 14:47:51 +00:00
|
|
|
|
|
|
|
```python
|
|
|
|
from example import app
|
|
|
|
from starlette.testclient import TestClient
|
|
|
|
|
|
|
|
|
|
|
|
def test_homepage():
|
2018-11-28 11:49:28 +00:00
|
|
|
with TestClient(app) as client:
|
2019-11-13 12:25:18 +00:00
|
|
|
# Application 'on_startup' handlers are called on entering the block.
|
2018-10-09 14:47:51 +00:00
|
|
|
response = client.get("/")
|
|
|
|
assert response.status_code == 200
|
|
|
|
|
2019-11-13 12:25:18 +00:00
|
|
|
# Application 'on_shutdown' handlers are called on exiting the block.
|
2018-10-09 14:47:51 +00:00
|
|
|
```
|