mirror of
https://github.com/home-assistant/core.git
synced 2025-07-15 01:07:10 +00:00
Config validation for MQTT sensor platform.
This commit is contained in:
parent
3383854506
commit
eb3f812e38
@ -6,33 +6,42 @@ https://home-assistant.io/components/sensor.mqtt/
|
|||||||
"""
|
"""
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
|
import voluptuous as vol
|
||||||
|
|
||||||
import homeassistant.components.mqtt as mqtt
|
import homeassistant.components.mqtt as mqtt
|
||||||
from homeassistant.const import CONF_VALUE_TEMPLATE, STATE_UNKNOWN
|
from homeassistant.const import CONF_NAME, CONF_VALUE_TEMPLATE, STATE_UNKNOWN
|
||||||
|
import homeassistant.helpers.config_validation as cv
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
from homeassistant.helpers import template
|
from homeassistant.helpers import template
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
DEFAULT_NAME = "MQTT Sensor"
|
|
||||||
DEFAULT_QOS = 0
|
|
||||||
|
|
||||||
DEPENDENCIES = ['mqtt']
|
DEPENDENCIES = ['mqtt']
|
||||||
|
|
||||||
|
CONF_STATE_TOPIC = 'state_topic'
|
||||||
|
CONF_UNIT_OF_MEASUREMENT = 'unit_of_measurement'
|
||||||
|
|
||||||
|
DEFAULT_NAME = "MQTT Sensor"
|
||||||
|
|
||||||
|
PLATFORM_SCHEMA = mqtt.MQTT_BASE_PLATFORM_SCHEMA.extend({
|
||||||
|
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
|
||||||
|
vol.Required(CONF_STATE_TOPIC): mqtt.valid_subscribe_topic,
|
||||||
|
vol.Optional(CONF_UNIT_OF_MEASUREMENT): cv.string,
|
||||||
|
vol.Optional(CONF_VALUE_TEMPLATE): cv.template,
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
# pylint: disable=unused-argument
|
# pylint: disable=unused-argument
|
||||||
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
||||||
"""Setup MQTT Sensor."""
|
"""Setup MQTT Sensor."""
|
||||||
if config.get('state_topic') is None:
|
|
||||||
_LOGGER.error("Missing required variable: state_topic")
|
|
||||||
return False
|
|
||||||
|
|
||||||
add_devices_callback([MqttSensor(
|
add_devices_callback([MqttSensor(
|
||||||
hass,
|
hass,
|
||||||
config.get('name', DEFAULT_NAME),
|
config[CONF_NAME],
|
||||||
config.get('state_topic'),
|
config[CONF_STATE_TOPIC],
|
||||||
config.get('qos', DEFAULT_QOS),
|
config[mqtt.CONF_QOS],
|
||||||
config.get('unit_of_measurement'),
|
config.get(CONF_UNIT_OF_MEASUREMENT),
|
||||||
config.get(CONF_VALUE_TEMPLATE))])
|
config.get(CONF_VALUE_TEMPLATE),
|
||||||
|
)])
|
||||||
|
|
||||||
|
|
||||||
# pylint: disable=too-many-arguments, too-many-instance-attributes
|
# pylint: disable=too-many-arguments, too-many-instance-attributes
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
"""The tests for the MQTT sensor platform."""
|
"""The tests for the MQTT sensor platform."""
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
|
from homeassistant.bootstrap import _setup_component
|
||||||
import homeassistant.components.sensor as sensor
|
import homeassistant.components.sensor as sensor
|
||||||
from tests.common import mock_mqtt_component, fire_mqtt_message
|
from tests.common import mock_mqtt_component, fire_mqtt_message
|
||||||
|
|
||||||
@ -21,14 +22,15 @@ class TestSensorMQTT(unittest.TestCase):
|
|||||||
|
|
||||||
def test_setting_sensor_value_via_mqtt_message(self):
|
def test_setting_sensor_value_via_mqtt_message(self):
|
||||||
"""Test the setting of the value via MQTT."""
|
"""Test the setting of the value via MQTT."""
|
||||||
self.assertTrue(sensor.setup(self.hass, {
|
self.hass.config.components = ['mqtt']
|
||||||
'sensor': {
|
assert _setup_component(self.hass, sensor.DOMAIN, {
|
||||||
|
sensor.DOMAIN: {
|
||||||
'platform': 'mqtt',
|
'platform': 'mqtt',
|
||||||
'name': 'test',
|
'name': 'test',
|
||||||
'state_topic': 'test-topic',
|
'state_topic': 'test-topic',
|
||||||
'unit_of_measurement': 'fav unit'
|
'unit_of_measurement': 'fav unit'
|
||||||
}
|
}
|
||||||
}))
|
})
|
||||||
|
|
||||||
fire_mqtt_message(self.hass, 'test-topic', '100')
|
fire_mqtt_message(self.hass, 'test-topic', '100')
|
||||||
self.hass.pool.block_till_done()
|
self.hass.pool.block_till_done()
|
||||||
@ -40,15 +42,16 @@ class TestSensorMQTT(unittest.TestCase):
|
|||||||
|
|
||||||
def test_setting_sensor_value_via_mqtt_json_message(self):
|
def test_setting_sensor_value_via_mqtt_json_message(self):
|
||||||
"""Test the setting of the value via MQTT with JSON playload."""
|
"""Test the setting of the value via MQTT with JSON playload."""
|
||||||
self.assertTrue(sensor.setup(self.hass, {
|
self.hass.config.components = ['mqtt']
|
||||||
'sensor': {
|
assert _setup_component(self.hass, sensor.DOMAIN, {
|
||||||
|
sensor.DOMAIN: {
|
||||||
'platform': 'mqtt',
|
'platform': 'mqtt',
|
||||||
'name': 'test',
|
'name': 'test',
|
||||||
'state_topic': 'test-topic',
|
'state_topic': 'test-topic',
|
||||||
'unit_of_measurement': 'fav unit',
|
'unit_of_measurement': 'fav unit',
|
||||||
'value_template': '{{ value_json.val }}'
|
'value_template': '{{ value_json.val }}'
|
||||||
}
|
}
|
||||||
}))
|
})
|
||||||
|
|
||||||
fire_mqtt_message(self.hass, 'test-topic', '{ "val": "100" }')
|
fire_mqtt_message(self.hass, 'test-topic', '{ "val": "100" }')
|
||||||
self.hass.pool.block_till_done()
|
self.hass.pool.block_till_done()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user