async def test_trigger_with_specific_trigger_time(hass): """Test disarm after trigger.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'disarmed': { 'trigger_time': 5 }, 'pending_time': 0, 'disarm_after_trigger': True }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_trigger_with_zero_specific_trigger_time(hass): """Test trigger method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'trigger_time': 5, 'disarmed': { 'trigger_time': 0 }, 'pending_time': 0, 'disarm_after_trigger': True } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_trigger_with_zero_specific_trigger_time(hass): """Test trigger method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'trigger_time': 5, 'disarmed': { 'trigger_time': 0 }, 'pending_time': 0, 'disarm_after_trigger': True }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_trigger_no_pending(hass): """Test triggering when no pending submitted method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'trigger_time': 1, 'disarm_after_trigger': False }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=60) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state
async def test_trigger_with_specific_trigger_time(hass): """Test disarm after trigger.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'disarmed': { 'trigger_time': 5 }, 'pending_time': 0, 'disarm_after_trigger': True } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_trigger_no_pending(hass): """Test triggering when no pending submitted method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'trigger_time': 1, 'disarm_after_trigger': False } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=60) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state
async def test_trigger_with_pending_and_specific_delay(hass): """Test trigger method and switch from pending to triggered.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'code': CODE, 'delay_time': 10, 'pending_time': 0, 'armed_away': { 'delay_time': 1 }, 'triggered': { 'pending_time': 1 }, 'disarm_after_trigger': False } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_arm_away(hass, CODE) await hass.async_block_till_done() assert STATE_ALARM_ARMED_AWAY == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_PENDING assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=1) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_PENDING assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future += timedelta(seconds=1) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_TRIGGERED
async def test_trigger_with_pending_and_specific_delay(hass): """Test trigger method and switch from pending to triggered.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'code': CODE, 'delay_time': 10, 'pending_time': 0, 'armed_away': { 'delay_time': 1 }, 'triggered': { 'pending_time': 1 }, 'disarm_after_trigger': False }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_arm_away(hass, CODE) await hass.async_block_till_done() assert STATE_ALARM_ARMED_AWAY == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass, entity_id=entity_id) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_PENDING assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=1) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_PENDING assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future += timedelta(seconds=1) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_TRIGGERED
async def test_trigger_with_pending(hass): """Test arm home method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 2, 'trigger_time': 3, 'disarm_after_trigger': False } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state state = hass.states.get(entity_id) assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=2) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_DISARMED
async def test_trigger_with_pending(hass): """Test arm home method.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 2, 'trigger_time': 3, 'disarm_after_trigger': False }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state state = hass.states.get(entity_id) assert state.attributes['post_pending_state'] == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=2) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_TRIGGERED future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() state = hass.states.get(entity_id) assert state.state == STATE_ALARM_DISARMED
async def test_trigger_zero_trigger_time_with_pending(hass): """Test disabled trigger.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 2, 'trigger_time': 0, 'disarm_after_trigger': False }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_disarm_during_trigger_with_invalid_code(hass): """Test disarming while code is invalid.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 5, 'code': CODE + '2', 'disarm_after_trigger': False } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state common.async_alarm_disarm(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.alarm_control_panel.manual.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state
async def test_trigger_zero_trigger_time_with_pending(hass): """Test disabled trigger.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, { 'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 2, 'trigger_time': 0, 'disarm_after_trigger': False } }) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state
async def test_disarm_during_trigger_with_invalid_code(hass): """Test disarming while code is invalid.""" assert await async_setup_component( hass, alarm_control_panel.DOMAIN, {'alarm_control_panel': { 'platform': 'manual', 'name': 'test', 'pending_time': 5, 'code': CODE + '2', 'disarm_after_trigger': False }}) entity_id = 'alarm_control_panel.test' assert STATE_ALARM_DISARMED == \ hass.states.get(entity_id).state common.async_alarm_trigger(hass) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state common.async_alarm_disarm(hass, entity_id=entity_id) await hass.async_block_till_done() assert STATE_ALARM_PENDING == \ hass.states.get(entity_id).state future = dt_util.utcnow() + timedelta(seconds=5) with patch(('homeassistant.components.manual.alarm_control_panel.' 'dt_util.utcnow'), return_value=future): async_fire_time_changed(hass, future) await hass.async_block_till_done() assert STATE_ALARM_TRIGGERED == \ hass.states.get(entity_id).state