* Add event loop to the core * Add block_till_done to HA core object * Fix some tests * Linting core * Fix statemachine tests * Core test fixes * fix block_till_done to wait for loop and queue to empty * fix test_core for passing, and correct start/stop/block_till_done * Fix remote tests * Fix tests: block_till_done * Fix linting * Fix more tests * Fix final linting * Fix remote test * remove unnecessary import * reduce sleep to avoid slowing down the tests excessively * fix remaining tests to wait for non-threadsafe operations * Add async_ doc strings for event loop / coroutine info * Fix command line test to block for the right timeout * Fix py3.4.2 loop var access * Fix SERVICE_CALL_LIMIT being in effect for other tests * Fix lint errors * Fix lint error with proper placement * Fix slave start to not start a timer * Add asyncio compatible listeners. * Increase min Python version to 3.4.2 * Move async backports to util * Add backported async tests * Fix linting * Simplify Python version check * Fix lint * Remove unneeded try/except and queue listener appproriately. * Fix tuple vs. list unorderable error on version compare. * Fix version tests
65 lines
2.3 KiB
Python
65 lines
2.3 KiB
Python
"""The tests for the persistent notification component."""
|
|
import homeassistant.components.persistent_notification as pn
|
|
|
|
from tests.common import get_test_home_assistant
|
|
|
|
|
|
class TestPersistentNotification:
|
|
"""Test persistent notification component."""
|
|
|
|
def setup_method(self, method):
|
|
"""Setup things to be run when tests are started."""
|
|
self.hass = get_test_home_assistant()
|
|
pn.setup(self.hass, {})
|
|
|
|
def teardown_method(self, method):
|
|
"""Stop everything that was started."""
|
|
self.hass.stop()
|
|
|
|
def test_create(self):
|
|
"""Test creating notification without title or notification id."""
|
|
assert len(self.hass.states.entity_ids(pn.DOMAIN)) == 0
|
|
|
|
pn.create(self.hass, 'Hello World {{ 1 + 1 }}',
|
|
title='{{ 1 + 1 }} beers')
|
|
self.hass.block_till_done()
|
|
|
|
entity_ids = self.hass.states.entity_ids(pn.DOMAIN)
|
|
assert len(entity_ids) == 1
|
|
|
|
state = self.hass.states.get(entity_ids[0])
|
|
assert state.state == 'Hello World 2'
|
|
assert state.attributes.get('title') == '2 beers'
|
|
|
|
def test_create_notification_id(self):
|
|
"""Ensure overwrites existing notification with same id."""
|
|
assert len(self.hass.states.entity_ids(pn.DOMAIN)) == 0
|
|
|
|
pn.create(self.hass, 'test', notification_id='Beer 2')
|
|
self.hass.block_till_done()
|
|
|
|
assert len(self.hass.states.entity_ids()) == 1
|
|
state = self.hass.states.get('persistent_notification.beer_2')
|
|
assert state.state == 'test'
|
|
|
|
pn.create(self.hass, 'test 2', notification_id='Beer 2')
|
|
self.hass.block_till_done()
|
|
|
|
# We should have overwritten old one
|
|
assert len(self.hass.states.entity_ids()) == 1
|
|
state = self.hass.states.get('persistent_notification.beer_2')
|
|
assert state.state == 'test 2'
|
|
|
|
def test_create_template_error(self):
|
|
"""Ensure we output templates if contain error."""
|
|
assert len(self.hass.states.entity_ids(pn.DOMAIN)) == 0
|
|
|
|
pn.create(self.hass, '{{ message + 1 }}', '{{ title + 1 }}')
|
|
self.hass.block_till_done()
|
|
|
|
entity_ids = self.hass.states.entity_ids(pn.DOMAIN)
|
|
assert len(entity_ids) == 1
|
|
|
|
state = self.hass.states.get(entity_ids[0])
|
|
assert state.state == '{{ message + 1 }}'
|
|
assert state.attributes.get('title') == '{{ title + 1 }}'
|