Add UniFi Uptime sensor (#40058)

* Added UniFi Uptime sensor

Added the UniFi uptime data as a sensor. Untested.

* Update sensor.py

Updated code as a result of the tests.

* Changed timestamp format and device class

Converted state to iso timestamp and changed device class to DEVICE_CLASS_TIMESTAMP.

* Updated unit of measurement to None

* Added import

* Update homeassistant/components/unifi/sensor.py

Co-authored-by: Martin Hjelmare <marhje52@gmail.com>

* Removed whitespace

* Added the uptime sensors option to the config flow

* All the unit tests should be there now

* Whoops

* Fixed translation

* Properly formatted the code

* Flake8 really has angel eyes

* Black should also be satisfied now

* Should have satisfied all static code analysis tools

* Fixed add uptime sensor function

* Fixed overintendation

* Fixed unit tests

* Made a spelling mistake during editing of unit tests

* Test verifies if utc time is correct

* Converted to iso format

* Converted unit test to iso format

* Unit test sensor json had the wrong uptime name

* Added options_updated handler

* Fixed remove sensors unit test

* Update homeassistant/components/unifi/sensor.py

Co-authored-by: Robert Svensson <Kane610@users.noreply.github.com>

* Update homeassistant/components/unifi/sensor.py

Co-authored-by: Robert Svensson <Kane610@users.noreply.github.com>

* Update test_device_tracker.py

Removed uptime from the devices

* Fixed black formatting issue

* I think the code coverage should be good now

* Trying to add the sensors again

* Using signals to hopefully trigger the controller to add them again

* Forgot import

* Sorted components

* fixed isort comments

* Removed CLASS and DEVICE_CLASS

* Added TYPE again

* Removed double underscores

Co-authored-by: Martin Hjelmare <marhje52@gmail.com>
Co-authored-by: Robert Svensson <Kane610@users.noreply.github.com>
This commit is contained in:
timkoers 2020-09-18 19:33:37 +02:00 committed by GitHub
parent b25bb78916
commit 46b86f4a2f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 163 additions and 15 deletions

View file

@ -16,6 +16,7 @@ import homeassistant.helpers.config_validation as cv
from .const import ( from .const import (
CONF_ALLOW_BANDWIDTH_SENSORS, CONF_ALLOW_BANDWIDTH_SENSORS,
CONF_ALLOW_UPTIME_SENSORS,
CONF_BLOCK_CLIENT, CONF_BLOCK_CLIENT,
CONF_CONTROLLER, CONF_CONTROLLER,
CONF_DETECTION_TIME, CONF_DETECTION_TIME,
@ -312,7 +313,11 @@ class UnifiOptionsFlowHandler(config_entries.OptionsFlow):
vol.Optional( vol.Optional(
CONF_ALLOW_BANDWIDTH_SENSORS, CONF_ALLOW_BANDWIDTH_SENSORS,
default=self.controller.option_allow_bandwidth_sensors, default=self.controller.option_allow_bandwidth_sensors,
): bool ): bool,
vol.Optional(
CONF_ALLOW_UPTIME_SENSORS,
default=self.controller.option_allow_uptime_sensors,
): bool,
} }
), ),
) )

View file

@ -12,6 +12,7 @@ CONF_SITE_ID = "site"
UNIFI_WIRELESS_CLIENTS = "unifi_wireless_clients" UNIFI_WIRELESS_CLIENTS = "unifi_wireless_clients"
CONF_ALLOW_BANDWIDTH_SENSORS = "allow_bandwidth_sensors" CONF_ALLOW_BANDWIDTH_SENSORS = "allow_bandwidth_sensors"
CONF_ALLOW_UPTIME_SENSORS = "allow_uptime_sensors"
CONF_BLOCK_CLIENT = "block_client" CONF_BLOCK_CLIENT = "block_client"
CONF_DETECTION_TIME = "detection_time" CONF_DETECTION_TIME = "detection_time"
CONF_IGNORE_WIRED_BUG = "ignore_wired_bug" CONF_IGNORE_WIRED_BUG = "ignore_wired_bug"
@ -22,6 +23,7 @@ CONF_TRACK_WIRED_CLIENTS = "track_wired_clients"
CONF_SSID_FILTER = "ssid_filter" CONF_SSID_FILTER = "ssid_filter"
DEFAULT_ALLOW_BANDWIDTH_SENSORS = False DEFAULT_ALLOW_BANDWIDTH_SENSORS = False
DEFAULT_ALLOW_UPTIME_SENSORS = False
DEFAULT_IGNORE_WIRED_BUG = False DEFAULT_IGNORE_WIRED_BUG = False
DEFAULT_POE_CLIENTS = True DEFAULT_POE_CLIENTS = True
DEFAULT_TRACK_CLIENTS = True DEFAULT_TRACK_CLIENTS = True

