Add diagnostic platform to Whirlpool (#114578)

* Add diagnostic platform and tests

* lowercase variable

* Correc doc string
pull/114764/head
mkmer 2024-04-02 03:41:40 -04:00 committed by Franck Nijhof
parent e5a620545c
commit 384d10a51d
No known key found for this signature in database
GPG Key ID: D62583BA8AB11CA3
3 changed files with 125 additions and 0 deletions

View File

@ -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),
}

View File

@ -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,
}),
})
# ---

View File

@ -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"))