Merge pull request #1220 from stefan-jonasson/command_line.py
New notification platform "command line"
This commit is contained in:
commit
1c8c16f85f
2 changed files with 106 additions and 0 deletions
48
homeassistant/components/notify/command_line.py
Normal file
48
homeassistant/components/notify/command_line.py
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
"""
|
||||||
|
homeassistant.components.notify.command_line
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
command_line notification service.
|
||||||
|
|
||||||
|
For more details about this platform, please refer to the documentation at
|
||||||
|
https://home-assistant.io/components/notify.command_line/
|
||||||
|
"""
|
||||||
|
import logging
|
||||||
|
import subprocess
|
||||||
|
from homeassistant.helpers import validate_config
|
||||||
|
from homeassistant.components.notify import (
|
||||||
|
DOMAIN, BaseNotificationService)
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
def get_service(hass, config):
|
||||||
|
""" Get the Command Line notification service. """
|
||||||
|
|
||||||
|
if not validate_config({DOMAIN: config},
|
||||||
|
{DOMAIN: ['command']},
|
||||||
|
_LOGGER):
|
||||||
|
return None
|
||||||
|
|
||||||
|
command = config['command']
|
||||||
|
|
||||||
|
return CommandLineNotificationService(command)
|
||||||
|
|
||||||
|
|
||||||
|
# pylint: disable=too-few-public-methods
|
||||||
|
class CommandLineNotificationService(BaseNotificationService):
|
||||||
|
""" Implements notification service for the Command Line service. """
|
||||||
|
|
||||||
|
def __init__(self, command):
|
||||||
|
self.command = command
|
||||||
|
|
||||||
|
def send_message(self, message="", **kwargs):
|
||||||
|
""" Send a message to a command_line. """
|
||||||
|
|
||||||
|
try:
|
||||||
|
proc = subprocess.Popen(self.command, universal_newlines=True,
|
||||||
|
stdin=subprocess.PIPE, shell=True)
|
||||||
|
proc.communicate(input=message)
|
||||||
|
if proc.returncode != 0:
|
||||||
|
_LOGGER.error('Command failed: %s', self.command)
|
||||||
|
except subprocess.SubprocessError:
|
||||||
|
_LOGGER.error('Error trying to exec Command: %s', self.command)
|
58
tests/components/notify/test_command_line.py
Normal file
58
tests/components/notify/test_command_line.py
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
"""
|
||||||
|
tests.components.notify.test_command_line
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Tests command line notification.
|
||||||
|
"""
|
||||||
|
import os
|
||||||
|
import tempfile
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
from homeassistant import core
|
||||||
|
import homeassistant.components.notify as notify
|
||||||
|
from unittest.mock import patch
|
||||||
|
|
||||||
|
|
||||||
|
class TestCommandLine(unittest.TestCase):
|
||||||
|
""" Test the command line. """
|
||||||
|
|
||||||
|
def setUp(self): # pylint: disable=invalid-name
|
||||||
|
self.hass = core.HomeAssistant()
|
||||||
|
|
||||||
|
def tearDown(self): # pylint: disable=invalid-name
|
||||||
|
""" Stop down stuff we started. """
|
||||||
|
self.hass.stop()
|
||||||
|
|
||||||
|
def test_command_line_output(self):
|
||||||
|
with tempfile.TemporaryDirectory() as tempdirname:
|
||||||
|
filename = os.path.join(tempdirname, 'message.txt')
|
||||||
|
message = 'one, two, testing, testing'
|
||||||
|
self.assertTrue(notify.setup(self.hass, {
|
||||||
|
'notify': {
|
||||||
|
'name': 'test',
|
||||||
|
'platform': 'command_line',
|
||||||
|
'command': 'echo $(cat) > {}'.format(filename)
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
|
||||||
|
self.hass.services.call('notify', 'test', {'message': message},
|
||||||
|
blocking=True)
|
||||||
|
|
||||||
|
result = open(filename).read()
|
||||||
|
# the echo command adds a line break
|
||||||
|
self.assertEqual(result, "{}\n".format(message))
|
||||||
|
|
||||||
|
@patch('homeassistant.components.notify.command_line._LOGGER.error')
|
||||||
|
def test_error_for_none_zero_exit_code(self, mock_error):
|
||||||
|
""" Test if an error if logged for non zero exit codes. """
|
||||||
|
self.assertTrue(notify.setup(self.hass, {
|
||||||
|
'notify': {
|
||||||
|
'name': 'test',
|
||||||
|
'platform': 'command_line',
|
||||||
|
'command': 'echo $(cat); exit 1'
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
|
||||||
|
self.hass.services.call('notify', 'test', {'message': 'error'},
|
||||||
|
blocking=True)
|
||||||
|
self.assertEqual(1, mock_error.call_count)
|
Loading…
Add table
Reference in a new issue