From da517701762d13cb0c452810fb67965c947bbdf4 Mon Sep 17 00:00:00 2001 From: Marc-Olivier Arsenault Date: Wed, 6 Dec 2023 00:22:27 +0000 Subject: [PATCH] update tests for disabled entity --- tests/test_binary_sensor.py | 62 +++++++++++++++++++++++++++++++++++++ tests/test_sensor.py | 40 ++++++++++++++++++++++-- 2 files changed, 99 insertions(+), 3 deletions(-) diff --git a/tests/test_binary_sensor.py b/tests/test_binary_sensor.py index 7338bde..4119d3e 100644 --- a/tests/test_binary_sensor.py +++ b/tests/test_binary_sensor.py @@ -1,6 +1,7 @@ """ Binary_sensor Tests""" from unittest.mock import patch +from homeassistant.helpers import entity_registry as er import pytest from pytest_homeassistant_custom_component.common import MockConfigEntry @@ -81,6 +82,21 @@ async def test_update_available(hass): assert await async_setup_entry(hass, config_entry) await hass.async_block_till_done() + entity_registry = er.async_get(hass) + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert entity.disabled + entity_registry.async_update_entity( + "binary_sensor.mainsail_update_available", + disabled_by=None, + ) + await hass.config_entries.async_reload(config_entry.entry_id) + await hass.async_block_till_done() + + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert not entity.disabled + state = hass.states.get("binary_sensor.mainsail_update_available") assert state.state == "on" @@ -92,6 +108,21 @@ async def test_update_available_system(hass, get_machine_update_status): assert await async_setup_entry(hass, config_entry) await hass.async_block_till_done() + entity_registry = er.async_get(hass) + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert entity.disabled + entity_registry.async_update_entity( + "binary_sensor.mainsail_update_available", + disabled_by=None, + ) + await hass.config_entries.async_reload(config_entry.entry_id) + await hass.async_block_till_done() + + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert not entity.disabled + state = hass.states.get("binary_sensor.mainsail_update_available") assert state.state == "on" @@ -103,6 +134,21 @@ async def test_update_available_component(hass, get_machine_update_status): assert await async_setup_entry(hass, config_entry) await hass.async_block_till_done() + entity_registry = er.async_get(hass) + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert entity.disabled + entity_registry.async_update_entity( + "binary_sensor.mainsail_update_available", + disabled_by=None, + ) + await hass.config_entries.async_reload(config_entry.entry_id) + await hass.async_block_till_done() + + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert not entity.disabled + state = hass.states.get("binary_sensor.mainsail_update_available") assert state.state == "on" @@ -115,5 +161,21 @@ async def test_update_available_no_update(hass, get_machine_update_status): assert await async_setup_entry(hass, config_entry) await hass.async_block_till_done() + entity_registry = er.async_get(hass) + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert entity.disabled + entity_registry.async_update_entity( + "binary_sensor.mainsail_update_available", + disabled_by=None, + ) + + await hass.config_entries.async_reload(config_entry.entry_id) + await hass.async_block_till_done() + + entity = entity_registry.async_get("binary_sensor.mainsail_update_available") + assert entity + assert not entity.disabled + state = hass.states.get("binary_sensor.mainsail_update_available") assert state.state == "off" diff --git a/tests/test_sensor.py b/tests/test_sensor.py index e0f4ef4..5ec4af9 100755 --- a/tests/test_sensor.py +++ b/tests/test_sensor.py @@ -2,6 +2,7 @@ import datetime as dt from unittest.mock import patch +from homeassistant.helpers import entity_registry as er from homeassistant.helpers.entity_registry import async_get as get_entity_registry import pytest from pytest_homeassistant_custom_component.common import ( @@ -106,9 +107,6 @@ async def test_sensor_services_update(hass, get_data): ("mainsail_slicer_print_duration_estimate", "8232.0"), ("mainsail_object_height", "62.6"), ("mainsail_speed_factor", "200.0"), - ("mainsail_machine_update_system", "8 packages can be upgraded"), - ("mainsail_crownest", "v4.0.4-6 > v4.1.1-1"), - ("mainsail_mainsail", "v2.8.0"), ], ) async def test_sensors( @@ -124,6 +122,42 @@ async def test_sensors( assert hass.states.get(f"sensor.{sensor}").state == value +# test all sensors +@pytest.mark.parametrize( + "sensor, value", + [ + ("mainsail_machine_update_system", "8 packages can be upgraded"), + ], +) +async def test_disabled_sensors( + hass, + sensor, + value, +): + config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG, entry_id="test") + config_entry.add_to_hass(hass) + assert await async_setup_entry(hass, config_entry) + await hass.async_block_till_done() + + entity_registry = er.async_get(hass) + entity = entity_registry.async_get(f"sensor.{sensor}") + assert entity + assert entity.disabled + entity_registry.async_update_entity( + f"sensor.{sensor}", + disabled_by=None, + ) + await hass.config_entries.async_reload(config_entry.entry_id) + await hass.async_block_till_done() + + entity = entity_registry.async_get(f"sensor.{sensor}") + assert entity + assert not entity.disabled + + state = hass.states.get(f"sensor.{sensor}") + assert state.state == value + + # test sensor affected by not printing state @pytest.mark.parametrize( "sensor_not_printing, value",