Migrate to voluptuous (#3293) [BREAKING CHANGE]
This commit is contained in:
parent
7c2cb6cffd
commit
7cf9ff83bc
2 changed files with 304 additions and 316 deletions
|
@ -9,106 +9,92 @@ https://home-assistant.io/components/proximity/
|
||||||
"""
|
"""
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
|
import voluptuous as vol
|
||||||
|
|
||||||
|
from homeassistant.const import (
|
||||||
|
CONF_ZONE, CONF_DEVICES, CONF_UNIT_OF_MEASUREMENT)
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
from homeassistant.helpers.event import track_state_change
|
from homeassistant.helpers.event import track_state_change
|
||||||
from homeassistant.util.location import distance
|
|
||||||
from homeassistant.util.distance import convert
|
from homeassistant.util.distance import convert
|
||||||
from homeassistant.const import ATTR_UNIT_OF_MEASUREMENT
|
from homeassistant.util.location import distance
|
||||||
|
import homeassistant.helpers.config_validation as cv
|
||||||
DEPENDENCIES = ['zone', 'device_tracker']
|
|
||||||
|
|
||||||
DOMAIN = 'proximity'
|
|
||||||
|
|
||||||
NOT_SET = 'not set'
|
|
||||||
|
|
||||||
# Default tolerance
|
|
||||||
DEFAULT_TOLERANCE = 1
|
|
||||||
|
|
||||||
# Default zone
|
|
||||||
DEFAULT_PROXIMITY_ZONE = 'home'
|
|
||||||
|
|
||||||
# Default distance to zone
|
|
||||||
DEFAULT_DIST_TO_ZONE = NOT_SET
|
|
||||||
|
|
||||||
# Default direction of travel
|
|
||||||
DEFAULT_DIR_OF_TRAVEL = NOT_SET
|
|
||||||
|
|
||||||
# Default nearest device
|
|
||||||
DEFAULT_NEAREST = NOT_SET
|
|
||||||
|
|
||||||
# Entity attributes
|
|
||||||
ATTR_DIST_FROM = 'dist_to_zone'
|
|
||||||
ATTR_DIR_OF_TRAVEL = 'dir_of_travel'
|
|
||||||
ATTR_NEAREST = 'nearest'
|
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
ATTR_DIR_OF_TRAVEL = 'dir_of_travel'
|
||||||
|
ATTR_DIST_FROM = 'dist_to_zone'
|
||||||
|
ATTR_NEAREST = 'nearest'
|
||||||
|
|
||||||
def setup_proximity_component(hass, config):
|
CONF_IGNORED_ZONES = 'ignored_zones'
|
||||||
|
CONF_TOLERANCE = 'tolerance'
|
||||||
|
|
||||||
|
DEFAULT_DIR_OF_TRAVEL = 'not set'
|
||||||
|
DEFAULT_DIST_TO_ZONE = 'not set'
|
||||||
|
DEFAULT_NEAREST = 'not set'
|
||||||
|
DEFAULT_PROXIMITY_ZONE = 'home'
|
||||||
|
DEFAULT_TOLERANCE = 1
|
||||||
|
DEPENDENCIES = ['zone', 'device_tracker']
|
||||||
|
DOMAIN = 'proximity'
|
||||||
|
|
||||||
|
UNITS = ['km', 'm', 'mi', 'ft']
|
||||||
|
|
||||||
|
ZONE_SCHEMA = vol.Schema({
|
||||||
|
vol.Optional(CONF_ZONE, default=DEFAULT_PROXIMITY_ZONE): cv.string,
|
||||||
|
vol.Optional(CONF_DEVICES, default=[]):
|
||||||
|
vol.All(cv.ensure_list, [cv.entity_id]),
|
||||||
|
vol.Optional(CONF_IGNORED_ZONES, default=[]):
|
||||||
|
vol.All(cv.ensure_list, [cv.string]),
|
||||||
|
vol.Optional(CONF_TOLERANCE, default=DEFAULT_TOLERANCE): cv.positive_int,
|
||||||
|
vol.Optional(CONF_UNIT_OF_MEASUREMENT): vol.All(cv.string, vol.In(UNITS)),
|
||||||
|
})
|
||||||
|
|
||||||
|
CONFIG_SCHEMA = vol.Schema({
|
||||||
|
DOMAIN: vol.Schema({
|
||||||
|
cv.slug: ZONE_SCHEMA,
|
||||||
|
}),
|
||||||
|
}, extra=vol.ALLOW_EXTRA)
|
||||||
|
|
||||||
|
|
||||||
|
def setup_proximity_component(hass, name, config):
|
||||||
"""Set up individual proximity component."""
|
"""Set up individual proximity component."""
|
||||||
# Get the devices from configuration.yaml.
|
ignored_zones = config.get(CONF_IGNORED_ZONES)
|
||||||
if 'devices' not in config:
|
proximity_devices = config.get(CONF_DEVICES)
|
||||||
_LOGGER.error('devices not found in config')
|
tolerance = config.get(CONF_TOLERANCE)
|
||||||
return False
|
proximity_zone = name
|
||||||
|
unit_of_measurement = config.get(
|
||||||
ignored_zones = []
|
CONF_UNIT_OF_MEASUREMENT, hass.config.units.length_unit)
|
||||||
if 'ignored_zones' in config:
|
|
||||||
for variable in config['ignored_zones']:
|
|
||||||
ignored_zones.append(variable)
|
|
||||||
|
|
||||||
proximity_devices = []
|
|
||||||
for variable in config['devices']:
|
|
||||||
proximity_devices.append(variable)
|
|
||||||
|
|
||||||
# Get the direction of travel tolerance from configuration.yaml.
|
|
||||||
tolerance = config.get('tolerance', DEFAULT_TOLERANCE)
|
|
||||||
|
|
||||||
# Get the zone to monitor proximity to from configuration.yaml.
|
|
||||||
proximity_zone = config.get('zone', DEFAULT_PROXIMITY_ZONE)
|
|
||||||
|
|
||||||
# Get the unit of measurement from configuration.yaml.
|
|
||||||
unit_of_measure = config.get(ATTR_UNIT_OF_MEASUREMENT,
|
|
||||||
hass.config.units.length_unit)
|
|
||||||
|
|
||||||
zone_id = 'zone.{}'.format(proximity_zone)
|
zone_id = 'zone.{}'.format(proximity_zone)
|
||||||
state = hass.states.get(zone_id)
|
|
||||||
zone_friendly_name = (state.name).lower()
|
|
||||||
|
|
||||||
proximity = Proximity(hass, zone_friendly_name, DEFAULT_DIST_TO_ZONE,
|
proximity = Proximity(hass, proximity_zone, DEFAULT_DIST_TO_ZONE,
|
||||||
DEFAULT_DIR_OF_TRAVEL, DEFAULT_NEAREST,
|
DEFAULT_DIR_OF_TRAVEL, DEFAULT_NEAREST,
|
||||||
ignored_zones, proximity_devices, tolerance,
|
ignored_zones, proximity_devices, tolerance,
|
||||||
zone_id, unit_of_measure)
|
zone_id, unit_of_measurement)
|
||||||
proximity.entity_id = '{}.{}'.format(DOMAIN, proximity_zone)
|
proximity.entity_id = '{}.{}'.format(DOMAIN, proximity_zone)
|
||||||
|
|
||||||
proximity.update_ha_state()
|
proximity.update_ha_state()
|
||||||
|
|
||||||
# Main command to monitor proximity of devices.
|
track_state_change(
|
||||||
track_state_change(hass, proximity_devices,
|
hass, proximity_devices, proximity.check_proximity_state_change)
|
||||||
proximity.check_proximity_state_change)
|
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
def setup(hass, config):
|
def setup(hass, config):
|
||||||
"""Get the zones and offsets from configuration.yaml."""
|
"""Get the zones and offsets from configuration.yaml."""
|
||||||
result = True
|
for zone, proximity_config in config[DOMAIN].items():
|
||||||
if isinstance(config[DOMAIN], list):
|
setup_proximity_component(hass, zone, proximity_config)
|
||||||
for proximity_config in config[DOMAIN]:
|
|
||||||
if not setup_proximity_component(hass, proximity_config):
|
|
||||||
result = False
|
|
||||||
elif not setup_proximity_component(hass, config[DOMAIN]):
|
|
||||||
result = False
|
|
||||||
|
|
||||||
return result
|
return True
|
||||||
|
|
||||||
|
|
||||||
class Proximity(Entity): # pylint: disable=too-many-instance-attributes
|
# pylint: disable=too-many-instance-attributes
|
||||||
|
class Proximity(Entity):
|
||||||
"""Representation of a Proximity."""
|
"""Representation of a Proximity."""
|
||||||
|
|
||||||
# pylint: disable=too-many-arguments
|
# pylint: disable=too-many-arguments
|
||||||
def __init__(self, hass, zone_friendly_name, dist_to, dir_of_travel,
|
def __init__(self, hass, zone_friendly_name, dist_to, dir_of_travel,
|
||||||
nearest, ignored_zones, proximity_devices, tolerance,
|
nearest, ignored_zones, proximity_devices, tolerance,
|
||||||
proximity_zone, unit_of_measure):
|
proximity_zone, unit_of_measurement):
|
||||||
"""Initialize the proximity."""
|
"""Initialize the proximity."""
|
||||||
self.hass = hass
|
self.hass = hass
|
||||||
self.friendly_name = zone_friendly_name
|
self.friendly_name = zone_friendly_name
|
||||||
|
@ -119,7 +105,7 @@ class Proximity(Entity): # pylint: disable=too-many-instance-attributes
|
||||||
self.proximity_devices = proximity_devices
|
self.proximity_devices = proximity_devices
|
||||||
self.tolerance = tolerance
|
self.tolerance = tolerance
|
||||||
self.proximity_zone = proximity_zone
|
self.proximity_zone = proximity_zone
|
||||||
self.unit_of_measure = unit_of_measure
|
self._unit_of_measurement = unit_of_measurement
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def name(self):
|
def name(self):
|
||||||
|
@ -134,7 +120,7 @@ class Proximity(Entity): # pylint: disable=too-many-instance-attributes
|
||||||
@property
|
@property
|
||||||
def unit_of_measurement(self):
|
def unit_of_measurement(self):
|
||||||
"""Return the unit of measurement of this entity."""
|
"""Return the unit of measurement of this entity."""
|
||||||
return self.unit_of_measure
|
return self._unit_of_measurement
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def state_attributes(self):
|
def state_attributes(self):
|
||||||
|
@ -209,7 +195,7 @@ class Proximity(Entity): # pylint: disable=too-many-instance-attributes
|
||||||
|
|
||||||
# Add the device and distance to a dictionary.
|
# Add the device and distance to a dictionary.
|
||||||
distances_to_zone[device] = round(
|
distances_to_zone[device] = round(
|
||||||
convert(dist_to_zone, 'm', self.unit_of_measure), 1)
|
convert(dist_to_zone, 'm', self.unit_of_measurement), 1)
|
||||||
|
|
||||||
# Loop through each of the distances collected and work out the
|
# Loop through each of the distances collected and work out the
|
||||||
# closest.
|
# closest.
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
"""The tests for the Proximity component."""
|
"""The tests for the Proximity component."""
|
||||||
from homeassistant.components import proximity
|
import unittest
|
||||||
|
|
||||||
|
from homeassistant.components import proximity
|
||||||
|
from homeassistant.components.proximity import DOMAIN
|
||||||
|
|
||||||
|
from homeassistant.bootstrap import setup_component
|
||||||
from tests.common import get_test_home_assistant
|
from tests.common import get_test_home_assistant
|
||||||
|
|
||||||
|
|
||||||
class TestProximity:
|
class TestProximity(unittest.TestCase):
|
||||||
"""Test the Proximity component."""
|
"""Test the Proximity component."""
|
||||||
|
|
||||||
def setup_method(self, method):
|
def setUp(self):
|
||||||
"""Setup things to be run when tests are started."""
|
"""Setup things to be run when tests are started."""
|
||||||
self.hass = get_test_home_assistant()
|
self.hass = get_test_home_assistant()
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
|
@ -27,31 +31,34 @@ class TestProximity:
|
||||||
'radius': 10
|
'radius': 10
|
||||||
})
|
})
|
||||||
|
|
||||||
def teardown_method(self, method):
|
def tearDown(self):
|
||||||
"""Stop everything that was started."""
|
"""Stop everything that was started."""
|
||||||
self.hass.stop()
|
self.hass.stop()
|
||||||
|
|
||||||
def test_proximities(self):
|
def test_proximities(self):
|
||||||
"""Test a list of proximities."""
|
"""Test a list of proximities."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': [{
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
|
],
|
||||||
|
'devices': [
|
||||||
|
'device_tracker.test1',
|
||||||
|
'device_tracker.test2'
|
||||||
|
],
|
||||||
|
'tolerance': '1'
|
||||||
},
|
},
|
||||||
'devices': {
|
'work': {
|
||||||
'device_tracker.test1',
|
'devices': [
|
||||||
'device_tracker.test2'
|
'device_tracker.test1'
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
}, {
|
}
|
||||||
'zone': 'work',
|
}
|
||||||
'devices': {
|
}
|
||||||
'device_tracker.test1'
|
|
||||||
},
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
'tolerance': '1'
|
|
||||||
}]
|
|
||||||
})
|
|
||||||
|
|
||||||
proximities = ['home', 'work']
|
proximities = ['home', 'work']
|
||||||
|
|
||||||
|
@ -66,40 +73,46 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.' + prox)
|
state = self.hass.states.get('proximity.' + prox)
|
||||||
assert state.state == '0'
|
assert state.state == '0'
|
||||||
|
|
||||||
def test_proximities_missing_devices(self):
|
def test_proximities_setup(self):
|
||||||
"""Test a list of proximities with one missing devices."""
|
"""Test a list of proximities with missing devices."""
|
||||||
assert not proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': [{
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
|
],
|
||||||
|
'devices': [
|
||||||
|
'device_tracker.test1',
|
||||||
|
'device_tracker.test2'
|
||||||
|
],
|
||||||
|
'tolerance': '1'
|
||||||
},
|
},
|
||||||
'devices': {
|
'work': {
|
||||||
'device_tracker.test1',
|
'tolerance': '1'
|
||||||
'device_tracker.test2'
|
}
|
||||||
},
|
}
|
||||||
'tolerance': '1'
|
}
|
||||||
}, {
|
|
||||||
'zone': 'work',
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
'tolerance': '1'
|
|
||||||
}]
|
|
||||||
})
|
|
||||||
|
|
||||||
def test_proximity(self):
|
def test_proximity(self):
|
||||||
"""Test the proximity."""
|
"""Test the proximity."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.state == 'not set'
|
assert state.state == 'not set'
|
||||||
|
@ -111,75 +124,23 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.state == '0'
|
assert state.state == '0'
|
||||||
|
|
||||||
def test_no_devices_in_config(self):
|
|
||||||
"""Test for missing devices in configuration."""
|
|
||||||
assert not proximity.setup(self.hass, {
|
|
||||||
'proximity': {
|
|
||||||
'zone': 'home',
|
|
||||||
'ignored_zones': {
|
|
||||||
'work'
|
|
||||||
},
|
|
||||||
'tolerance': '1'
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
def test_no_tolerance_in_config(self):
|
|
||||||
"""Test for missing tolerance in configuration ."""
|
|
||||||
assert proximity.setup(self.hass, {
|
|
||||||
'proximity': {
|
|
||||||
'zone': 'home',
|
|
||||||
'ignored_zones': {
|
|
||||||
'work'
|
|
||||||
},
|
|
||||||
'devices': {
|
|
||||||
'device_tracker.test1',
|
|
||||||
'device_tracker.test2'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
def test_no_ignored_zones_in_config(self):
|
|
||||||
"""Test for ignored zones in configuration."""
|
|
||||||
assert proximity.setup(self.hass, {
|
|
||||||
'proximity': {
|
|
||||||
'zone': 'home',
|
|
||||||
'devices': {
|
|
||||||
'device_tracker.test1',
|
|
||||||
'device_tracker.test2'
|
|
||||||
},
|
|
||||||
'tolerance': '1'
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
def test_no_zone_in_config(self):
|
|
||||||
"""Test for missing zone in configuration."""
|
|
||||||
assert proximity.setup(self.hass, {
|
|
||||||
'proximity': {
|
|
||||||
'ignored_zones': {
|
|
||||||
'work'
|
|
||||||
},
|
|
||||||
'devices': {
|
|
||||||
'device_tracker.test1',
|
|
||||||
'device_tracker.test2'
|
|
||||||
},
|
|
||||||
'tolerance': '1'
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
def test_device_tracker_test1_in_zone(self):
|
def test_device_tracker_test1_in_zone(self):
|
||||||
"""Test for tracker in zone."""
|
"""Test for tracker in zone."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1'
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'home',
|
'device_tracker.test1', 'home',
|
||||||
|
@ -196,19 +157,22 @@ class TestProximity:
|
||||||
|
|
||||||
def test_device_trackers_in_zone(self):
|
def test_device_trackers_in_zone(self):
|
||||||
"""Test for trackers in zone."""
|
"""Test for trackers in zone."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'home',
|
'device_tracker.test1', 'home',
|
||||||
|
@ -234,18 +198,21 @@ class TestProximity:
|
||||||
|
|
||||||
def test_device_tracker_test1_away(self):
|
def test_device_tracker_test1_away(self):
|
||||||
"""Test for tracker state away."""
|
"""Test for tracker state away."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1',
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
|
@ -254,6 +221,7 @@ class TestProximity:
|
||||||
'latitude': 20.1,
|
'latitude': 20.1,
|
||||||
'longitude': 10.1
|
'longitude': 10.1
|
||||||
})
|
})
|
||||||
|
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
|
@ -261,17 +229,21 @@ class TestProximity:
|
||||||
|
|
||||||
def test_device_tracker_test1_awayfurther(self):
|
def test_device_tracker_test1_awayfurther(self):
|
||||||
"""Test for tracker state away further."""
|
"""Test for tracker state away further."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1',
|
||||||
|
],
|
||||||
|
'tolerance': '1'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
|
@ -284,31 +256,6 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
self.hass.states.set(
|
|
||||||
'device_tracker.test1', 'not_home',
|
|
||||||
{
|
|
||||||
'friendly_name': 'test1',
|
|
||||||
'latitude': 40.1,
|
|
||||||
'longitude': 20.1
|
|
||||||
})
|
|
||||||
self.hass.block_till_done()
|
|
||||||
state = self.hass.states.get('proximity.home')
|
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
|
||||||
assert state.attributes.get('dir_of_travel') == 'away_from'
|
|
||||||
|
|
||||||
def test_device_tracker_test1_awaycloser(self):
|
|
||||||
"""Test for tracker state away closer."""
|
|
||||||
assert proximity.setup(self.hass, {
|
|
||||||
'proximity': {
|
|
||||||
'zone': 'home',
|
|
||||||
'ignored_zones': {
|
|
||||||
'work'
|
|
||||||
},
|
|
||||||
'devices': {
|
|
||||||
'device_tracker.test1'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
|
@ -320,32 +267,67 @@ class TestProximity:
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
|
||||||
self.hass.states.set(
|
|
||||||
'device_tracker.test1', 'not_home',
|
|
||||||
{
|
|
||||||
'friendly_name': 'test1',
|
|
||||||
'latitude': 20.1,
|
|
||||||
'longitude': 10.1
|
|
||||||
})
|
|
||||||
self.hass.block_till_done()
|
|
||||||
state = self.hass.states.get('proximity.home')
|
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
|
||||||
assert state.attributes.get('dir_of_travel') == 'towards'
|
assert state.attributes.get('dir_of_travel') == 'towards'
|
||||||
|
|
||||||
def test_all_device_trackers_in_ignored_zone(self):
|
def test_device_tracker_test1_awaycloser(self):
|
||||||
"""Test for tracker in ignored zone."""
|
"""Test for tracker state away closer."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1',
|
||||||
|
],
|
||||||
|
'tolerance': '1'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
|
self.hass.states.set(
|
||||||
|
'device_tracker.test1', 'not_home',
|
||||||
|
{
|
||||||
|
'friendly_name': 'test1',
|
||||||
|
'latitude': 40.1,
|
||||||
|
'longitude': 20.1
|
||||||
|
})
|
||||||
|
self.hass.block_till_done()
|
||||||
|
state = self.hass.states.get('proximity.home')
|
||||||
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
|
|
||||||
|
self.hass.states.set(
|
||||||
|
'device_tracker.test1', 'not_home',
|
||||||
|
{
|
||||||
|
'friendly_name': 'test1',
|
||||||
|
'latitude': 20.1,
|
||||||
|
'longitude': 10.1
|
||||||
|
})
|
||||||
|
self.hass.block_till_done()
|
||||||
|
state = self.hass.states.get('proximity.home')
|
||||||
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
|
assert state.attributes.get('dir_of_travel') == 'away_from'
|
||||||
|
|
||||||
|
def test_all_device_trackers_in_ignored_zone(self):
|
||||||
|
"""Test for tracker in ignored zone."""
|
||||||
|
config = {
|
||||||
|
'proximity': {
|
||||||
|
'home': {
|
||||||
|
'ignored_zones': [
|
||||||
|
'work'
|
||||||
|
],
|
||||||
|
'devices': [
|
||||||
|
'device_tracker.test1',
|
||||||
|
],
|
||||||
|
'tolerance': '1'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'work',
|
'device_tracker.test1', 'work',
|
||||||
|
@ -360,18 +342,21 @@ class TestProximity:
|
||||||
|
|
||||||
def test_device_tracker_test1_no_coordinates(self):
|
def test_device_tracker_test1_no_coordinates(self):
|
||||||
"""Test for tracker with no coordinates."""
|
"""Test for tracker with no coordinates."""
|
||||||
assert proximity.setup(self.hass, {
|
config = {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1',
|
||||||
},
|
],
|
||||||
'tolerance': '1'
|
'tolerance': '1'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
self.assertTrue(setup_component(self.hass, DOMAIN, config))
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
|
@ -397,15 +382,18 @@ class TestProximity:
|
||||||
'friendly_name': 'test2'
|
'friendly_name': 'test2'
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
|
],
|
||||||
|
'tolerance': '1',
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -421,6 +409,7 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test2', 'not_home',
|
'device_tracker.test2', 'not_home',
|
||||||
{
|
{
|
||||||
|
@ -449,13 +438,14 @@ class TestProximity:
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -471,6 +461,7 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test2'
|
assert state.attributes.get('nearest') == 'test2'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
{
|
{
|
||||||
|
@ -499,13 +490,14 @@ class TestProximity:
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -536,15 +528,17 @@ class TestProximity:
|
||||||
'friendly_name': 'test2'
|
'friendly_name': 'test2'
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -566,6 +560,7 @@ class TestProximity:
|
||||||
'longitude': 10.1
|
'longitude': 10.1
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
{
|
{
|
||||||
|
@ -574,6 +569,7 @@ class TestProximity:
|
||||||
'longitude': 20.1
|
'longitude': 20.1
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
{
|
{
|
||||||
|
@ -582,12 +578,14 @@ class TestProximity:
|
||||||
'longitude': 15.1
|
'longitude': 15.1
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'work',
|
'device_tracker.test1', 'work',
|
||||||
{
|
{
|
||||||
'friendly_name': 'test1'
|
'friendly_name': 'test1'
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test2'
|
assert state.attributes.get('nearest') == 'test2'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
|
@ -596,14 +594,15 @@ class TestProximity:
|
||||||
"""Test for tracker states."""
|
"""Test for tracker states."""
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1'
|
'device_tracker.test1'
|
||||||
},
|
],
|
||||||
'tolerance': 1000
|
'tolerance': 1000
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -618,6 +617,7 @@ class TestProximity:
|
||||||
state = self.hass.states.get('proximity.home')
|
state = self.hass.states.get('proximity.home')
|
||||||
assert state.attributes.get('nearest') == 'test1'
|
assert state.attributes.get('nearest') == 'test1'
|
||||||
assert state.attributes.get('dir_of_travel') == 'unknown'
|
assert state.attributes.get('dir_of_travel') == 'unknown'
|
||||||
|
|
||||||
self.hass.states.set(
|
self.hass.states.set(
|
||||||
'device_tracker.test1', 'not_home',
|
'device_tracker.test1', 'not_home',
|
||||||
{
|
{
|
||||||
|
@ -644,15 +644,17 @@ class TestProximity:
|
||||||
'friendly_name': 'test2'
|
'friendly_name': 'test2'
|
||||||
})
|
})
|
||||||
self.hass.block_till_done()
|
self.hass.block_till_done()
|
||||||
|
|
||||||
assert proximity.setup(self.hass, {
|
assert proximity.setup(self.hass, {
|
||||||
'proximity': {
|
'proximity': {
|
||||||
'zone': 'home',
|
'home': {
|
||||||
'ignored_zones': {
|
'ignored_zones': [
|
||||||
'work'
|
'work'
|
||||||
},
|
],
|
||||||
'devices': {
|
'devices': [
|
||||||
'device_tracker.test1',
|
'device_tracker.test1',
|
||||||
'device_tracker.test2'
|
'device_tracker.test2'
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue