mirror of
https://github.com/home-assistant/core.git
synced 2025-04-23 00:37:53 +00:00
Support passing callbacks to start.async_at_start (#63473)
* Support passing callbacks to start.async_at_start * Update homeassistant/helpers/start.py Co-authored-by: Franck Nijhof <git@frenck.dev> * Fix imports Co-authored-by: Franck Nijhof <git@frenck.dev>
This commit is contained in:
parent
1b44c25015
commit
6d57dbde68
@ -4,23 +4,24 @@ from __future__ import annotations
|
||||
from collections.abc import Awaitable, Callable
|
||||
|
||||
from homeassistant.const import EVENT_HOMEASSISTANT_START
|
||||
from homeassistant.core import Event, HomeAssistant, callback
|
||||
from homeassistant.core import Event, HassJob, HomeAssistant, callback
|
||||
|
||||
|
||||
@callback
|
||||
def async_at_start(
|
||||
hass: HomeAssistant, at_start_cb: Callable[[HomeAssistant], Awaitable]
|
||||
hass: HomeAssistant, at_start_cb: Callable[[HomeAssistant], Awaitable[None] | None]
|
||||
) -> None:
|
||||
"""Execute something when Home Assistant is started.
|
||||
|
||||
Will execute it now if Home Assistant is already started.
|
||||
"""
|
||||
at_start_job = HassJob(at_start_cb)
|
||||
if hass.is_running:
|
||||
hass.async_create_task(at_start_cb(hass))
|
||||
hass.async_run_hass_job(at_start_job, hass)
|
||||
return
|
||||
|
||||
async def _matched_event(event: Event) -> None:
|
||||
"""Call the callback when Home Assistant started."""
|
||||
await at_start_cb(hass)
|
||||
hass.async_run_hass_job(at_start_job, hass)
|
||||
|
||||
hass.bus.async_listen_once(EVENT_HOMEASSISTANT_START, _matched_event)
|
||||
|
@ -4,8 +4,9 @@ from homeassistant.const import EVENT_HOMEASSISTANT_START
|
||||
from homeassistant.helpers import start
|
||||
|
||||
|
||||
async def test_at_start_when_running(hass):
|
||||
async def test_at_start_when_running_awaitable(hass):
|
||||
"""Test at start when already running."""
|
||||
assert hass.state == core.CoreState.running
|
||||
assert hass.is_running
|
||||
|
||||
calls = []
|
||||
@ -18,8 +19,37 @@ async def test_at_start_when_running(hass):
|
||||
await hass.async_block_till_done()
|
||||
assert len(calls) == 1
|
||||
|
||||
hass.state = core.CoreState.starting
|
||||
assert hass.is_running
|
||||
|
||||
async def test_at_start_when_starting(hass):
|
||||
start.async_at_start(hass, cb_at_start)
|
||||
await hass.async_block_till_done()
|
||||
assert len(calls) == 2
|
||||
|
||||
|
||||
async def test_at_start_when_running_callback(hass):
|
||||
"""Test at start when already running."""
|
||||
assert hass.state == core.CoreState.running
|
||||
assert hass.is_running
|
||||
|
||||
calls = []
|
||||
|
||||
@core.callback
|
||||
def cb_at_start(hass):
|
||||
"""Home Assistant is started."""
|
||||
calls.append(1)
|
||||
|
||||
start.async_at_start(hass, cb_at_start)
|
||||
assert len(calls) == 1
|
||||
|
||||
hass.state = core.CoreState.starting
|
||||
assert hass.is_running
|
||||
|
||||
start.async_at_start(hass, cb_at_start)
|
||||
assert len(calls) == 2
|
||||
|
||||
|
||||
async def test_at_start_when_starting_awaitable(hass):
|
||||
"""Test at start when yet to start."""
|
||||
hass.state = core.CoreState.not_running
|
||||
assert not hass.is_running
|
||||
@ -37,3 +67,24 @@ async def test_at_start_when_starting(hass):
|
||||
hass.bus.async_fire(EVENT_HOMEASSISTANT_START)
|
||||
await hass.async_block_till_done()
|
||||
assert len(calls) == 1
|
||||
|
||||
|
||||
async def test_at_start_when_starting_callback(hass):
|
||||
"""Test at start when yet to start."""
|
||||
hass.state = core.CoreState.not_running
|
||||
assert not hass.is_running
|
||||
|
||||
calls = []
|
||||
|
||||
@core.callback
|
||||
def cb_at_start(hass):
|
||||
"""Home Assistant is started."""
|
||||
calls.append(1)
|
||||
|
||||
start.async_at_start(hass, cb_at_start)
|
||||
await hass.async_block_till_done()
|
||||
assert len(calls) == 0
|
||||
|
||||
hass.bus.async_fire(EVENT_HOMEASSISTANT_START)
|
||||
await hass.async_block_till_done()
|
||||
assert len(calls) == 1
|
||||
|
Loading…
x
Reference in New Issue
Block a user