Fixed bug in rfxtrx sensor
This commit is contained in:
parent
557dae7ab3
commit
c4062bf6ea
2 changed files with 123 additions and 1 deletions
|
@ -39,7 +39,7 @@ def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
||||||
event = rfxtrx.get_rfx_object(entity_info[ATTR_PACKETID])
|
event = rfxtrx.get_rfx_object(entity_info[ATTR_PACKETID])
|
||||||
new_sensor = RfxtrxSensor(event, entity_info[ATTR_NAME],
|
new_sensor = RfxtrxSensor(event, entity_info[ATTR_NAME],
|
||||||
entity_info.get(ATTR_DATA_TYPE, None))
|
entity_info.get(ATTR_DATA_TYPE, None))
|
||||||
rfxtrx.RFX_DEVICES[device_id] = new_sensor
|
rfxtrx.RFX_DEVICES[slugify(device_id)] = new_sensor
|
||||||
sensors.append(new_sensor)
|
sensors.append(new_sensor)
|
||||||
|
|
||||||
add_devices_callback(sensors)
|
add_devices_callback(sensors)
|
||||||
|
@ -53,6 +53,12 @@ def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
||||||
|
|
||||||
if device_id in rfxtrx.RFX_DEVICES:
|
if device_id in rfxtrx.RFX_DEVICES:
|
||||||
rfxtrx.RFX_DEVICES[device_id].event = event
|
rfxtrx.RFX_DEVICES[device_id].event = event
|
||||||
|
k = 2
|
||||||
|
_device_id = device_id + "_" + str(k)
|
||||||
|
while _device_id in rfxtrx.RFX_DEVICES:
|
||||||
|
rfxtrx.RFX_DEVICES[_device_id].event = event
|
||||||
|
k = k + 1
|
||||||
|
_device_id = device_id + "_" + str(k)
|
||||||
return
|
return
|
||||||
|
|
||||||
# Add entity if not exist and the automatic_add is True
|
# Add entity if not exist and the automatic_add is True
|
||||||
|
|
|
@ -86,6 +86,7 @@ class TestSensorRfxtrx(unittest.TestCase):
|
||||||
rfxtrx.setup_platform(self.hass, config, add_dev_callback)
|
rfxtrx.setup_platform(self.hass, config, add_dev_callback)
|
||||||
|
|
||||||
self.assertEqual(3, len(devices))
|
self.assertEqual(3, len(devices))
|
||||||
|
self.assertEqual(3, len(rfxtrx_core.RFX_DEVICES))
|
||||||
device_num = 0
|
device_num = 0
|
||||||
for entity in devices:
|
for entity in devices:
|
||||||
if entity.name == 'Bath_Humidity':
|
if entity.name == 'Bath_Humidity':
|
||||||
|
@ -133,6 +134,7 @@ class TestSensorRfxtrx(unittest.TestCase):
|
||||||
devices.append(dev)
|
devices.append(dev)
|
||||||
|
|
||||||
rfxtrx.setup_platform(self.hass, config, add_dev_callback)
|
rfxtrx.setup_platform(self.hass, config, add_dev_callback)
|
||||||
|
|
||||||
event = rfxtrx_core.get_rfx_object('0a520801070100b81b0279')
|
event = rfxtrx_core.get_rfx_object('0a520801070100b81b0279')
|
||||||
event.data = bytearray(b'\nR\x08\x01\x07\x01\x00\xb8\x1b\x02y')
|
event.data = bytearray(b'\nR\x08\x01\x07\x01\x00\xb8\x1b\x02y')
|
||||||
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
||||||
|
@ -223,3 +225,117 @@ class TestSensorRfxtrx(unittest.TestCase):
|
||||||
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
||||||
self.assertEqual(0, len(rfxtrx_core.RFX_DEVICES))
|
self.assertEqual(0, len(rfxtrx_core.RFX_DEVICES))
|
||||||
self.assertEqual(0, len(devices))
|
self.assertEqual(0, len(devices))
|
||||||
|
|
||||||
|
def test_update_of_sensors(self):
|
||||||
|
"""Test with 3 sensors."""
|
||||||
|
config = {'devices':
|
||||||
|
{'sensor_0502': {
|
||||||
|
'name': 'Test',
|
||||||
|
'packetid': '0a52080705020095220269',
|
||||||
|
'data_type': 'Temperature'},
|
||||||
|
'sensor_0601': {
|
||||||
|
'name': 'Bath_Humidity',
|
||||||
|
'packetid': '0a520802060100ff0e0269',
|
||||||
|
'data_type': 'Humidity'},
|
||||||
|
'sensor_0601 2': {
|
||||||
|
'name': 'Bath',
|
||||||
|
'packetid': '0a520802060100ff0e0269'}}}
|
||||||
|
devices = []
|
||||||
|
|
||||||
|
def add_dev_callback(devs):
|
||||||
|
"""Add a callback to add devices."""
|
||||||
|
for dev in devs:
|
||||||
|
devices.append(dev)
|
||||||
|
|
||||||
|
rfxtrx.setup_platform(self.hass, config, add_dev_callback)
|
||||||
|
|
||||||
|
self.assertEqual(3, len(devices))
|
||||||
|
self.assertEqual(3, len(rfxtrx_core.RFX_DEVICES))
|
||||||
|
|
||||||
|
device_num = 0
|
||||||
|
for entity in devices:
|
||||||
|
if entity.name == 'Bath_Humidity':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual('%', entity.unit_of_measurement)
|
||||||
|
self.assertEqual(14, entity.state)
|
||||||
|
self.assertEqual({'Battery numeric': 9, 'Temperature': 25.5,
|
||||||
|
'Humidity': 14, 'Humidity status': 'normal',
|
||||||
|
'Humidity status numeric': 2,
|
||||||
|
'Rssi numeric': 6},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Bath_Humidity', entity.__str__())
|
||||||
|
elif entity.name == 'Bath':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual(TEMP_CELCIUS, entity.unit_of_measurement)
|
||||||
|
self.assertEqual(25.5, entity.state)
|
||||||
|
self.assertEqual({'Battery numeric': 9, 'Temperature': 25.5,
|
||||||
|
'Humidity': 14, 'Humidity status': 'normal',
|
||||||
|
'Humidity status numeric': 2,
|
||||||
|
'Rssi numeric': 6},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Bath', entity.__str__())
|
||||||
|
elif entity.name == 'Test':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual(TEMP_CELCIUS, entity.unit_of_measurement)
|
||||||
|
self.assertEqual(14.9, entity.state)
|
||||||
|
self.assertEqual({'Humidity status': 'normal',
|
||||||
|
'Temperature': 14.9,
|
||||||
|
'Rssi numeric': 6, 'Humidity': 34,
|
||||||
|
'Battery numeric': 9,
|
||||||
|
'Humidity status numeric': 2},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Test', entity.__str__())
|
||||||
|
|
||||||
|
self.assertEqual(3, device_num)
|
||||||
|
|
||||||
|
event = rfxtrx_core.get_rfx_object('0a520802060101ff0f0269')
|
||||||
|
event.data = bytearray(b'\nR\x08\x01\x07\x01\x00\xb8\x1b\x02y')
|
||||||
|
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
||||||
|
entity = devices[0]
|
||||||
|
|
||||||
|
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
||||||
|
event = rfxtrx_core.get_rfx_object('0a52080705020085220269')
|
||||||
|
event.data = bytearray(b'\nR\x08\x04\x05\x02\x00\x95$\x02y')
|
||||||
|
rfxtrx_core.RECEIVED_EVT_SUBSCRIBERS[0](event)
|
||||||
|
|
||||||
|
self.assertEqual(3, len(devices))
|
||||||
|
self.assertEqual(3, len(rfxtrx_core.RFX_DEVICES))
|
||||||
|
|
||||||
|
device_num = 0
|
||||||
|
for entity in devices:
|
||||||
|
if entity.name == 'Bath_Humidity':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual('%', entity.unit_of_measurement)
|
||||||
|
self.assertEqual(15, entity.state)
|
||||||
|
self.assertEqual({'Battery numeric': 9, 'Temperature': 51.1,
|
||||||
|
'Humidity': 15, 'Humidity status': 'normal',
|
||||||
|
'Humidity status numeric': 2,
|
||||||
|
'Rssi numeric': 6},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Bath_Humidity', entity.__str__())
|
||||||
|
elif entity.name == 'Bath':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual(TEMP_CELCIUS, entity.unit_of_measurement)
|
||||||
|
self.assertEqual(51.1, entity.state)
|
||||||
|
self.assertEqual({'Battery numeric': 9, 'Temperature': 51.1,
|
||||||
|
'Humidity': 15, 'Humidity status': 'normal',
|
||||||
|
'Humidity status numeric': 2,
|
||||||
|
'Rssi numeric': 6},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Bath', entity.__str__())
|
||||||
|
elif entity.name == 'Test':
|
||||||
|
device_num = device_num + 1
|
||||||
|
self.assertEqual(TEMP_CELCIUS, entity.unit_of_measurement)
|
||||||
|
self.assertEqual(13.3, entity.state)
|
||||||
|
self.assertEqual({'Humidity status': 'normal',
|
||||||
|
'Temperature': 13.3,
|
||||||
|
'Rssi numeric': 6, 'Humidity': 34,
|
||||||
|
'Battery numeric': 9,
|
||||||
|
'Humidity status numeric': 2},
|
||||||
|
entity.device_state_attributes)
|
||||||
|
self.assertEqual('Test', entity.__str__())
|
||||||
|
|
||||||
|
self.assertEqual(3, device_num)
|
||||||
|
|
||||||
|
self.assertEqual(3, len(devices))
|
||||||
|
self.assertEqual(3, len(rfxtrx_core.RFX_DEVICES))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue