2016-03-09 09:25:50 +00:00
|
|
|
"""The tests for the StatsD feeder."""
|
2016-02-12 01:04:28 +00:00
|
|
|
import unittest
|
|
|
|
from unittest import mock
|
|
|
|
|
2016-09-14 01:22:30 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2016-02-13 08:08:32 +00:00
|
|
|
import homeassistant.core as ha
|
2016-02-12 01:04:28 +00:00
|
|
|
import homeassistant.components.statsd as statsd
|
2016-09-14 01:22:30 +00:00
|
|
|
from homeassistant.const import (STATE_ON, STATE_OFF, EVENT_STATE_CHANGED)
|
2016-02-12 01:04:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TestStatsd(unittest.TestCase):
|
2016-03-09 09:25:50 +00:00
|
|
|
"""Test the StatsD component."""
|
|
|
|
|
2016-09-14 01:22:30 +00:00
|
|
|
def test_invalid_config(self):
|
|
|
|
"""Test configuration with defaults."""
|
|
|
|
config = {
|
|
|
|
'statsd': {
|
|
|
|
'host1': 'host1',
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
with self.assertRaises(vol.Invalid):
|
|
|
|
statsd.CONFIG_SCHEMA(None)
|
|
|
|
with self.assertRaises(vol.Invalid):
|
|
|
|
statsd.CONFIG_SCHEMA(config)
|
|
|
|
|
2016-07-03 22:21:18 +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."""
|
2016-02-12 01:04:28 +00:00
|
|
|
config = {
|
|
|
|
'statsd': {
|
|
|
|
'host': 'host',
|
|
|
|
'port': 123,
|
|
|
|
'sample_rate': 1,
|
|
|
|
'prefix': 'foo',
|
|
|
|
}
|
|
|
|
}
|
|
|
|
hass = mock.MagicMock()
|
|
|
|
self.assertTrue(statsd.setup(hass, config))
|
2016-07-03 22:21:18 +00:00
|
|
|
mock_connection.assert_called_once_with(
|
|
|
|
host='host',
|
|
|
|
port=123,
|
|
|
|
prefix='foo')
|
|
|
|
|
2016-02-12 01:04:28 +00:00
|
|
|
self.assertTrue(hass.bus.listen.called)
|
|
|
|
self.assertEqual(EVENT_STATE_CHANGED,
|
|
|
|
hass.bus.listen.call_args_list[0][0][0])
|
|
|
|
|
2016-07-03 22:21:18 +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."""
|
2016-02-12 01:04:28 +00:00
|
|
|
config = {
|
|
|
|
'statsd': {
|
|
|
|
'host': 'host',
|
|
|
|
}
|
|
|
|
}
|
2016-09-14 01:22:30 +00:00
|
|
|
|
|
|
|
config['statsd'][statsd.CONF_PORT] = statsd.DEFAULT_PORT
|
|
|
|
config['statsd'][statsd.CONF_PREFIX] = statsd.DEFAULT_PREFIX
|
|
|
|
|
2016-02-12 01:04:28 +00:00
|
|
|
hass = mock.MagicMock()
|
|
|
|
self.assertTrue(statsd.setup(hass, config))
|
|
|
|
mock_connection.assert_called_once_with(
|
|
|
|
host='host',
|
2016-09-14 01:22:30 +00:00
|
|
|
port=8125,
|
|
|
|
prefix='hass')
|
2016-02-12 01:04:28 +00:00
|
|
|
self.assertTrue(hass.bus.listen.called)
|
|
|
|
|
2016-07-03 22:21:18 +00:00
|
|
|
@mock.patch('statsd.StatsClient')
|
2016-07-08 06:09:02 +00:00
|
|
|
def test_event_listener_defaults(self, mock_client):
|
2016-03-09 09:25:50 +00:00
|
|
|
"""Test event listener."""
|
2016-02-12 01:04:28 +00:00
|
|
|
config = {
|
|
|
|
'statsd': {
|
|
|
|
'host': 'host',
|
|
|
|
}
|
|
|
|
}
|
2016-09-14 01:22:30 +00:00
|
|
|
|
|
|
|
config['statsd'][statsd.CONF_RATE] = statsd.DEFAULT_RATE
|
|
|
|
|
2016-02-12 01:04:28 +00:00
|
|
|
hass = mock.MagicMock()
|
|
|
|
statsd.setup(hass, config)
|
|
|
|
self.assertTrue(hass.bus.listen.called)
|
|
|
|
handler_method = hass.bus.listen.call_args_list[0][0][1]
|
|
|
|
|
|
|
|
valid = {'1': 1,
|
|
|
|
'1.0': 1.0,
|
|
|
|
STATE_ON: 1,
|
|
|
|
STATE_OFF: 0}
|
|
|
|
for in_, out in valid.items():
|
2016-07-08 06:09:02 +00:00
|
|
|
state = mock.MagicMock(state=in_,
|
|
|
|
attributes={"attribute key": 3.2})
|
2016-02-12 01:04:28 +00:00
|
|
|
handler_method(mock.MagicMock(data={'new_state': state}))
|
2016-07-08 06:09:02 +00:00
|
|
|
mock_client.return_value.gauge.assert_has_calls([
|
|
|
|
mock.call(state.entity_id, out, statsd.DEFAULT_RATE),
|
|
|
|
])
|
|
|
|
|
|
|
|
mock_client.return_value.gauge.reset_mock()
|
|
|
|
|
|
|
|
mock_client.return_value.incr.assert_called_once_with(
|
|
|
|
state.entity_id, rate=statsd.DEFAULT_RATE)
|
|
|
|
mock_client.return_value.incr.reset_mock()
|
|
|
|
|
|
|
|
for invalid in ('foo', '', object):
|
|
|
|
handler_method(mock.MagicMock(data={
|
|
|
|
'new_state': ha.State('domain.test', invalid, {})}))
|
|
|
|
self.assertFalse(mock_client.return_value.gauge.called)
|
|
|
|
self.assertFalse(mock_client.return_value.incr.called)
|
|
|
|
|
|
|
|
@mock.patch('statsd.StatsClient')
|
|
|
|
def test_event_listener_attr_details(self, mock_client):
|
|
|
|
"""Test event listener."""
|
|
|
|
config = {
|
|
|
|
'statsd': {
|
|
|
|
'host': 'host',
|
|
|
|
'log_attributes': True
|
|
|
|
}
|
|
|
|
}
|
2016-09-14 01:22:30 +00:00
|
|
|
|
|
|
|
config['statsd'][statsd.CONF_RATE] = statsd.DEFAULT_RATE
|
|
|
|
|
2016-07-08 06:09:02 +00:00
|
|
|
hass = mock.MagicMock()
|
|
|
|
statsd.setup(hass, config)
|
|
|
|
self.assertTrue(hass.bus.listen.called)
|
|
|
|
handler_method = hass.bus.listen.call_args_list[0][0][1]
|
|
|
|
|
|
|
|
valid = {'1': 1,
|
|
|
|
'1.0': 1.0,
|
|
|
|
STATE_ON: 1,
|
|
|
|
STATE_OFF: 0}
|
|
|
|
for in_, out in valid.items():
|
|
|
|
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),
|
|
|
|
])
|
|
|
|
|
2016-07-03 22:21:18 +00:00
|
|
|
mock_client.return_value.gauge.reset_mock()
|
|
|
|
|
|
|
|
mock_client.return_value.incr.assert_called_once_with(
|
|
|
|
state.entity_id, rate=statsd.DEFAULT_RATE)
|
|
|
|
mock_client.return_value.incr.reset_mock()
|
2016-02-12 01:04:28 +00:00
|
|
|
|
|
|
|
for invalid in ('foo', '', object):
|
2016-02-13 08:08:32 +00:00
|
|
|
handler_method(mock.MagicMock(data={
|
|
|
|
'new_state': ha.State('domain.test', invalid, {})}))
|
2016-07-03 22:21:18 +00:00
|
|
|
self.assertFalse(mock_client.return_value.gauge.called)
|
|
|
|
self.assertFalse(mock_client.return_value.incr.called)
|