Add input_select component
This commit is contained in:
parent
c95c3d9198
commit
96710ad410
2 changed files with 274 additions and 0 deletions
132
tests/components/test_input_select.py
Normal file
132
tests/components/test_input_select.py
Normal file
|
@ -0,0 +1,132 @@
|
|||
"""
|
||||
tests.components.test_input_select
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Tests input_select component.
|
||||
"""
|
||||
# pylint: disable=too-many-public-methods,protected-access
|
||||
import unittest
|
||||
|
||||
from homeassistant.components import input_select
|
||||
from homeassistant.const import (
|
||||
ATTR_ICON, ATTR_FRIENDLY_NAME)
|
||||
|
||||
from tests.common import get_test_home_assistant
|
||||
|
||||
|
||||
class TestInputSelect(unittest.TestCase):
|
||||
""" Test the input select module. """
|
||||
|
||||
def setUp(self): # pylint: disable=invalid-name
|
||||
self.hass = get_test_home_assistant()
|
||||
|
||||
def tearDown(self): # pylint: disable=invalid-name
|
||||
""" Stop down stuff we started. """
|
||||
self.hass.stop()
|
||||
|
||||
def test_config(self):
|
||||
"""Test config."""
|
||||
self.assertFalse(input_select.setup(self.hass, {
|
||||
'input_select': None
|
||||
}))
|
||||
|
||||
self.assertFalse(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
}
|
||||
}))
|
||||
|
||||
self.assertFalse(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
'name with space': None
|
||||
}
|
||||
}))
|
||||
|
||||
self.assertFalse(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
'hello': {
|
||||
'options': None
|
||||
}
|
||||
}
|
||||
}))
|
||||
|
||||
self.assertFalse(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
'hello': None
|
||||
}
|
||||
}))
|
||||
|
||||
def test_select_option(self):
|
||||
""" Test select_option methods. """
|
||||
self.assertTrue(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
'test_1': {
|
||||
'options': [
|
||||
'some option',
|
||||
'another option',
|
||||
],
|
||||
},
|
||||
}
|
||||
}))
|
||||
entity_id = 'input_select.test_1'
|
||||
|
||||
state = self.hass.states.get(entity_id)
|
||||
self.assertEqual('some option', state.state)
|
||||
|
||||
input_select.select_option(self.hass, entity_id, 'another option')
|
||||
self.hass.pool.block_till_done()
|
||||
|
||||
state = self.hass.states.get(entity_id)
|
||||
self.assertEqual('another option', state.state)
|
||||
|
||||
input_select.select_option(self.hass, entity_id, 'non existing option')
|
||||
self.hass.pool.block_till_done()
|
||||
|
||||
state = self.hass.states.get(entity_id)
|
||||
self.assertEqual('another option', state.state)
|
||||
|
||||
def test_config_options(self):
|
||||
count_start = len(self.hass.states.entity_ids())
|
||||
|
||||
test_2_options = [
|
||||
'Good Option',
|
||||
'Better Option',
|
||||
'Best Option',
|
||||
]
|
||||
|
||||
self.assertTrue(input_select.setup(self.hass, {
|
||||
'input_select': {
|
||||
'test_1': {
|
||||
'options': [
|
||||
1,
|
||||
2,
|
||||
],
|
||||
},
|
||||
'test_2': {
|
||||
'name': 'Hello World',
|
||||
'icon': 'work',
|
||||
'options': test_2_options,
|
||||
'initial': 'Better Option',
|
||||
},
|
||||
},
|
||||
}))
|
||||
|
||||
self.assertEqual(count_start + 2, len(self.hass.states.entity_ids()))
|
||||
|
||||
state_1 = self.hass.states.get('input_select.test_1')
|
||||
state_2 = self.hass.states.get('input_select.test_2')
|
||||
|
||||
self.assertIsNotNone(state_1)
|
||||
self.assertIsNotNone(state_2)
|
||||
|
||||
self.assertEqual('1', state_1.state)
|
||||
self.assertEqual(['1', '2'],
|
||||
state_1.attributes.get(input_select.ATTR_OPTIONS))
|
||||
self.assertNotIn(ATTR_ICON, state_1.attributes)
|
||||
self.assertNotIn(ATTR_FRIENDLY_NAME, state_1.attributes)
|
||||
|
||||
self.assertEqual('Better Option', state_2.state)
|
||||
self.assertEqual(test_2_options,
|
||||
state_2.attributes.get(input_select.ATTR_OPTIONS))
|
||||
self.assertEqual('Hello World',
|
||||
state_2.attributes.get(ATTR_FRIENDLY_NAME))
|
||||
self.assertEqual('work', state_2.attributes.get(ATTR_ICON))
|
Loading…
Add table
Add a link
Reference in a new issue