Black
This commit is contained in:
parent
da05dfe708
commit
4de97abc3a
2676 changed files with 163166 additions and 140084 deletions
|
@ -6,13 +6,14 @@ real HTTP calls are not initiated during testing.
|
|||
"""
|
||||
from pysmartthings import ATTRIBUTES, CAPABILITIES, Attribute, Capability
|
||||
|
||||
from homeassistant.components.sensor import (
|
||||
DEVICE_CLASSES, DOMAIN as SENSOR_DOMAIN)
|
||||
from homeassistant.components.sensor import DEVICE_CLASSES, DOMAIN as SENSOR_DOMAIN
|
||||
from homeassistant.components.smartthings import sensor
|
||||
from homeassistant.components.smartthings.const import (
|
||||
DOMAIN, SIGNAL_SMARTTHINGS_UPDATE)
|
||||
from homeassistant.components.smartthings.const import DOMAIN, SIGNAL_SMARTTHINGS_UPDATE
|
||||
from homeassistant.const import (
|
||||
ATTR_FRIENDLY_NAME, ATTR_UNIT_OF_MEASUREMENT, STATE_UNKNOWN)
|
||||
ATTR_FRIENDLY_NAME,
|
||||
ATTR_UNIT_OF_MEASUREMENT,
|
||||
STATE_UNKNOWN,
|
||||
)
|
||||
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
||||
|
||||
from .conftest import setup_platform
|
||||
|
@ -25,8 +26,9 @@ async def test_mapping_integrity():
|
|||
for sensor_map in maps:
|
||||
assert sensor_map.attribute in ATTRIBUTES, sensor_map.attribute
|
||||
if sensor_map.device_class:
|
||||
assert sensor_map.device_class in DEVICE_CLASSES, \
|
||||
sensor_map.device_class
|
||||
assert (
|
||||
sensor_map.device_class in DEVICE_CLASSES
|
||||
), sensor_map.device_class
|
||||
|
||||
|
||||
async def test_async_setup_platform():
|
||||
|
@ -36,95 +38,87 @@ async def test_async_setup_platform():
|
|||
|
||||
async def test_entity_state(hass, device_factory):
|
||||
"""Tests the state attributes properly match the sensor types."""
|
||||
device = device_factory('Sensor 1', [Capability.battery],
|
||||
{Attribute.battery: 100})
|
||||
device = device_factory("Sensor 1", [Capability.battery], {Attribute.battery: 100})
|
||||
await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
state = hass.states.get('sensor.sensor_1_battery')
|
||||
assert state.state == '100'
|
||||
assert state.attributes[ATTR_UNIT_OF_MEASUREMENT] == '%'
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] ==\
|
||||
device.label + " Battery"
|
||||
state = hass.states.get("sensor.sensor_1_battery")
|
||||
assert state.state == "100"
|
||||
assert state.attributes[ATTR_UNIT_OF_MEASUREMENT] == "%"
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] == device.label + " Battery"
|
||||
|
||||
|
||||
async def test_entity_three_axis_state(hass, device_factory):
|
||||
"""Tests the state attributes properly match the three axis types."""
|
||||
device = device_factory('Three Axis', [Capability.three_axis],
|
||||
{Attribute.three_axis: [100, 75, 25]})
|
||||
device = device_factory(
|
||||
"Three Axis", [Capability.three_axis], {Attribute.three_axis: [100, 75, 25]}
|
||||
)
|
||||
await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
state = hass.states.get('sensor.three_axis_x_coordinate')
|
||||
assert state.state == '100'
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] ==\
|
||||
device.label + " X Coordinate"
|
||||
state = hass.states.get('sensor.three_axis_y_coordinate')
|
||||
assert state.state == '75'
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] ==\
|
||||
device.label + " Y Coordinate"
|
||||
state = hass.states.get('sensor.three_axis_z_coordinate')
|
||||
assert state.state == '25'
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] ==\
|
||||
device.label + " Z Coordinate"
|
||||
state = hass.states.get("sensor.three_axis_x_coordinate")
|
||||
assert state.state == "100"
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] == device.label + " X Coordinate"
|
||||
state = hass.states.get("sensor.three_axis_y_coordinate")
|
||||
assert state.state == "75"
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] == device.label + " Y Coordinate"
|
||||
state = hass.states.get("sensor.three_axis_z_coordinate")
|
||||
assert state.state == "25"
|
||||
assert state.attributes[ATTR_FRIENDLY_NAME] == device.label + " Z Coordinate"
|
||||
|
||||
|
||||
async def test_entity_three_axis_invalid_state(hass, device_factory):
|
||||
"""Tests the state attributes properly match the three axis types."""
|
||||
device = device_factory('Three Axis', [Capability.three_axis],
|
||||
{Attribute.three_axis: []})
|
||||
device = device_factory(
|
||||
"Three Axis", [Capability.three_axis], {Attribute.three_axis: []}
|
||||
)
|
||||
await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
state = hass.states.get('sensor.three_axis_x_coordinate')
|
||||
state = hass.states.get("sensor.three_axis_x_coordinate")
|
||||
assert state.state == STATE_UNKNOWN
|
||||
state = hass.states.get('sensor.three_axis_y_coordinate')
|
||||
state = hass.states.get("sensor.three_axis_y_coordinate")
|
||||
assert state.state == STATE_UNKNOWN
|
||||
state = hass.states.get('sensor.three_axis_z_coordinate')
|
||||
state = hass.states.get("sensor.three_axis_z_coordinate")
|
||||
assert state.state == STATE_UNKNOWN
|
||||
|
||||
|
||||
async def test_entity_and_device_attributes(hass, device_factory):
|
||||
"""Test the attributes of the entity are correct."""
|
||||
# Arrange
|
||||
device = device_factory('Sensor 1', [Capability.battery],
|
||||
{Attribute.battery: 100})
|
||||
device = device_factory("Sensor 1", [Capability.battery], {Attribute.battery: 100})
|
||||
entity_registry = await hass.helpers.entity_registry.async_get_registry()
|
||||
device_registry = await hass.helpers.device_registry.async_get_registry()
|
||||
# Act
|
||||
await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
# Assert
|
||||
entry = entity_registry.async_get('sensor.sensor_1_battery')
|
||||
entry = entity_registry.async_get("sensor.sensor_1_battery")
|
||||
assert entry
|
||||
assert entry.unique_id == device.device_id + '.' + Attribute.battery
|
||||
entry = device_registry.async_get_device(
|
||||
{(DOMAIN, device.device_id)}, [])
|
||||
assert entry.unique_id == device.device_id + "." + Attribute.battery
|
||||
entry = device_registry.async_get_device({(DOMAIN, device.device_id)}, [])
|
||||
assert entry
|
||||
assert entry.name == device.label
|
||||
assert entry.model == device.device_type_name
|
||||
assert entry.manufacturer == 'Unavailable'
|
||||
assert entry.manufacturer == "Unavailable"
|
||||
|
||||
|
||||
async def test_update_from_signal(hass, device_factory):
|
||||
"""Test the binary_sensor updates when receiving a signal."""
|
||||
# Arrange
|
||||
device = device_factory('Sensor 1', [Capability.battery],
|
||||
{Attribute.battery: 100})
|
||||
device = device_factory("Sensor 1", [Capability.battery], {Attribute.battery: 100})
|
||||
await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
device.status.apply_attribute_update(
|
||||
'main', Capability.battery, Attribute.battery, 75)
|
||||
"main", Capability.battery, Attribute.battery, 75
|
||||
)
|
||||
# Act
|
||||
async_dispatcher_send(hass, SIGNAL_SMARTTHINGS_UPDATE,
|
||||
[device.device_id])
|
||||
async_dispatcher_send(hass, SIGNAL_SMARTTHINGS_UPDATE, [device.device_id])
|
||||
# Assert
|
||||
await hass.async_block_till_done()
|
||||
state = hass.states.get('sensor.sensor_1_battery')
|
||||
state = hass.states.get("sensor.sensor_1_battery")
|
||||
assert state is not None
|
||||
assert state.state == '75'
|
||||
assert state.state == "75"
|
||||
|
||||
|
||||
async def test_unload_config_entry(hass, device_factory):
|
||||
"""Test the binary_sensor is removed when the config entry is unloaded."""
|
||||
# Arrange
|
||||
device = device_factory('Sensor 1', [Capability.battery],
|
||||
{Attribute.battery: 100})
|
||||
device = device_factory("Sensor 1", [Capability.battery], {Attribute.battery: 100})
|
||||
config_entry = await setup_platform(hass, SENSOR_DOMAIN, devices=[device])
|
||||
# Act
|
||||
await hass.config_entries.async_forward_entry_unload(
|
||||
config_entry, 'sensor')
|
||||
await hass.config_entries.async_forward_entry_unload(config_entry, "sensor")
|
||||
# Assert
|
||||
assert not hass.states.get('sensor.sensor_1_battery')
|
||||
assert not hass.states.get("sensor.sensor_1_battery")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue