Update ha-ffmpeg version 0.12 and add tests (#3301)
* update ha-ffmpeg version 0.12 and add tests * change error logging
This commit is contained in:
parent
a69c575dab
commit
a9ef8d8568
3 changed files with 29 additions and 6 deletions
|
@ -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'
|
||||||
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__)
|
||||||
|
|
||||||
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):
|
||||||
|
|
||||||
# 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):
|
||||||
_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)
|
||||||
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
|
||||||
|
|
||||||
# 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
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue