Add config flow for efergy (#56890)
This commit is contained in:
parent
3825f80a2d
commit
c4eeebd7a7
27 changed files with 851 additions and 184 deletions
|
@ -1,135 +1,125 @@
|
|||
"""The tests for Efergy sensor platform."""
|
||||
|
||||
import asyncio
|
||||
from datetime import timedelta
|
||||
|
||||
from homeassistant.components.efergy.sensor import SENSOR_TYPES
|
||||
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN
|
||||
from homeassistant.const import STATE_UNAVAILABLE
|
||||
from homeassistant.const import (
|
||||
ATTR_DEVICE_CLASS,
|
||||
ATTR_UNIT_OF_MEASUREMENT,
|
||||
DEVICE_CLASS_ENERGY,
|
||||
DEVICE_CLASS_MONETARY,
|
||||
DEVICE_CLASS_POWER,
|
||||
ENERGY_KILO_WATT_HOUR,
|
||||
POWER_WATT,
|
||||
STATE_UNAVAILABLE,
|
||||
)
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.setup import async_setup_component
|
||||
from homeassistant.helpers import entity_registry as er
|
||||
from homeassistant.helpers.entity_registry import EntityRegistry
|
||||
import homeassistant.util.dt as dt_util
|
||||
|
||||
from tests.common import async_fire_time_changed, load_fixture
|
||||
from . import MULTI_SENSOR_TOKEN, mock_responses, setup_platform
|
||||
|
||||
from tests.common import async_fire_time_changed
|
||||
from tests.test_util.aiohttp import AiohttpClientMocker
|
||||
|
||||
token = "9p6QGJ7dpZfO3fqPTBk1fyEmjV1cGoLT"
|
||||
multi_sensor_token = "9r6QGF7dpZfO3fqPTBl1fyRmjV1cGoLT"
|
||||
|
||||
ONE_SENSOR_CONFIG = {
|
||||
"platform": "efergy",
|
||||
"app_token": token,
|
||||
"utc_offset": "300",
|
||||
"monitored_variables": [
|
||||
{"type": "amount", "period": "day"},
|
||||
{"type": "instant_readings"},
|
||||
{"type": "budget"},
|
||||
{"type": "cost", "period": "day", "currency": "$"},
|
||||
{"type": "current_values"},
|
||||
],
|
||||
}
|
||||
|
||||
MULTI_SENSOR_CONFIG = {
|
||||
"platform": "efergy",
|
||||
"app_token": multi_sensor_token,
|
||||
"utc_offset": "300",
|
||||
"monitored_variables": [{"type": "current_values"}],
|
||||
}
|
||||
|
||||
|
||||
def mock_responses(aioclient_mock: AiohttpClientMocker, error: bool = False):
|
||||
"""Mock responses for Efergy."""
|
||||
base_url = "https://engage.efergy.com/mobile_proxy/"
|
||||
if error:
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getCurrentValuesSummary?token={token}", exc=asyncio.TimeoutError
|
||||
)
|
||||
return
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getInstant?token={token}",
|
||||
text=load_fixture("efergy/efergy_instant.json"),
|
||||
)
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getEnergy?token={token}&offset=300&period=day",
|
||||
text=load_fixture("efergy/efergy_energy.json"),
|
||||
)
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getBudget?token={token}",
|
||||
text=load_fixture("efergy/efergy_budget.json"),
|
||||
)
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getCost?token={token}&offset=300&period=day",
|
||||
text=load_fixture("efergy/efergy_cost.json"),
|
||||
)
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getCurrentValuesSummary?token={token}",
|
||||
text=load_fixture("efergy/efergy_current_values_single.json"),
|
||||
)
|
||||
aioclient_mock.get(
|
||||
f"{base_url}getCurrentValuesSummary?token={multi_sensor_token}",
|
||||
text=load_fixture("efergy/efergy_current_values_multi.json"),
|
||||
)
|
||||
|
||||
|
||||
async def test_single_sensor_readings(
|
||||
async def test_sensor_readings(
|
||||
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
||||
):
|
||||
"""Test for successfully setting up the Efergy platform."""
|
||||
mock_responses(aioclient_mock)
|
||||
assert await async_setup_component(
|
||||
hass, SENSOR_DOMAIN, {SENSOR_DOMAIN: ONE_SENSOR_CONFIG}
|
||||
)
|
||||
await hass.async_block_till_done()
|
||||
for description in SENSOR_TYPES:
|
||||
description.entity_registry_enabled_default = True
|
||||
entry = await setup_platform(hass, aioclient_mock, SENSOR_DOMAIN)
|
||||
ent_reg: EntityRegistry = er.async_get(hass)
|
||||
|
||||
assert hass.states.get("sensor.energy_consumed").state == "38.21"
|
||||
assert hass.states.get("sensor.energy_usage").state == "1580"
|
||||
assert hass.states.get("sensor.energy_budget").state == "ok"
|
||||
assert hass.states.get("sensor.energy_cost").state == "5.27"
|
||||
assert hass.states.get("sensor.efergy_728386").state == "1628"
|
||||
state = hass.states.get("sensor.power_usage")
|
||||
assert state.state == "1580"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_POWER
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == POWER_WATT
|
||||
state = hass.states.get("sensor.energy_budget")
|
||||
assert state.state == "ok"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) is None
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) is None
|
||||
state = hass.states.get("sensor.daily_consumption")
|
||||
assert state.state == "38.21"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_ENERGY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == ENERGY_KILO_WATT_HOUR
|
||||
state = hass.states.get("sensor.weekly_consumption")
|
||||
assert state.state == "267.47"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_ENERGY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == ENERGY_KILO_WATT_HOUR
|
||||
state = hass.states.get("sensor.monthly_consumption")
|
||||
assert state.state == "1069.88"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_ENERGY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == ENERGY_KILO_WATT_HOUR
|
||||
state = hass.states.get("sensor.yearly_consumption")
|
||||
assert state.state == "13373.50"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_ENERGY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == ENERGY_KILO_WATT_HOUR
|
||||
state = hass.states.get("sensor.daily_energy_cost")
|
||||
assert state.state == "5.27"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_MONETARY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == "EUR"
|
||||
state = hass.states.get("sensor.weekly_energy_cost")
|
||||
assert state.state == "36.89"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_MONETARY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == "EUR"
|
||||
state = hass.states.get("sensor.monthly_energy_cost")
|
||||
assert state.state == "147.56"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_MONETARY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == "EUR"
|
||||
state = hass.states.get("sensor.yearly_energy_cost")
|
||||
assert state.state == "1844.50"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_MONETARY
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == "EUR"
|
||||
entity = ent_reg.async_get("sensor.power_usage_728386")
|
||||
assert entity.disabled_by == er.DISABLED_INTEGRATION
|
||||
ent_reg.async_update_entity(entity.entity_id, **{"disabled_by": None})
|
||||
await hass.config_entries.async_reload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
state = hass.states.get("sensor.power_usage_728386")
|
||||
assert state.state == "1628"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_POWER
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == POWER_WATT
|
||||
|
||||
|
||||
async def test_multi_sensor_readings(
|
||||
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
||||
):
|
||||
"""Test for multiple sensors in one household."""
|
||||
mock_responses(aioclient_mock)
|
||||
assert await async_setup_component(
|
||||
hass, SENSOR_DOMAIN, {SENSOR_DOMAIN: MULTI_SENSOR_CONFIG}
|
||||
)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
assert hass.states.get("sensor.efergy_728386").state == "218"
|
||||
assert hass.states.get("sensor.efergy_0").state == "1808"
|
||||
assert hass.states.get("sensor.efergy_728387").state == "312"
|
||||
|
||||
|
||||
async def test_failed_getting_sids(
|
||||
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
||||
):
|
||||
"""Test failed gettings sids."""
|
||||
mock_responses(aioclient_mock, error=True)
|
||||
assert await async_setup_component(
|
||||
hass, SENSOR_DOMAIN, {SENSOR_DOMAIN: ONE_SENSOR_CONFIG}
|
||||
)
|
||||
assert not hass.states.async_all("sensor")
|
||||
for description in SENSOR_TYPES:
|
||||
description.entity_registry_enabled_default = True
|
||||
await setup_platform(hass, aioclient_mock, SENSOR_DOMAIN, MULTI_SENSOR_TOKEN)
|
||||
state = hass.states.get("sensor.power_usage_728386")
|
||||
assert state.state == "218"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_POWER
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == POWER_WATT
|
||||
state = hass.states.get("sensor.power_usage_0")
|
||||
assert state.state == "1808"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_POWER
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == POWER_WATT
|
||||
state = hass.states.get("sensor.power_usage_728387")
|
||||
assert state.state == "312"
|
||||
assert state.attributes.get(ATTR_DEVICE_CLASS) == DEVICE_CLASS_POWER
|
||||
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == POWER_WATT
|
||||
|
||||
|
||||
async def test_failed_update_and_reconnection(
|
||||
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
||||
):
|
||||
"""Test failed update and reconnection."""
|
||||
mock_responses(aioclient_mock)
|
||||
assert await async_setup_component(
|
||||
hass, SENSOR_DOMAIN, {SENSOR_DOMAIN: ONE_SENSOR_CONFIG}
|
||||
)
|
||||
await setup_platform(hass, aioclient_mock, SENSOR_DOMAIN)
|
||||
assert hass.states.get("sensor.power_usage").state == "1580"
|
||||
aioclient_mock.clear_requests()
|
||||
mock_responses(aioclient_mock, error=True)
|
||||
next_update = dt_util.utcnow() + timedelta(seconds=3)
|
||||
async_fire_time_changed(hass, next_update)
|
||||
await hass.async_block_till_done()
|
||||
assert hass.states.get("sensor.efergy_728386").state == STATE_UNAVAILABLE
|
||||
aioclient_mock.clear_requests()
|
||||
mock_responses(aioclient_mock)
|
||||
await mock_responses(hass, aioclient_mock, error=True)
|
||||
next_update = dt_util.utcnow() + timedelta(seconds=30)
|
||||
async_fire_time_changed(hass, next_update)
|
||||
await hass.async_block_till_done()
|
||||
assert hass.states.get("sensor.efergy_728386").state == "1628"
|
||||
assert hass.states.get("sensor.power_usage").state == STATE_UNAVAILABLE
|
||||
aioclient_mock.clear_requests()
|
||||
await mock_responses(hass, aioclient_mock)
|
||||
next_update = dt_util.utcnow() + timedelta(seconds=30)
|
||||
async_fire_time_changed(hass, next_update)
|
||||
await hass.async_block_till_done()
|
||||
assert hass.states.get("sensor.power_usage").state == "1580"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue