mirror of
https://github.com/home-assistant/core.git
synced 2025-07-21 12:17:07 +00:00
Add diagnostics for switchbot integration (#143389)
This commit is contained in:
parent
5230aa8917
commit
a55a6e5c48
30
homeassistant/components/switchbot/diagnostics.py
Normal file
30
homeassistant/components/switchbot/diagnostics.py
Normal file
@ -0,0 +1,30 @@
|
||||
"""Diagnostics support for switchbot integration."""
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
from typing import Any
|
||||
|
||||
from homeassistant.components import bluetooth
|
||||
from homeassistant.components.diagnostics import async_redact_data
|
||||
from homeassistant.core import HomeAssistant
|
||||
|
||||
from .const import CONF_ENCRYPTION_KEY, CONF_KEY_ID
|
||||
from .coordinator import SwitchbotConfigEntry
|
||||
|
||||
TO_REDACT = [CONF_KEY_ID, CONF_ENCRYPTION_KEY]
|
||||
|
||||
|
||||
async def async_get_config_entry_diagnostics(
|
||||
hass: HomeAssistant, entry: SwitchbotConfigEntry
|
||||
) -> dict[str, Any]:
|
||||
"""Return diagnostics for a config entry."""
|
||||
coordinator = entry.runtime_data
|
||||
|
||||
service_info = bluetooth.async_last_service_info(
|
||||
hass, coordinator.ble_device.address, connectable=coordinator.connectable
|
||||
)
|
||||
|
||||
return {
|
||||
"entry": async_redact_data(entry.as_dict(), TO_REDACT),
|
||||
"service_info": service_info,
|
||||
}
|
81
tests/components/switchbot/snapshots/test_diagnostics.ambr
Normal file
81
tests/components/switchbot/snapshots/test_diagnostics.ambr
Normal file
@ -0,0 +1,81 @@
|
||||
# serializer version: 1
|
||||
# name: test_diagnostics
|
||||
dict({
|
||||
'entry': dict({
|
||||
'data': dict({
|
||||
'address': 'aa:bb:cc:dd:ee:ff',
|
||||
'encryption_key': '**REDACTED**',
|
||||
'key_id': '**REDACTED**',
|
||||
'name': 'test-name',
|
||||
'sensor_type': 'relay_switch_1pm',
|
||||
}),
|
||||
'disabled_by': None,
|
||||
'discovery_keys': dict({
|
||||
}),
|
||||
'domain': 'switchbot',
|
||||
'minor_version': 1,
|
||||
'options': dict({
|
||||
'retry_count': 3,
|
||||
}),
|
||||
'pref_disable_new_entities': False,
|
||||
'pref_disable_polling': False,
|
||||
'source': 'user',
|
||||
'subentries': list([
|
||||
]),
|
||||
'title': 'Mock Title',
|
||||
'unique_id': 'aabbccddeeaa',
|
||||
'version': 1,
|
||||
}),
|
||||
'service_info': dict({
|
||||
'address': 'AA:BB:CC:DD:EE:FF',
|
||||
'advertisement': list([
|
||||
'W1080000',
|
||||
dict({
|
||||
'2409': dict({
|
||||
'__type': "<class 'bytes'>",
|
||||
'repr': "b'$X|\\x0866G\\x81\\x00\\x00\\x001\\x00\\x00\\x00\\x00'",
|
||||
}),
|
||||
}),
|
||||
dict({
|
||||
'0000fd3d-0000-1000-8000-00805f9b34fb': dict({
|
||||
'__type': "<class 'bytes'>",
|
||||
'repr': "b'<\\x00\\x00\\x00'",
|
||||
}),
|
||||
}),
|
||||
list([
|
||||
'cba20d00-224d-11e6-9fb8-0002a5d5c51b',
|
||||
]),
|
||||
-127,
|
||||
-60,
|
||||
list([
|
||||
list([
|
||||
]),
|
||||
]),
|
||||
]),
|
||||
'connectable': True,
|
||||
'device': dict({
|
||||
'__type': "<class 'bleak.backends.device.BLEDevice'>",
|
||||
'repr': 'BLEDevice(AA:BB:CC:DD:EE:FF, W1080000)',
|
||||
}),
|
||||
'manufacturer_data': dict({
|
||||
'2409': dict({
|
||||
'__type': "<class 'bytes'>",
|
||||
'repr': "b'$X|\\x0866G\\x81\\x00\\x00\\x001\\x00\\x00\\x00\\x00'",
|
||||
}),
|
||||
}),
|
||||
'name': 'W1080000',
|
||||
'rssi': -60,
|
||||
'service_data': dict({
|
||||
'0000fd3d-0000-1000-8000-00805f9b34fb': dict({
|
||||
'__type': "<class 'bytes'>",
|
||||
'repr': "b'<\\x00\\x00\\x00'",
|
||||
}),
|
||||
}),
|
||||
'service_uuids': list([
|
||||
'cba20d00-224d-11e6-9fb8-0002a5d5c51b',
|
||||
]),
|
||||
'source': 'local',
|
||||
'tx_power': -127,
|
||||
}),
|
||||
})
|
||||
# ---
|
63
tests/components/switchbot/test_diagnostics.py
Normal file
63
tests/components/switchbot/test_diagnostics.py
Normal file
@ -0,0 +1,63 @@
|
||||
"""Tests for the diagnostics data provided by the Switchbot integration."""
|
||||
|
||||
from unittest.mock import patch
|
||||
|
||||
from syrupy import SnapshotAssertion
|
||||
from syrupy.filters import props
|
||||
|
||||
from homeassistant.components.switchbot.const import (
|
||||
CONF_ENCRYPTION_KEY,
|
||||
CONF_KEY_ID,
|
||||
CONF_RETRY_COUNT,
|
||||
DEFAULT_RETRY_COUNT,
|
||||
DOMAIN,
|
||||
)
|
||||
from homeassistant.config_entries import ConfigEntryState
|
||||
from homeassistant.const import CONF_ADDRESS, CONF_NAME, CONF_SENSOR_TYPE
|
||||
from homeassistant.core import HomeAssistant
|
||||
|
||||
from . import WORELAY_SWITCH_1PM_SERVICE_INFO
|
||||
|
||||
from tests.common import MockConfigEntry
|
||||
from tests.components.bluetooth import inject_bluetooth_service_info
|
||||
from tests.components.diagnostics import get_diagnostics_for_config_entry
|
||||
from tests.typing import ClientSessionGenerator
|
||||
|
||||
|
||||
async def test_diagnostics(
|
||||
hass: HomeAssistant,
|
||||
hass_client: ClientSessionGenerator,
|
||||
snapshot: SnapshotAssertion,
|
||||
) -> None:
|
||||
"""Test diagnostics for config entry."""
|
||||
|
||||
inject_bluetooth_service_info(hass, WORELAY_SWITCH_1PM_SERVICE_INFO)
|
||||
|
||||
with patch(
|
||||
"homeassistant.components.switchbot.switch.switchbot.SwitchbotRelaySwitch.update",
|
||||
return_value=None,
|
||||
):
|
||||
mock_config_entry = MockConfigEntry(
|
||||
domain=DOMAIN,
|
||||
data={
|
||||
CONF_ADDRESS: "aa:bb:cc:dd:ee:ff",
|
||||
CONF_NAME: "test-name",
|
||||
CONF_SENSOR_TYPE: "relay_switch_1pm",
|
||||
CONF_KEY_ID: "ff",
|
||||
CONF_ENCRYPTION_KEY: "ffffffffffffffffffffffffffffffff",
|
||||
},
|
||||
unique_id="aabbccddeeaa",
|
||||
options={CONF_RETRY_COUNT: DEFAULT_RETRY_COUNT},
|
||||
)
|
||||
mock_config_entry.add_to_hass(hass)
|
||||
|
||||
await hass.config_entries.async_setup(mock_config_entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
assert mock_config_entry.state is ConfigEntryState.LOADED
|
||||
|
||||
result = await get_diagnostics_for_config_entry(
|
||||
hass, hass_client, mock_config_entry
|
||||
)
|
||||
assert result == snapshot(
|
||||
exclude=props("created_at", "modified_at", "entry_id", "time")
|
||||
)
|
Loading…
x
Reference in New Issue
Block a user