mirror of
https://github.com/home-assistant/core.git
synced 2025-08-06 14:15:12 +02:00
Add option to set entity_id on min_max sensor
This commit is contained in:
@@ -34,6 +34,7 @@ ATTR_TO_PROPERTY = [
|
|||||||
CONF_ENTITY_IDS = 'entity_ids'
|
CONF_ENTITY_IDS = 'entity_ids'
|
||||||
CONF_ROUND_DIGITS = 'round_digits'
|
CONF_ROUND_DIGITS = 'round_digits'
|
||||||
CONF_ICON = 'icon'
|
CONF_ICON = 'icon'
|
||||||
|
CONF_ID = 'id'
|
||||||
|
|
||||||
DEFAULT_ICON = 'mdi:calculator'
|
DEFAULT_ICON = 'mdi:calculator'
|
||||||
|
|
||||||
@@ -47,6 +48,7 @@ PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
|||||||
vol.Optional(CONF_TYPE, default=SENSOR_TYPES[ATTR_MAX_VALUE]):
|
vol.Optional(CONF_TYPE, default=SENSOR_TYPES[ATTR_MAX_VALUE]):
|
||||||
vol.All(cv.string, vol.In(SENSOR_TYPES.values())),
|
vol.All(cv.string, vol.In(SENSOR_TYPES.values())),
|
||||||
vol.Optional(CONF_NAME): cv.string,
|
vol.Optional(CONF_NAME): cv.string,
|
||||||
|
vol.Optional(CONF_ID): cv.string,
|
||||||
vol.Required(CONF_ENTITY_IDS): cv.entity_ids,
|
vol.Required(CONF_ENTITY_IDS): cv.entity_ids,
|
||||||
vol.Optional(CONF_ROUND_DIGITS, default=2): vol.Coerce(int),
|
vol.Optional(CONF_ROUND_DIGITS, default=2): vol.Coerce(int),
|
||||||
vol.Optional(CONF_ICON, default=DEFAULT_ICON): cv.string,
|
vol.Optional(CONF_ICON, default=DEFAULT_ICON): cv.string,
|
||||||
@@ -58,12 +60,13 @@ def async_setup_platform(hass, config, async_add_devices, discovery_info=None):
|
|||||||
"""Set up the min/max/mean sensor."""
|
"""Set up the min/max/mean sensor."""
|
||||||
entity_ids = config.get(CONF_ENTITY_IDS)
|
entity_ids = config.get(CONF_ENTITY_IDS)
|
||||||
name = config.get(CONF_NAME)
|
name = config.get(CONF_NAME)
|
||||||
|
eid = config.get(CONF_ID)
|
||||||
sensor_type = config.get(CONF_TYPE)
|
sensor_type = config.get(CONF_TYPE)
|
||||||
round_digits = config.get(CONF_ROUND_DIGITS)
|
round_digits = config.get(CONF_ROUND_DIGITS)
|
||||||
icon = config.get(CONF_ICON)
|
icon = config.get(CONF_ICON)
|
||||||
|
|
||||||
async_add_devices(
|
async_add_devices(
|
||||||
[MinMaxSensor(hass, entity_ids, name, sensor_type, round_digits,
|
[MinMaxSensor(hass, entity_ids, name, eid, sensor_type, round_digits,
|
||||||
icon)],
|
icon)],
|
||||||
True)
|
True)
|
||||||
return True
|
return True
|
||||||
@@ -105,10 +108,11 @@ def calc_mean(sensor_values, round_digits):
|
|||||||
class MinMaxSensor(Entity):
|
class MinMaxSensor(Entity):
|
||||||
"""Representation of a min/max sensor."""
|
"""Representation of a min/max sensor."""
|
||||||
|
|
||||||
def __init__(self, hass, entity_ids, name, sensor_type, round_digits,
|
def __init__(self, hass, entity_ids, name, eid, sensor_type, round_digits,
|
||||||
icon):
|
icon):
|
||||||
"""Initialize the min/max sensor."""
|
"""Initialize the min/max sensor."""
|
||||||
self._hass = hass
|
self._hass = hass
|
||||||
|
self.entity_id = eid
|
||||||
self._entity_ids = entity_ids
|
self._entity_ids = entity_ids
|
||||||
self._sensor_type = sensor_type
|
self._sensor_type = sensor_type
|
||||||
self._round_digits = round_digits
|
self._round_digits = round_digits
|
||||||
|
@@ -260,3 +260,25 @@ class TestMinMaxSensor(unittest.TestCase):
|
|||||||
|
|
||||||
self.assertEqual(STATE_UNKNOWN, state.state)
|
self.assertEqual(STATE_UNKNOWN, state.state)
|
||||||
self.assertEqual('ERR', state.attributes.get('unit_of_measurement'))
|
self.assertEqual('ERR', state.attributes.get('unit_of_measurement'))
|
||||||
|
|
||||||
|
def test_set_entity_id(self):
|
||||||
|
"""Test for setting entity id."""
|
||||||
|
config = {
|
||||||
|
'sensor': {
|
||||||
|
'platform': 'min_max',
|
||||||
|
'name': 'test',
|
||||||
|
'id': 'sensor.customid',
|
||||||
|
'type': 'mean',
|
||||||
|
'entity_ids': [
|
||||||
|
'sensor.test_1',
|
||||||
|
'sensor.test_2',
|
||||||
|
'sensor.test_3',
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert 'sensor.customid' not in self.hass.states.entity_ids()
|
||||||
|
|
||||||
|
assert setup_component(self.hass, 'sensor', config)
|
||||||
|
|
||||||
|
assert 'sensor.customid' in self.hass.states.entity_ids()
|
||||||
|
Reference in New Issue
Block a user