mirror of
https://github.com/home-assistant/core.git
synced 2025-11-09 10:59:40 +00:00
* 2nd attempt to add energysensors to Adax component * Ruff format changes * I did not reuse the first call for information.. Now i do.. * Fixed some tests after the last change * Remove extra attributes * Dont use info logger * aggregate if not rooms * Raise error if no rooms are discovered * Move code out of try catch * Catch more specific errors * removed platforms from manifest.json * remove attribute translation key * Getting rid of the summation of energy used.. * Fixed errorness in test * set roomproperty in Init * concatenated the two functions * use raw Wh values and suggest a konversion for HomeAssistant * Use snapshot testing * Update homeassistant/components/adax/coordinator.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/strings.json Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Removing un needed logg * Removing initial value * Changing tests to snapshot_platform * Removing available property from sensor.py and doing a ruff formating.. * Fix a broken indent * Add fix for coordinator updates in Adax energisensor and namesetting * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/coordinator.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/coordinator.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * generated snapshots * Ruff changes * Even more ruff changes, that did not appear on ruff command locally * Trying to fix CI updates * Update homeassistant/components/adax/sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> * Improve AdaxEnergySensor by simplifying code and ensuring correct handling of energy values. Adjust how room and device information is retrieved to avoid duplication and improve readability. * Removed a test för device_id as per request.. * Make supersure that value is int and not "Any" * removing executable status * Update tests/components/adax/test_sensor.py Co-authored-by: Josef Zweck <josef@zweck.dev> --------- Co-authored-by: Josef Zweck <josef@zweck.dev>
86 lines
2.7 KiB
Python
86 lines
2.7 KiB
Python
"""Test Adax climate entity."""
|
|
|
|
from homeassistant.components.adax.const import SCAN_INTERVAL
|
|
from homeassistant.components.climate import ATTR_CURRENT_TEMPERATURE, HVACMode
|
|
from homeassistant.const import ATTR_TEMPERATURE, STATE_UNAVAILABLE, Platform
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from . import setup_integration
|
|
from .conftest import CLOUD_DEVICE_DATA, LOCAL_DEVICE_DATA
|
|
|
|
from tests.common import AsyncMock, MockConfigEntry, async_fire_time_changed
|
|
from tests.test_setup import FrozenDateTimeFactory
|
|
|
|
|
|
async def test_climate_cloud(
|
|
hass: HomeAssistant,
|
|
freezer: FrozenDateTimeFactory,
|
|
mock_cloud_config_entry: MockConfigEntry,
|
|
mock_adax_cloud: AsyncMock,
|
|
) -> None:
|
|
"""Test states of the (cloud) Climate entity."""
|
|
await setup_integration(hass, mock_cloud_config_entry)
|
|
mock_adax_cloud.fetch_rooms_info.assert_called_once()
|
|
|
|
assert len(hass.states.async_entity_ids(Platform.CLIMATE)) == 1
|
|
entity_id = hass.states.async_entity_ids(Platform.CLIMATE)[0]
|
|
|
|
state = hass.states.get(entity_id)
|
|
|
|
assert state
|
|
assert state.state == HVACMode.HEAT
|
|
assert (
|
|
state.attributes[ATTR_TEMPERATURE] == CLOUD_DEVICE_DATA[0]["targetTemperature"]
|
|
)
|
|
assert (
|
|
state.attributes[ATTR_CURRENT_TEMPERATURE]
|
|
== CLOUD_DEVICE_DATA[0]["temperature"]
|
|
)
|
|
|
|
mock_adax_cloud.fetch_rooms_info.side_effect = Exception()
|
|
freezer.tick(SCAN_INTERVAL)
|
|
async_fire_time_changed(hass)
|
|
await hass.async_block_till_done()
|
|
|
|
state = hass.states.get(entity_id)
|
|
assert state
|
|
assert state.state == STATE_UNAVAILABLE
|
|
|
|
|
|
async def test_climate_local(
|
|
hass: HomeAssistant,
|
|
freezer: FrozenDateTimeFactory,
|
|
mock_local_config_entry: MockConfigEntry,
|
|
mock_adax_local: AsyncMock,
|
|
) -> None:
|
|
"""Test states of the (local) Climate entity."""
|
|
await setup_integration(hass, mock_local_config_entry)
|
|
mock_adax_local.get_status.assert_called_once()
|
|
|
|
assert len(hass.states.async_entity_ids(Platform.CLIMATE)) == 1
|
|
entity_id = hass.states.async_entity_ids(Platform.CLIMATE)[0]
|
|
|
|
freezer.tick(SCAN_INTERVAL)
|
|
async_fire_time_changed(hass)
|
|
await hass.async_block_till_done()
|
|
|
|
state = hass.states.get(entity_id)
|
|
assert state
|
|
assert state.state == HVACMode.HEAT
|
|
assert (
|
|
state.attributes[ATTR_TEMPERATURE] == (LOCAL_DEVICE_DATA["target_temperature"])
|
|
)
|
|
assert (
|
|
state.attributes[ATTR_CURRENT_TEMPERATURE]
|
|
== (LOCAL_DEVICE_DATA["current_temperature"])
|
|
)
|
|
|
|
mock_adax_local.get_status.side_effect = Exception()
|
|
freezer.tick(SCAN_INTERVAL)
|
|
async_fire_time_changed(hass)
|
|
await hass.async_block_till_done()
|
|
|
|
state = hass.states.get(entity_id)
|
|
assert state
|
|
assert state.state == STATE_UNAVAILABLE
|