core/tests/components/statsd/test_init.py

140 lines
5.4 KiB
Python
Raw Normal View History

2016-03-09 09:25:50 +00:00
"""The tests for the StatsD feeder."""
import unittest
from unittest import mock
import voluptuous as vol
from homeassistant.setup import setup_component
import homeassistant.core as ha
import homeassistant.components.statsd as statsd
2019-07-31 19:25:30 +00:00
from homeassistant.const import STATE_ON, STATE_OFF, EVENT_STATE_CHANGED
from tests.common import get_test_home_assistant
import pytest
class TestStatsd(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test the StatsD component."""
def setUp(self): # pylint: disable=invalid-name
2018-08-19 20:29:08 +00:00
"""Set up things to be run when tests are started."""
self.hass = get_test_home_assistant()
def tearDown(self): # pylint: disable=invalid-name
"""Stop everything that was started."""
self.hass.stop()
def test_invalid_config(self):
"""Test configuration with defaults."""
2019-07-31 19:25:30 +00:00
config = {"statsd": {"host1": "host1"}}
with pytest.raises(vol.Invalid):
statsd.CONFIG_SCHEMA(None)
with pytest.raises(vol.Invalid):
statsd.CONFIG_SCHEMA(config)
2019-07-31 19:25:30 +00:00
@mock.patch("statsd.StatsClient")
def test_statsd_setup_full(self, mock_connection):
2016-03-09 09:25:50 +00:00
"""Test setup with all data."""
2019-07-31 19:25:30 +00:00
config = {"statsd": {"host": "host", "port": 123, "rate": 1, "prefix": "foo"}}
self.hass.bus.listen = mock.MagicMock()
assert setup_component(self.hass, statsd.DOMAIN, config)
assert mock_connection.call_count == 1
2019-07-31 19:25:30 +00:00
assert mock_connection.call_args == mock.call(
host="host", port=123, prefix="foo"
)
assert self.hass.bus.listen.called
2019-07-31 19:25:30 +00:00
assert EVENT_STATE_CHANGED == self.hass.bus.listen.call_args_list[0][0][0]
2019-07-31 19:25:30 +00:00
@mock.patch("statsd.StatsClient")
def test_statsd_setup_defaults(self, mock_connection):
2016-03-09 09:25:50 +00:00
"""Test setup with defaults."""
2019-07-31 19:25:30 +00:00
config = {"statsd": {"host": "host"}}
2019-07-31 19:25:30 +00:00
config["statsd"][statsd.CONF_PORT] = statsd.DEFAULT_PORT
config["statsd"][statsd.CONF_PREFIX] = statsd.DEFAULT_PREFIX
self.hass.bus.listen = mock.MagicMock()
assert setup_component(self.hass, statsd.DOMAIN, config)
assert mock_connection.call_count == 1
2019-07-31 19:25:30 +00:00
assert mock_connection.call_args == mock.call(
host="host", port=8125, prefix="hass"
)
assert self.hass.bus.listen.called
2019-07-31 19:25:30 +00:00
@mock.patch("statsd.StatsClient")
def test_event_listener_defaults(self, mock_client):
2016-03-09 09:25:50 +00:00
"""Test event listener."""
2019-07-31 19:25:30 +00:00
config = {"statsd": {"host": "host", "value_mapping": {"custom": 3}}}
2019-07-31 19:25:30 +00:00
config["statsd"][statsd.CONF_RATE] = statsd.DEFAULT_RATE
self.hass.bus.listen = mock.MagicMock()
setup_component(self.hass, statsd.DOMAIN, config)
assert self.hass.bus.listen.called
handler_method = self.hass.bus.listen.call_args_list[0][0][1]
2019-07-31 19:25:30 +00:00
valid = {"1": 1, "1.0": 1.0, "custom": 3, STATE_ON: 1, STATE_OFF: 0}
for in_, out in valid.items():
2019-07-31 19:25:30 +00:00
state = mock.MagicMock(state=in_, attributes={"attribute key": 3.2})
handler_method(mock.MagicMock(data={"new_state": state}))
mock_client.return_value.gauge.assert_has_calls(
[mock.call(state.entity_id, out, statsd.DEFAULT_RATE)]
)
mock_client.return_value.gauge.reset_mock()
assert mock_client.return_value.incr.call_count == 1
2019-07-31 19:25:30 +00:00
assert mock_client.return_value.incr.call_args == mock.call(
state.entity_id, rate=statsd.DEFAULT_RATE
)
mock_client.return_value.incr.reset_mock()
2019-07-31 19:25:30 +00:00
for invalid in ("foo", "", object):
handler_method(
mock.MagicMock(data={"new_state": ha.State("domain.test", invalid, {})})
)
assert not mock_client.return_value.gauge.called
assert mock_client.return_value.incr.called
2019-07-31 19:25:30 +00:00
@mock.patch("statsd.StatsClient")
def test_event_listener_attr_details(self, mock_client):
"""Test event listener."""
2019-07-31 19:25:30 +00:00
config = {"statsd": {"host": "host", "log_attributes": True}}
2019-07-31 19:25:30 +00:00
config["statsd"][statsd.CONF_RATE] = statsd.DEFAULT_RATE
self.hass.bus.listen = mock.MagicMock()
setup_component(self.hass, statsd.DOMAIN, config)
assert self.hass.bus.listen.called
handler_method = self.hass.bus.listen.call_args_list[0][0][1]
2019-07-31 19:25:30 +00:00
valid = {"1": 1, "1.0": 1.0, STATE_ON: 1, STATE_OFF: 0}
for in_, out in valid.items():
2019-07-31 19:25:30 +00:00
state = mock.MagicMock(state=in_, attributes={"attribute key": 3.2})
handler_method(mock.MagicMock(data={"new_state": state}))
mock_client.return_value.gauge.assert_has_calls(
[
mock.call("%s.state" % state.entity_id, out, statsd.DEFAULT_RATE),
mock.call(
"%s.attribute_key" % state.entity_id, 3.2, statsd.DEFAULT_RATE
),
]
)
mock_client.return_value.gauge.reset_mock()
assert mock_client.return_value.incr.call_count == 1
2019-07-31 19:25:30 +00:00
assert mock_client.return_value.incr.call_args == mock.call(
state.entity_id, rate=statsd.DEFAULT_RATE
)
mock_client.return_value.incr.reset_mock()
2019-07-31 19:25:30 +00:00
for invalid in ("foo", "", object):
handler_method(
mock.MagicMock(data={"new_state": ha.State("domain.test", invalid, {})})
)
assert not mock_client.return_value.gauge.called
assert mock_client.return_value.incr.called