Skip to content
Snippets Groups Projects
Commit a9ef8d85 authored by Pascal Vizeli's avatar Pascal Vizeli Committed by GitHub
Browse files

Update ha-ffmpeg version 0.12 and add tests (#3301)

* update ha-ffmpeg version 0.12 and add tests

* change error logging
parent a69c575d
No related branches found
No related tags found
No related merge requests found
...@@ -16,7 +16,7 @@ from homeassistant.config import load_yaml_config_file ...@@ -16,7 +16,7 @@ from homeassistant.config import load_yaml_config_file
from homeassistant.const import (EVENT_HOMEASSISTANT_STOP, CONF_NAME, from homeassistant.const import (EVENT_HOMEASSISTANT_STOP, CONF_NAME,
ATTR_ENTITY_ID) ATTR_ENTITY_ID)
REQUIREMENTS = ["ha-ffmpeg==0.10"] REQUIREMENTS = ["ha-ffmpeg==0.12"]
SERVICE_RESTART = 'ffmpeg_restart' SERVICE_RESTART = 'ffmpeg_restart'
...@@ -39,12 +39,16 @@ CONF_RESET = 'reset' ...@@ -39,12 +39,16 @@ CONF_RESET = 'reset'
CONF_CHANGES = 'changes' CONF_CHANGES = 'changes'
CONF_REPEAT = 'repeat' CONF_REPEAT = 'repeat'
CONF_REPEAT_TIME = 'repeat_time' CONF_REPEAT_TIME = 'repeat_time'
CONF_RUN_TEST = 'run_test'
DEFAULT_RUN_TEST = True
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({ PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_TOOL): vol.In(MAP_FFMPEG_BIN), vol.Required(CONF_TOOL): vol.In(MAP_FFMPEG_BIN),
vol.Required(CONF_INPUT): cv.string, vol.Required(CONF_INPUT): cv.string,
vol.Optional(CONF_FFMPEG_BIN, default="ffmpeg"): cv.string, vol.Optional(CONF_FFMPEG_BIN, default="ffmpeg"): cv.string,
vol.Optional(CONF_NAME, default="FFmpeg"): cv.string, vol.Optional(CONF_NAME, default="FFmpeg"): cv.string,
vol.Optional(CONF_RUN_TEST, default=DEFAULT_RUN_TEST): cv.boolean,
vol.Optional(CONF_EXTRA_ARGUMENTS): cv.string, vol.Optional(CONF_EXTRA_ARGUMENTS): cv.string,
vol.Optional(CONF_OUTPUT): cv.string, vol.Optional(CONF_OUTPUT): cv.string,
vol.Optional(CONF_PEAK, default=-30): vol.Coerce(int), vol.Optional(CONF_PEAK, default=-30): vol.Coerce(int),
...@@ -73,8 +77,16 @@ _LOGGER = logging.getLogger(__name__) ...@@ -73,8 +77,16 @@ _LOGGER = logging.getLogger(__name__)
def setup_platform(hass, config, add_entities, discovery_info=None): def setup_platform(hass, config, add_entities, discovery_info=None):
"""Create the binary sensor.""" """Create the binary sensor."""
from haffmpeg import SensorNoise, SensorMotion from haffmpeg import Test, SensorNoise, SensorMotion
# check source
if config.get(CONF_RUN_TEST):
test = Test(config.get(CONF_FFMPEG_BIN))
if not test.run_test(config.get(CONF_INPUT)):
_LOGGER.error("FFmpeg '%s' test fails!", config.get(CONF_INPUT))
return
# generate sensor object
if config.get(CONF_TOOL) == FFMPEG_SENSOR_NOISE: if config.get(CONF_TOOL) == FFMPEG_SENSOR_NOISE:
entity = FFmpegNoise(SensorNoise, config) entity = FFmpegNoise(SensorNoise, config)
else: else:
...@@ -88,7 +100,7 @@ def setup_platform(hass, config, add_entities, discovery_info=None): ...@@ -88,7 +100,7 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
# exists service? # exists service?
if hass.services.has_service(DOMAIN, SERVICE_RESTART): if hass.services.has_service(DOMAIN, SERVICE_RESTART):
return True return
descriptions = load_yaml_config_file( descriptions = load_yaml_config_file(
path.join(path.dirname(__file__), 'services.yaml')) path.join(path.dirname(__file__), 'services.yaml'))
...@@ -111,7 +123,6 @@ def setup_platform(hass, config, add_entities, discovery_info=None): ...@@ -111,7 +123,6 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
_service_handle_restart, _service_handle_restart,
descriptions.get(SERVICE_RESTART), descriptions.get(SERVICE_RESTART),
schema=SERVICE_RESTART_SCHEMA) schema=SERVICE_RESTART_SCHEMA)
return True
class FFmpegBinarySensor(BinarySensorDevice): class FFmpegBinarySensor(BinarySensorDevice):
......
...@@ -12,27 +12,39 @@ from homeassistant.components.camera import (Camera, PLATFORM_SCHEMA) ...@@ -12,27 +12,39 @@ from homeassistant.components.camera import (Camera, PLATFORM_SCHEMA)
import homeassistant.helpers.config_validation as cv import homeassistant.helpers.config_validation as cv
from homeassistant.const import CONF_NAME from homeassistant.const import CONF_NAME
REQUIREMENTS = ['ha-ffmpeg==0.10'] REQUIREMENTS = ['ha-ffmpeg==0.12']
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
CONF_INPUT = 'input' CONF_INPUT = 'input'
CONF_FFMPEG_BIN = 'ffmpeg_bin' CONF_FFMPEG_BIN = 'ffmpeg_bin'
CONF_EXTRA_ARGUMENTS = 'extra_arguments' CONF_EXTRA_ARGUMENTS = 'extra_arguments'
CONF_RUN_TEST = 'run_test'
DEFAULT_BINARY = 'ffmpeg' DEFAULT_BINARY = 'ffmpeg'
DEFAULT_NAME = 'FFmpeg' DEFAULT_NAME = 'FFmpeg'
DEFAULT_RUN_TEST = True
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({ PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_INPUT): cv.string, vol.Required(CONF_INPUT): cv.string,
vol.Optional(CONF_EXTRA_ARGUMENTS): cv.string, vol.Optional(CONF_EXTRA_ARGUMENTS): cv.string,
vol.Optional(CONF_FFMPEG_BIN, default=DEFAULT_BINARY): cv.string, vol.Optional(CONF_FFMPEG_BIN, default=DEFAULT_BINARY): cv.string,
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string, vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
vol.Optional(CONF_RUN_TEST, default=DEFAULT_RUN_TEST): cv.boolean,
}) })
def setup_platform(hass, config, add_devices, discovery_info=None): def setup_platform(hass, config, add_devices, discovery_info=None):
"""Setup a FFmpeg Camera.""" """Setup a FFmpeg Camera."""
from haffmpeg import Test
# run Test
if config.get(CONF_RUN_TEST):
test = Test(config.get(CONF_FFMPEG_BIN))
if not test.run_test(config.get(CONF_INPUT)):
_LOGGER.error("FFmpeg '%s' test fails!", config.get(CONF_INPUT))
return
add_devices([FFmpegCamera(config)]) add_devices([FFmpegCamera(config)])
......
...@@ -113,7 +113,7 @@ gps3==0.33.3 ...@@ -113,7 +113,7 @@ gps3==0.33.3
# homeassistant.components.binary_sensor.ffmpeg # homeassistant.components.binary_sensor.ffmpeg
# homeassistant.components.camera.ffmpeg # homeassistant.components.camera.ffmpeg
ha-ffmpeg==0.10 ha-ffmpeg==0.12
# homeassistant.components.mqtt.server # homeassistant.components.mqtt.server
hbmqtt==0.7.1 hbmqtt==0.7.1
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment