core/tests/components/command_line/test_notify.py

95 lines
3.3 KiB
Python
Raw Normal View History

2016-03-09 09:25:50 +00:00
"""The tests for the command line notification platform."""
import os
import tempfile
import unittest
from unittest.mock import patch
import homeassistant.components.notify as notify
from homeassistant.setup import setup_component
from tests.common import assert_setup_component, get_test_home_assistant
class TestCommandLine(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test the command line notifications."""
def setUp(self): # pylint: disable=invalid-name
2018-08-19 20:29:08 +00:00
"""Set up things to be run when tests are started."""
self.hass = get_test_home_assistant()
def tearDown(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Stop down everything that was started."""
self.hass.stop()
def test_setup(self):
"""Test setup."""
with assert_setup_component(1) as handle_config:
2019-07-31 19:25:30 +00:00
assert setup_component(
self.hass,
"notify",
{
"notify": {
"name": "test",
"platform": "command_line",
"command": "echo $(cat); exit 1",
}
},
)
assert handle_config[notify.DOMAIN]
def test_bad_config(self):
"""Test set up the platform with bad/missing configuration."""
2019-07-31 19:25:30 +00:00
config = {notify.DOMAIN: {"name": "test", "platform": "command_line"}}
with assert_setup_component(0) as handle_config:
assert setup_component(self.hass, notify.DOMAIN, config)
assert not handle_config[notify.DOMAIN]
def test_command_line_output(self):
2016-03-09 09:25:50 +00:00
"""Test the command line output."""
with tempfile.TemporaryDirectory() as tempdirname:
2019-07-31 19:25:30 +00:00
filename = os.path.join(tempdirname, "message.txt")
message = "one, two, testing, testing"
with assert_setup_component(1) as handle_config:
2019-07-31 19:25:30 +00:00
assert setup_component(
self.hass,
notify.DOMAIN,
{
"notify": {
"name": "test",
"platform": "command_line",
"command": "echo $(cat) > {}".format(filename),
}
},
)
assert handle_config[notify.DOMAIN]
assert self.hass.services.call(
2019-07-31 19:25:30 +00:00
"notify", "test", {"message": message}, blocking=True
)
with open(filename) as fil:
# the echo command adds a line break
assert fil.read() == "{}\n".format(message)
2019-07-31 19:25:30 +00:00
@patch("homeassistant.components.command_line.notify._LOGGER.error")
def test_error_for_none_zero_exit_code(self, mock_error):
"""Test if an error is logged for non zero exit codes."""
with assert_setup_component(1) as handle_config:
2019-07-31 19:25:30 +00:00
assert setup_component(
self.hass,
notify.DOMAIN,
{
"notify": {
"name": "test",
"platform": "command_line",
"command": "echo $(cat); exit 1",
}
},
)
assert handle_config[notify.DOMAIN]
2019-07-31 19:25:30 +00:00
assert self.hass.services.call(
"notify", "test", {"message": "error"}, blocking=True
)
assert 1 == mock_error.call_count