* Upgrade pytest-aiohttp * Make sure executors, tasks and timers are closed Some test will trigger warnings on garbage collect, these warnings spills over into next test. Some test trigger tasks that raise errors on shutdown, these spill over into next test. This is to mimic older pytest-aiohttp and it's behaviour on test cleanup. Discussions on similar changes for pytest-aiohttp are here: https://github.com/pytest-dev/pytest-asyncio/pull/309 * Replace loop with event_loop * Make sure time is frozen for tests * Make sure the ConditionType is not async /home-assistant/homeassistant/helpers/template.py:2082: RuntimeWarning: coroutine 'AsyncMockMixin._execute_mock_call' was never awaited def wrapper(*args, **kwargs): Enable tracemalloc to get traceback where the object was allocated. See https://docs.pytest.org/en/stable/how-to/capture-warnings.html#resource-warnings for more info. * Increase litejet press tests with a factor 10 The times are simulated anyway, and we can't stop the normal event from occuring. * Use async handlers for aiohttp tests/components/motioneye/test_camera.py::test_get_still_image_from_camera tests/components/motioneye/test_camera.py::test_get_still_image_from_camera tests/components/motioneye/test_camera.py::test_get_stream_from_camera tests/components/motioneye/test_camera.py::test_get_stream_from_camera tests/components/motioneye/test_camera.py::test_camera_option_stream_url_template tests/components/motioneye/test_camera.py::test_camera_option_stream_url_template /Users/joakim/src/hass/home-assistant/venv/lib/python3.9/site-packages/aiohttp/web_urldispatcher.py:189: DeprecationWarning: Bare functions are deprecated, use async ones warnings.warn( * Switch to freezegun in modbus tests The tests allowed clock to tick in between steps * Make sure skybell object are fully mocked Old tests would trigger attempts to post to could services: ``` DEBUG:aioskybell:HTTP post https://cloud.myskybell.com/api/v3/login/ Request with headers: {'content-type': 'application/json', 'accept': '*/*', 'x-skybell-app-id': 'd2b542c7-a7e4-4e1e-b77d-2b76911c7c46', 'x-skybell-client-id': '1f36a3c0-6dee-4997-a6db-4e1c67338e57'} ``` * Fix sorting that broke after rebase
123 lines
3.8 KiB
Python
123 lines
3.8 KiB
Python
"""HomeKit session fixtures."""
|
|
from contextlib import suppress
|
|
import os
|
|
from unittest.mock import patch
|
|
|
|
import pytest
|
|
|
|
from homeassistant.components.device_tracker.legacy import YAML_DEVICES
|
|
from homeassistant.components.homekit.accessories import HomeDriver
|
|
from homeassistant.components.homekit.const import BRIDGE_NAME, EVENT_HOMEKIT_CHANGED
|
|
from homeassistant.components.homekit.iidmanager import AccessoryIIDStorage
|
|
|
|
from tests.common import async_capture_events, mock_device_registry, mock_registry
|
|
|
|
|
|
@pytest.fixture
|
|
def iid_storage(hass):
|
|
"""Mock the iid storage."""
|
|
with patch.object(AccessoryIIDStorage, "_async_schedule_save"):
|
|
yield AccessoryIIDStorage(hass, "")
|
|
|
|
|
|
@pytest.fixture()
|
|
def run_driver(hass, event_loop, iid_storage):
|
|
"""Return a custom AccessoryDriver instance for HomeKit accessory init.
|
|
|
|
This mock does not mock async_stop, so the driver will not be stopped
|
|
"""
|
|
with patch("pyhap.accessory_driver.AsyncZeroconf"), patch(
|
|
"pyhap.accessory_driver.AccessoryEncoder"
|
|
), patch("pyhap.accessory_driver.HAPServer"), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.publish"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.persist"
|
|
):
|
|
yield HomeDriver(
|
|
hass,
|
|
pincode=b"123-45-678",
|
|
entry_id="",
|
|
entry_title="mock entry",
|
|
bridge_name=BRIDGE_NAME,
|
|
iid_storage=iid_storage,
|
|
address="127.0.0.1",
|
|
loop=event_loop,
|
|
)
|
|
|
|
|
|
@pytest.fixture
|
|
def hk_driver(hass, event_loop, iid_storage):
|
|
"""Return a custom AccessoryDriver instance for HomeKit accessory init."""
|
|
with patch("pyhap.accessory_driver.AsyncZeroconf"), patch(
|
|
"pyhap.accessory_driver.AccessoryEncoder"
|
|
), patch("pyhap.accessory_driver.HAPServer.async_stop"), patch(
|
|
"pyhap.accessory_driver.HAPServer.async_start"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.publish"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.persist"
|
|
):
|
|
yield HomeDriver(
|
|
hass,
|
|
pincode=b"123-45-678",
|
|
entry_id="",
|
|
entry_title="mock entry",
|
|
bridge_name=BRIDGE_NAME,
|
|
iid_storage=iid_storage,
|
|
address="127.0.0.1",
|
|
loop=event_loop,
|
|
)
|
|
|
|
|
|
@pytest.fixture
|
|
def mock_hap(hass, event_loop, iid_storage, mock_zeroconf):
|
|
"""Return a custom AccessoryDriver instance for HomeKit accessory init."""
|
|
with patch("pyhap.accessory_driver.AsyncZeroconf"), patch(
|
|
"pyhap.accessory_driver.AccessoryEncoder"
|
|
), patch("pyhap.accessory_driver.HAPServer.async_stop"), patch(
|
|
"pyhap.accessory_driver.HAPServer.async_start"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.publish"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.async_start"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.async_stop"
|
|
), patch(
|
|
"pyhap.accessory_driver.AccessoryDriver.persist"
|
|
):
|
|
yield HomeDriver(
|
|
hass,
|
|
pincode=b"123-45-678",
|
|
entry_id="",
|
|
entry_title="mock entry",
|
|
bridge_name=BRIDGE_NAME,
|
|
iid_storage=iid_storage,
|
|
address="127.0.0.1",
|
|
loop=event_loop,
|
|
)
|
|
|
|
|
|
@pytest.fixture
|
|
def events(hass):
|
|
"""Yield caught homekit_changed events."""
|
|
return async_capture_events(hass, EVENT_HOMEKIT_CHANGED)
|
|
|
|
|
|
@pytest.fixture(name="device_reg")
|
|
def device_reg_fixture(hass):
|
|
"""Return an empty, loaded, registry."""
|
|
return mock_device_registry(hass)
|
|
|
|
|
|
@pytest.fixture(name="entity_reg")
|
|
def entity_reg_fixture(hass):
|
|
"""Return an empty, loaded, registry."""
|
|
return mock_registry(hass)
|
|
|
|
|
|
@pytest.fixture
|
|
def demo_cleanup(hass):
|
|
"""Clean up device tracker demo file."""
|
|
yield
|
|
with suppress(FileNotFoundError):
|
|
os.remove(hass.config.path(YAML_DEVICES))
|