Fix restoring state class in mobile app (#126868)
parent
40e83dd9e0
commit
1ebcc34e66
|
@ -59,6 +59,8 @@ async def async_setup_entry(
|
|||
ATTR_SENSOR_UOM: entry.unit_of_measurement,
|
||||
ATTR_SENSOR_ENTITY_CATEGORY: entry.entity_category,
|
||||
}
|
||||
if capabilities := entry.capabilities:
|
||||
config[ATTR_SENSOR_STATE_CLASS] = capabilities.get(ATTR_SENSOR_STATE_CLASS)
|
||||
entities.append(MobileAppSensor(config, config_entry))
|
||||
|
||||
async_add_entities(entities)
|
||||
|
|
|
@ -622,3 +622,78 @@ async def test_updating_disabled_sensor(
|
|||
json = await update_resp.json()
|
||||
assert json["battery_state"]["success"] is True
|
||||
assert json["battery_state"]["is_disabled"] is True
|
||||
|
||||
|
||||
async def test_recreate_correct_from_entity_registry(
|
||||
hass: HomeAssistant,
|
||||
entity_registry: er.EntityRegistry,
|
||||
create_registrations: tuple[dict[str, Any], dict[str, Any]],
|
||||
webhook_client: TestClient,
|
||||
) -> None:
|
||||
"""Test that sensors can be re-created from entity registry."""
|
||||
webhook_id = create_registrations[1]["webhook_id"]
|
||||
webhook_url = f"/api/webhook/{webhook_id}"
|
||||
|
||||
reg_resp = await webhook_client.post(
|
||||
webhook_url,
|
||||
json={
|
||||
"type": "register_sensor",
|
||||
"data": {
|
||||
"device_class": "battery",
|
||||
"icon": "mdi:battery",
|
||||
"name": "Battery State",
|
||||
"state": 100,
|
||||
"type": "sensor",
|
||||
"unique_id": "battery_state",
|
||||
"unit_of_measurement": PERCENTAGE,
|
||||
"state_class": "measurement",
|
||||
},
|
||||
},
|
||||
)
|
||||
|
||||
assert reg_resp.status == HTTPStatus.CREATED
|
||||
|
||||
update_resp = await webhook_client.post(
|
||||
webhook_url,
|
||||
json={
|
||||
"type": "update_sensor_states",
|
||||
"data": [
|
||||
{
|
||||
"icon": "mdi:battery-unknown",
|
||||
"state": 123,
|
||||
"type": "sensor",
|
||||
"unique_id": "battery_state",
|
||||
},
|
||||
],
|
||||
},
|
||||
)
|
||||
|
||||
assert update_resp.status == HTTPStatus.OK
|
||||
|
||||
entity = hass.states.get("sensor.test_1_battery_state")
|
||||
|
||||
assert entity is not None
|
||||
entity_entry = entity_registry.async_get("sensor.test_1_battery_state")
|
||||
assert entity_entry is not None
|
||||
|
||||
assert entity_entry.capabilities == {
|
||||
"state_class": "measurement",
|
||||
}
|
||||
|
||||
entry = hass.config_entries.async_entries("mobile_app")[1]
|
||||
|
||||
assert await hass.config_entries.async_unload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
assert hass.states.get("sensor.test_1_battery_state").state == STATE_UNAVAILABLE
|
||||
|
||||
assert await hass.config_entries.async_setup(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
entity_entry = entity_registry.async_get("sensor.test_1_battery_state")
|
||||
assert entity_entry is not None
|
||||
assert hass.states.get("sensor.test_1_battery_state") is not None
|
||||
|
||||
assert entity_entry.capabilities == {
|
||||
"state_class": "measurement",
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue