mirror of
https://github.com/home-assistant/core.git
synced 2025-12-24 21:06:19 +00:00
Clean up remote component (#8728)
* Clean up remote component * Don't have device be required in send_command service and method. * Don't have entity_id be required in the base service schema. * Don't always add activity in the data dict for a service call. * Update harmony remote platform according to new service schema. * Remove not needed properties and attributes from the Kira remote platform. * Add send_command method to demo platform. * Add tests and remove duplicate tests. * Break out required argument as positional argument
This commit is contained in:
committed by
Paulus Schoutsen
parent
e57d6f679a
commit
33663f9502
@@ -4,12 +4,10 @@ import unittest
|
||||
|
||||
from homeassistant.setup import setup_component
|
||||
import homeassistant.components.remote as remote
|
||||
from homeassistant.const import (
|
||||
ATTR_ENTITY_ID, STATE_ON, STATE_OFF, CONF_PLATFORM,
|
||||
SERVICE_TURN_ON, SERVICE_TURN_OFF)
|
||||
from tests.common import get_test_home_assistant, mock_service
|
||||
from homeassistant.const import STATE_ON, STATE_OFF
|
||||
from tests.common import get_test_home_assistant
|
||||
|
||||
SERVICE_SEND_COMMAND = 'send_command'
|
||||
ENTITY_ID = 'remote.remote_one'
|
||||
|
||||
|
||||
class TestDemoRemote(unittest.TestCase):
|
||||
@@ -29,71 +27,25 @@ class TestDemoRemote(unittest.TestCase):
|
||||
self.hass.stop()
|
||||
|
||||
def test_methods(self):
|
||||
"""Test if methods call the services as expected."""
|
||||
self.assertTrue(
|
||||
setup_component(self.hass, remote.DOMAIN,
|
||||
{remote.DOMAIN: {CONF_PLATFORM: 'demo'}}))
|
||||
|
||||
# Test is_on
|
||||
self.hass.states.set('remote.demo', STATE_ON)
|
||||
self.assertTrue(remote.is_on(self.hass, 'remote.demo'))
|
||||
|
||||
self.hass.states.set('remote.demo', STATE_OFF)
|
||||
self.assertFalse(remote.is_on(self.hass, 'remote.demo'))
|
||||
|
||||
self.hass.states.set(remote.ENTITY_ID_ALL_REMOTES, STATE_ON)
|
||||
self.assertTrue(remote.is_on(self.hass))
|
||||
|
||||
self.hass.states.set(remote.ENTITY_ID_ALL_REMOTES, STATE_OFF)
|
||||
self.assertFalse(remote.is_on(self.hass))
|
||||
|
||||
def test_services(self):
|
||||
"""Test the provided services."""
|
||||
# Test turn_on
|
||||
turn_on_calls = mock_service(
|
||||
self.hass, remote.DOMAIN, SERVICE_TURN_ON)
|
||||
|
||||
remote.turn_on(
|
||||
self.hass,
|
||||
entity_id='entity_id_val')
|
||||
|
||||
"""Test if services call the entity methods as expected."""
|
||||
remote.turn_on(self.hass, entity_id=ENTITY_ID)
|
||||
self.hass.block_till_done()
|
||||
state = self.hass.states.get(ENTITY_ID)
|
||||
self.assertEqual(state.state, STATE_ON)
|
||||
|
||||
self.assertEqual(1, len(turn_on_calls))
|
||||
call = turn_on_calls[-1]
|
||||
|
||||
self.assertEqual(remote.DOMAIN, call.domain)
|
||||
|
||||
# Test turn_off
|
||||
turn_off_calls = mock_service(
|
||||
self.hass, remote.DOMAIN, SERVICE_TURN_OFF)
|
||||
|
||||
remote.turn_off(
|
||||
self.hass, entity_id='entity_id_val')
|
||||
|
||||
remote.turn_off(self.hass, entity_id=ENTITY_ID)
|
||||
self.hass.block_till_done()
|
||||
state = self.hass.states.get(ENTITY_ID)
|
||||
self.assertEqual(state.state, STATE_OFF)
|
||||
|
||||
self.assertEqual(1, len(turn_off_calls))
|
||||
call = turn_off_calls[-1]
|
||||
|
||||
self.assertEqual(remote.DOMAIN, call.domain)
|
||||
self.assertEqual(SERVICE_TURN_OFF, call.service)
|
||||
self.assertEqual('entity_id_val', call.data[ATTR_ENTITY_ID])
|
||||
|
||||
# Test send_command
|
||||
send_command_calls = mock_service(
|
||||
self.hass, remote.DOMAIN, SERVICE_SEND_COMMAND)
|
||||
|
||||
remote.send_command(
|
||||
self.hass, entity_id='entity_id_val',
|
||||
device='test_device', command=['test_command'],
|
||||
num_repeats='2', delay_secs='0.8')
|
||||
|
||||
remote.turn_on(self.hass, entity_id=ENTITY_ID)
|
||||
self.hass.block_till_done()
|
||||
state = self.hass.states.get(ENTITY_ID)
|
||||
self.assertEqual(state.state, STATE_ON)
|
||||
|
||||
self.assertEqual(1, len(send_command_calls))
|
||||
call = send_command_calls[-1]
|
||||
|
||||
self.assertEqual(remote.DOMAIN, call.domain)
|
||||
self.assertEqual(SERVICE_SEND_COMMAND, call.service)
|
||||
self.assertEqual('entity_id_val', call.data[ATTR_ENTITY_ID])
|
||||
remote.send_command(self.hass, 'test', entity_id=ENTITY_ID)
|
||||
self.hass.block_till_done()
|
||||
state = self.hass.states.get(ENTITY_ID)
|
||||
self.assertEqual(
|
||||
state.attributes,
|
||||
{'friendly_name': 'Remote One', 'last_command_sent': 'test'})
|
||||
|
||||
Reference in New Issue
Block a user