Add diagnostic platform to Whirlpool (#114578)
* Add diagnostic platform and tests * lowercase variable * Correc doc stringpull/114764/head
parent
e5a620545c
commit
384d10a51d
|
@ -0,0 +1,49 @@
|
||||||
|
"""Diagnostics support for Whirlpool."""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from typing import Any
|
||||||
|
|
||||||
|
from homeassistant.components.diagnostics import async_redact_data
|
||||||
|
from homeassistant.config_entries import ConfigEntry
|
||||||
|
from homeassistant.core import HomeAssistant
|
||||||
|
|
||||||
|
from . import WhirlpoolData
|
||||||
|
from .const import DOMAIN
|
||||||
|
|
||||||
|
TO_REDACT = {
|
||||||
|
"SERIAL_NUMBER",
|
||||||
|
"macaddress",
|
||||||
|
"username",
|
||||||
|
"password",
|
||||||
|
"token",
|
||||||
|
"unique_id",
|
||||||
|
"SAID",
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
async def async_get_config_entry_diagnostics(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
config_entry: ConfigEntry,
|
||||||
|
) -> dict[str, Any]:
|
||||||
|
"""Return diagnostics for a config entry."""
|
||||||
|
|
||||||
|
whirlpool: WhirlpoolData = hass.data[DOMAIN][config_entry.entry_id]
|
||||||
|
diagnostics_data = {
|
||||||
|
"Washer_dryers": {
|
||||||
|
wd["NAME"]: dict(wd.items())
|
||||||
|
for wd in whirlpool.appliances_manager.washer_dryers
|
||||||
|
},
|
||||||
|
"aircons": {
|
||||||
|
ac["NAME"]: dict(ac.items()) for ac in whirlpool.appliances_manager.aircons
|
||||||
|
},
|
||||||
|
"ovens": {
|
||||||
|
oven["NAME"]: dict(oven.items())
|
||||||
|
for oven in whirlpool.appliances_manager.ovens
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
"config_entry": async_redact_data(config_entry.as_dict(), TO_REDACT),
|
||||||
|
"appliances": async_redact_data(diagnostics_data, TO_REDACT),
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
# serializer version: 1
|
||||||
|
# name: test_entry_diagnostics
|
||||||
|
dict({
|
||||||
|
'appliances': dict({
|
||||||
|
'Washer_dryers': dict({
|
||||||
|
'dryer': dict({
|
||||||
|
'NAME': 'dryer',
|
||||||
|
'SAID': '**REDACTED**',
|
||||||
|
}),
|
||||||
|
'washer': dict({
|
||||||
|
'NAME': 'washer',
|
||||||
|
'SAID': '**REDACTED**',
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
'aircons': dict({
|
||||||
|
'TestZone': dict({
|
||||||
|
'NAME': 'TestZone',
|
||||||
|
'SAID': '**REDACTED**',
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
'ovens': dict({
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
'config_entry': dict({
|
||||||
|
'data': dict({
|
||||||
|
'brand': 'Whirlpool',
|
||||||
|
'password': '**REDACTED**',
|
||||||
|
'region': 'EU',
|
||||||
|
'username': '**REDACTED**',
|
||||||
|
}),
|
||||||
|
'disabled_by': None,
|
||||||
|
'domain': 'whirlpool',
|
||||||
|
'minor_version': 1,
|
||||||
|
'options': dict({
|
||||||
|
}),
|
||||||
|
'pref_disable_new_entities': False,
|
||||||
|
'pref_disable_polling': False,
|
||||||
|
'source': 'user',
|
||||||
|
'title': 'Mock Title',
|
||||||
|
'unique_id': None,
|
||||||
|
'version': 1,
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
# ---
|
|
@ -0,0 +1,32 @@
|
||||||
|
"""Test Blink diagnostics."""
|
||||||
|
|
||||||
|
from unittest.mock import MagicMock
|
||||||
|
|
||||||
|
from syrupy import SnapshotAssertion
|
||||||
|
from syrupy.filters import props
|
||||||
|
|
||||||
|
from homeassistant.core import HomeAssistant
|
||||||
|
|
||||||
|
from . import init_integration
|
||||||
|
|
||||||
|
from tests.components.diagnostics import get_diagnostics_for_config_entry
|
||||||
|
from tests.typing import ClientSessionGenerator
|
||||||
|
|
||||||
|
YAML_CONFIG = {"username": "test-user", "password": "test-password"}
|
||||||
|
|
||||||
|
|
||||||
|
async def test_entry_diagnostics(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
hass_client: ClientSessionGenerator,
|
||||||
|
snapshot: SnapshotAssertion,
|
||||||
|
mock_appliances_manager_api: MagicMock,
|
||||||
|
mock_aircon1_api: MagicMock,
|
||||||
|
mock_aircon_api_instances: MagicMock,
|
||||||
|
) -> None:
|
||||||
|
"""Test config entry diagnostics."""
|
||||||
|
|
||||||
|
mock_entry = await init_integration(hass)
|
||||||
|
|
||||||
|
result = await get_diagnostics_for_config_entry(hass, hass_client, mock_entry)
|
||||||
|
|
||||||
|
assert result == snapshot(exclude=props("entry_id"))
|
Loading…
Reference in New Issue