View file

@ -33,6 +33,7 @@ from homeassistant.helpers.dispatcher import async_dispatcher_send
from .const import ( from .const import (
CONF_ALLOW_BANDWIDTH_SENSORS, CONF_ALLOW_BANDWIDTH_SENSORS,
CONF_ALLOW_UPTIME_SENSORS,
CONF_BLOCK_CLIENT, CONF_BLOCK_CLIENT,
CONF_CONTROLLER, CONF_CONTROLLER,
CONF_DETECTION_TIME, CONF_DETECTION_TIME,
@ -45,6 +46,7 @@ from .const import (
CONF_TRACK_WIRED_CLIENTS, CONF_TRACK_WIRED_CLIENTS,
CONTROLLER_ID, CONTROLLER_ID,
DEFAULT_ALLOW_BANDWIDTH_SENSORS, DEFAULT_ALLOW_BANDWIDTH_SENSORS,
DEFAULT_ALLOW_UPTIME_SENSORS,
DEFAULT_DETECTION_TIME, DEFAULT_DETECTION_TIME,
DEFAULT_IGNORE_WIRED_BUG, DEFAULT_IGNORE_WIRED_BUG,
DEFAULT_POE_CLIENTS, DEFAULT_POE_CLIENTS,
@ -184,6 +186,13 @@ class UniFiController:
CONF_ALLOW_BANDWIDTH_SENSORS, DEFAULT_ALLOW_BANDWIDTH_SENSORS CONF_ALLOW_BANDWIDTH_SENSORS, DEFAULT_ALLOW_BANDWIDTH_SENSORS
) )
@property
def option_allow_uptime_sensors(self):
"""Config entry option to allow uptime sensors."""
return self.config_entry.options.get(
CONF_ALLOW_UPTIME_SENSORS, DEFAULT_ALLOW_UPTIME_SENSORS
)
@callback @callback
def async_unifi_signalling_callback(self, signal, data): def async_unifi_signalling_callback(self, signal, data):
"""Handle messages back from UniFi library.""" """Handle messages back from UniFi library."""

View file

@ -1,10 +1,11 @@
"""Support for bandwidth sensors with UniFi clients.""" """Support for bandwidth sensors with UniFi clients."""
import logging import logging
from homeassistant.components.sensor import DOMAIN from homeassistant.components.sensor import DEVICE_CLASS_TIMESTAMP, DOMAIN
from homeassistant.const import DATA_MEGABYTES from homeassistant.const import DATA_MEGABYTES
from homeassistant.core import callback from homeassistant.core import callback
from homeassistant.helpers.dispatcher import async_dispatcher_connect from homeassistant.helpers.dispatcher import async_dispatcher_connect
import homeassistant.util.dt as dt_util
from .const import DOMAIN as UNIFI_DOMAIN from .const import DOMAIN as UNIFI_DOMAIN
from .unifi_client import UniFiClient from .unifi_client import UniFiClient
@ -13,6 +14,7 @@ LOGGER = logging.getLogger(__name__)
RX_SENSOR = "rx" RX_SENSOR = "rx"
TX_SENSOR = "tx" TX_SENSOR = "tx"
UPTIME_SENSOR = "uptime"
async def async_setup_platform(hass, config, async_add_entities, discovery_info=None): async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
@ -22,7 +24,11 @@ async def async_setup_platform(hass, config, async_add_entities, discovery_info=
async def async_setup_entry(hass, config_entry, async_add_entities): async def async_setup_entry(hass, config_entry, async_add_entities):
"""Set up sensors for UniFi integration.""" """Set up sensors for UniFi integration."""
controller = hass.data[UNIFI_DOMAIN][config_entry.entry_id] controller = hass.data[UNIFI_DOMAIN][config_entry.entry_id]
controller.entities[DOMAIN] = {RX_SENSOR: set(), TX_SENSOR: set()} controller.entities[DOMAIN] = {
RX_SENSOR: set(),
TX_SENSOR: set(),
UPTIME_SENSOR: set(),
}
@callback @callback
def items_added( def items_added(
@ -30,7 +36,10 @@ async def async_setup_entry(hass, config_entry, async_add_entities):
) -> None: ) -> None:
"""Update the values of the controller.""" """Update the values of the controller."""
if controller.option_allow_bandwidth_sensors: if controller.option_allow_bandwidth_sensors:
add_entities(controller, async_add_entities, clients) add_bandwith_entities(controller, async_add_entities, clients)
if controller.option_allow_uptime_sensors:
add_uptime_entities(controller, async_add_entities, clients)
for signal in (controller.signal_update, controller.signal_options_update): for signal in (controller.signal_update, controller.signal_options_update):
controller.listeners.append(async_dispatcher_connect(hass, signal, items_added)) controller.listeners.append(async_dispatcher_connect(hass, signal, items_added))
@ -39,7 +48,7 @@ async def async_setup_entry(hass, config_entry, async_add_entities):
@callback @callback
def add_entities(controller, async_add_entities, clients): def add_bandwith_entities(controller, async_add_entities, clients):
"""Add new sensor entities from the controller.""" """Add new sensor entities from the controller."""
sensors = [] sensors = []
@ -55,6 +64,22 @@ def add_entities(controller, async_add_entities, clients):
async_add_entities(sensors) async_add_entities(sensors)
@callback
def add_uptime_entities(controller, async_add_entities, clients):
"""Add new sensor entities from the controller."""
sensors = []
for mac in clients:
if mac in controller.entities[DOMAIN][UniFiUpTimeSensor.TYPE]:
continue
client = controller.api.clients[mac]
sensors.append(UniFiUpTimeSensor(client, controller))
if sensors:
async_add_entities(sensors)
class UniFiBandwidthSensor(UniFiClient): class UniFiBandwidthSensor(UniFiClient):
"""UniFi bandwidth sensor base class.""" """UniFi bandwidth sensor base class."""
@ -100,3 +125,30 @@ class UniFiTxBandwidthSensor(UniFiBandwidthSensor):
if self._is_wired: if self._is_wired:
return self.client.wired_tx_bytes / 1000000 return self.client.wired_tx_bytes / 1000000
return self.client.tx_bytes / 1000000 return self.client.tx_bytes / 1000000
class UniFiUpTimeSensor(UniFiClient):
"""UniFi uptime sensor."""
DOMAIN = DOMAIN
TYPE = UPTIME_SENSOR
@property
def device_class(self) -> str:
"""Return device class."""
return DEVICE_CLASS_TIMESTAMP
@property
def name(self) -> str:
"""Return the name of the client."""
return f"{super().name} {self.TYPE.capitalize()}"
@property
def state(self) -> int:
"""Return the uptime of the client."""
return dt_util.utc_from_timestamp(float(self.client.uptime)).isoformat()
async def options_updated(self) -> None:
"""Config entry options are updated, remove entity if option is disabled."""
if not self.controller.option_allow_uptime_sensors:
await self.remove_item({self.client.mac})

View file

@ -54,7 +54,8 @@
}, },
"statistics_sensors": { "statistics_sensors": {
"data": { "data": {
"allow_bandwidth_sensors": "Bandwidth usage sensors for network clients" "allow_bandwidth_sensors": "Bandwidth usage sensors for network clients",
"allow_uptime_sensors": "Uptime sensors for network clients"
}, },
"description": "Configure statistics sensors", "description": "Configure statistics sensors",
"title": "UniFi options 3/3" "title": "UniFi options 3/3"

View file

@ -58,7 +58,8 @@
}, },
"statistics_sensors": { "statistics_sensors": {
"data": { "data": {
"allow_bandwidth_sensors": "Maak bandbreedtegebruiksensoren voor netwerkclients" "allow_bandwidth_sensors": "Maak bandbreedtegebruiksensoren voor netwerkclients",
"allow_uptime_sensors": "Maak uptime-sensoren voor netwerkclients"
}, },
"description": "Configureer statistische sensoren", "description": "Configureer statistische sensoren",
"title": "UniFi-opties 3/3" "title": "UniFi-opties 3/3"

View file

@ -4,6 +4,7 @@ import aiounifi
from homeassistant import data_entry_flow from homeassistant import data_entry_flow
from homeassistant.components.unifi.const import ( from homeassistant.components.unifi.const import (
CONF_ALLOW_BANDWIDTH_SENSORS, CONF_ALLOW_BANDWIDTH_SENSORS,
CONF_ALLOW_UPTIME_SENSORS,
CONF_BLOCK_CLIENT, CONF_BLOCK_CLIENT,
CONF_CONTROLLER, CONF_CONTROLLER,
CONF_DETECTION_TIME, CONF_DETECTION_TIME,
@ -341,7 +342,11 @@ async def test_advanced_option_flow(hass):
assert result["step_id"] == "statistics_sensors" assert result["step_id"] == "statistics_sensors"
result = await hass.config_entries.options.async_configure( result = await hass.config_entries.options.async_configure(
result["flow_id"], user_input={CONF_ALLOW_BANDWIDTH_SENSORS: True} result["flow_id"],
user_input={
CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
},
) )
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
@ -355,6 +360,7 @@ async def test_advanced_option_flow(hass):
CONF_POE_CLIENTS: False, CONF_POE_CLIENTS: False,
CONF_BLOCK_CLIENT: [CLIENTS[0]["mac"]], CONF_BLOCK_CLIENT: [CLIENTS[0]["mac"]],
CONF_ALLOW_BANDWIDTH_SENSORS: True, CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
} }

View file

@ -13,6 +13,7 @@ from homeassistant.components.unifi.const import (
CONF_CONTROLLER, CONF_CONTROLLER,
CONF_SITE_ID, CONF_SITE_ID,
DEFAULT_ALLOW_BANDWIDTH_SENSORS, DEFAULT_ALLOW_BANDWIDTH_SENSORS,
DEFAULT_ALLOW_UPTIME_SENSORS,
DEFAULT_DETECTION_TIME, DEFAULT_DETECTION_TIME,
DEFAULT_TRACK_CLIENTS, DEFAULT_TRACK_CLIENTS,
DEFAULT_TRACK_DEVICES, DEFAULT_TRACK_DEVICES,
@ -49,6 +50,7 @@ CONTROLLER_HOST = {
"sw_port": 1, "sw_port": 1,
"wired-rx_bytes": 1234000000, "wired-rx_bytes": 1234000000,
"wired-tx_bytes": 5678000000, "wired-tx_bytes": 5678000000,
"uptime": 1562600160,
} }
CONTROLLER_DATA = { CONTROLLER_DATA = {
@ -175,6 +177,7 @@ async def test_controller_setup(hass):
assert controller.site_role == SITES[controller.site_name]["role"] assert controller.site_role == SITES[controller.site_name]["role"]
assert controller.option_allow_bandwidth_sensors == DEFAULT_ALLOW_BANDWIDTH_SENSORS assert controller.option_allow_bandwidth_sensors == DEFAULT_ALLOW_BANDWIDTH_SENSORS
assert controller.option_allow_uptime_sensors == DEFAULT_ALLOW_UPTIME_SENSORS
assert isinstance(controller.option_block_clients, list) assert isinstance(controller.option_block_clients, list)
assert controller.option_track_clients == DEFAULT_TRACK_CLIENTS assert controller.option_track_clients == DEFAULT_TRACK_CLIENTS
assert controller.option_track_devices == DEFAULT_TRACK_DEVICES assert controller.option_track_devices == DEFAULT_TRACK_DEVICES

View file

@ -8,10 +8,12 @@ from homeassistant.components.device_tracker import DOMAIN as TRACKER_DOMAIN
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN
from homeassistant.components.unifi.const import ( from homeassistant.components.unifi.const import (
CONF_ALLOW_BANDWIDTH_SENSORS, CONF_ALLOW_BANDWIDTH_SENSORS,
CONF_ALLOW_UPTIME_SENSORS,
CONF_TRACK_CLIENTS, CONF_TRACK_CLIENTS,
CONF_TRACK_DEVICES, CONF_TRACK_DEVICES,
DOMAIN as UNIFI_DOMAIN, DOMAIN as UNIFI_DOMAIN,
) )
from homeassistant.helpers.dispatcher import async_dispatcher_send
from homeassistant.setup import async_setup_component from homeassistant.setup import async_setup_component
from .test_controller import setup_unifi_integration from .test_controller import setup_unifi_integration
@ -29,6 +31,7 @@ CLIENTS = [
"sw_port": 1, "sw_port": 1,
"wired-rx_bytes": 1234000000, "wired-rx_bytes": 1234000000,
"wired-tx_bytes": 5678000000, "wired-tx_bytes": 5678000000,
"uptime": 1600094505,
}, },
{ {
"hostname": "Wireless client hostname", "hostname": "Wireless client hostname",
@ -42,6 +45,7 @@ CLIENTS = [
"sw_port": 2, "sw_port": 2,
"rx_bytes": 1234000000, "rx_bytes": 1234000000,
"tx_bytes": 5678000000, "tx_bytes": 5678000000,
"uptime": 1600094505,
}, },
] ]
@ -61,7 +65,10 @@ async def test_no_clients(hass):
"""Test the update_clients function when no clients are found.""" """Test the update_clients function when no clients are found."""
controller = await setup_unifi_integration( controller = await setup_unifi_integration(
hass, hass,
options={CONF_ALLOW_BANDWIDTH_SENSORS: True}, options={
CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
},
) )
assert len(controller.mock_requests) == 4 assert len(controller.mock_requests) == 4
@ -74,6 +81,7 @@ async def test_sensors(hass):
hass, hass,
options={ options={
CONF_ALLOW_BANDWIDTH_SENSORS: True, CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
CONF_TRACK_CLIENTS: False, CONF_TRACK_CLIENTS: False,
CONF_TRACK_DEVICES: False, CONF_TRACK_DEVICES: False,
}, },
@ -81,7 +89,7 @@ async def test_sensors(hass):
) )
assert len(controller.mock_requests) == 4 assert len(controller.mock_requests) == 4
assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 4 assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 6
wired_client_rx = hass.states.get("sensor.wired_client_name_rx") wired_client_rx = hass.states.get("sensor.wired_client_name_rx")
assert wired_client_rx.state == "1234.0" assert wired_client_rx.state == "1234.0"
@ -89,16 +97,23 @@ async def test_sensors(hass):
wired_client_tx = hass.states.get("sensor.wired_client_name_tx") wired_client_tx = hass.states.get("sensor.wired_client_name_tx")
assert wired_client_tx.state == "5678.0" assert wired_client_tx.state == "5678.0"
wired_client_uptime = hass.states.get("sensor.wired_client_name_uptime")
assert wired_client_uptime.state == "2020-09-14T14:41:45+00:00"
wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx") wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx")
assert wireless_client_rx.state == "1234.0" assert wireless_client_rx.state == "1234.0"
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx.state == "5678.0" assert wireless_client_tx.state == "5678.0"
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime.state == "2020-09-14T14:41:45+00:00"
clients = deepcopy(CLIENTS) clients = deepcopy(CLIENTS)
clients[0]["is_wired"] = False clients[0]["is_wired"] = False
clients[1]["rx_bytes"] = 2345000000 clients[1]["rx_bytes"] = 2345000000
clients[1]["tx_bytes"] = 6789000000 clients[1]["tx_bytes"] = 6789000000
clients[1]["uptime"] = 1600180860
event = {"meta": {"message": MESSAGE_CLIENT}, "data": clients} event = {"meta": {"message": MESSAGE_CLIENT}, "data": clients}
controller.api.message_handler(event) controller.api.message_handler(event)
@ -110,9 +125,15 @@ async def test_sensors(hass):
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx.state == "6789.0" assert wireless_client_tx.state == "6789.0"
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime.state == "2020-09-15T14:41:00+00:00"
hass.config_entries.async_update_entry( hass.config_entries.async_update_entry(
controller.config_entry, controller.config_entry,
options={CONF_ALLOW_BANDWIDTH_SENSORS: False}, options={
CONF_ALLOW_BANDWIDTH_SENSORS: False,
CONF_ALLOW_UPTIME_SENSORS: False,
},
) )
await hass.async_block_till_done() await hass.async_block_till_done()
@ -122,9 +143,18 @@ async def test_sensors(hass):
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx is None assert wireless_client_tx is None
wired_client_uptime = hass.states.get("sensor.wired_client_name_uptime")
assert wired_client_uptime is None
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime is None
hass.config_entries.async_update_entry( hass.config_entries.async_update_entry(
controller.config_entry, controller.config_entry,
options={CONF_ALLOW_BANDWIDTH_SENSORS: True}, options={
CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
},
) )
await hass.async_block_till_done() await hass.async_block_till_done()
@ -134,15 +164,42 @@ async def test_sensors(hass):
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx.state == "6789.0" assert wireless_client_tx.state == "6789.0"
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime.state == "2020-09-15T14:41:00+00:00"
wired_client_uptime = hass.states.get("sensor.wired_client_name_uptime")
assert wired_client_uptime.state == "2020-09-14T14:41:45+00:00"
# Try to add the sensors again, using a signal
clients_connected = set()
devices_connected = set()
clients_connected.add(clients[0]["mac"])
clients_connected.add(clients[1]["mac"])
async_dispatcher_send(
hass,
controller.signal_update,
clients_connected,
devices_connected,
)
await hass.async_block_till_done()
assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 6
async def test_remove_sensors(hass): async def test_remove_sensors(hass):
"""Test the remove_items function with some clients.""" """Test the remove_items function with some clients."""
controller = await setup_unifi_integration( controller = await setup_unifi_integration(
hass, hass,
options={CONF_ALLOW_BANDWIDTH_SENSORS: True}, options={
CONF_ALLOW_BANDWIDTH_SENSORS: True,
CONF_ALLOW_UPTIME_SENSORS: True,
},
clients_response=CLIENTS, clients_response=CLIENTS,
) )
assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 4 assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 6
assert len(hass.states.async_entity_ids(TRACKER_DOMAIN)) == 2 assert len(hass.states.async_entity_ids(TRACKER_DOMAIN)) == 2
wired_client_rx = hass.states.get("sensor.wired_client_name_rx") wired_client_rx = hass.states.get("sensor.wired_client_name_rx")
@ -150,11 +207,17 @@ async def test_remove_sensors(hass):
wired_client_tx = hass.states.get("sensor.wired_client_name_tx") wired_client_tx = hass.states.get("sensor.wired_client_name_tx")
assert wired_client_tx is not None assert wired_client_tx is not None
wired_client_uptime = hass.states.get("sensor.wired_client_name_uptime")
assert wired_client_uptime is not None
wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx") wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx")
assert wireless_client_rx is not None assert wireless_client_rx is not None
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx is not None assert wireless_client_tx is not None
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime is not None
controller.api.websocket._data = { controller.api.websocket._data = {
"meta": {"message": MESSAGE_CLIENT_REMOVED}, "meta": {"message": MESSAGE_CLIENT_REMOVED},
"data": [CLIENTS[0]], "data": [CLIENTS[0]],
@ -162,7 +225,7 @@ async def test_remove_sensors(hass):
controller.api.session_handler(SIGNAL_DATA) controller.api.session_handler(SIGNAL_DATA)
await hass.async_block_till_done() await hass.async_block_till_done()
assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 2 assert len(hass.states.async_entity_ids(SENSOR_DOMAIN)) == 3
assert len(hass.states.async_entity_ids(TRACKER_DOMAIN)) == 1 assert len(hass.states.async_entity_ids(TRACKER_DOMAIN)) == 1
wired_client_rx = hass.states.get("sensor.wired_client_name_rx") wired_client_rx = hass.states.get("sensor.wired_client_name_rx")
@ -170,7 +233,13 @@ async def test_remove_sensors(hass):
wired_client_tx = hass.states.get("sensor.wired_client_name_tx") wired_client_tx = hass.states.get("sensor.wired_client_name_tx")
assert wired_client_tx is None assert wired_client_tx is None
wired_client_uptime = hass.states.get("sensor.wired_client_name_uptime")
assert wired_client_uptime is None
wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx") wireless_client_rx = hass.states.get("sensor.wireless_client_name_rx")
assert wireless_client_rx is not None assert wireless_client_rx is not None
wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx") wireless_client_tx = hass.states.get("sensor.wireless_client_name_tx")
assert wireless_client_tx is not None assert wireless_client_tx is not None
wireless_client_uptime = hass.states.get("sensor.wireless_client_name_uptime")
assert wireless_client_uptime is not None