SmartThings Lock platform state attributes enhancement (#21379)
* Add additional lock metadata * Fixed attribute name in testpull/21388/head
parent
ce86fe47e3
commit
3d9f4bf2aa
|
@ -10,9 +10,12 @@ DEPENDENCIES = ['smartthings']
|
||||||
|
|
||||||
ST_STATE_LOCKED = 'locked'
|
ST_STATE_LOCKED = 'locked'
|
||||||
ST_LOCK_ATTR_MAP = {
|
ST_LOCK_ATTR_MAP = {
|
||||||
'method': 'method',
|
|
||||||
'codeId': 'code_id',
|
'codeId': 'code_id',
|
||||||
|
'codeName': 'code_name',
|
||||||
|
'lockName': 'lock_name',
|
||||||
|
'method': 'method',
|
||||||
'timeout': 'timeout',
|
'timeout': 'timeout',
|
||||||
|
'usedCode': 'used_code'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ The only mocking required is of the underlying SmartThings API object so
|
||||||
real HTTP calls are not initiated during testing.
|
real HTTP calls are not initiated during testing.
|
||||||
"""
|
"""
|
||||||
from pysmartthings import Attribute, Capability
|
from pysmartthings import Attribute, Capability
|
||||||
|
from pysmartthings.device import Status
|
||||||
|
|
||||||
from homeassistant.components.lock import DOMAIN as LOCK_DOMAIN
|
from homeassistant.components.lock import DOMAIN as LOCK_DOMAIN
|
||||||
from homeassistant.components.smartthings import lock
|
from homeassistant.components.smartthings import lock
|
||||||
|
@ -45,8 +46,15 @@ async def test_entity_and_device_attributes(hass, device_factory):
|
||||||
async def test_lock(hass, device_factory):
|
async def test_lock(hass, device_factory):
|
||||||
"""Test the lock locks successfully."""
|
"""Test the lock locks successfully."""
|
||||||
# Arrange
|
# Arrange
|
||||||
device = device_factory('Lock_1', [Capability.lock],
|
device = device_factory('Lock_1', [Capability.lock])
|
||||||
{Attribute.lock: 'unlocked'})
|
device.status.attributes[Attribute.lock] = Status(
|
||||||
|
'unlocked', None, {
|
||||||
|
'method': 'Manual',
|
||||||
|
'codeId': None,
|
||||||
|
'codeName': 'Code 1',
|
||||||
|
'lockName': 'Front Door',
|
||||||
|
'usedCode': 'Code 2'
|
||||||
|
})
|
||||||
await setup_platform(hass, LOCK_DOMAIN, device)
|
await setup_platform(hass, LOCK_DOMAIN, device)
|
||||||
# Act
|
# Act
|
||||||
await hass.services.async_call(
|
await hass.services.async_call(
|
||||||
|
@ -56,6 +64,12 @@ async def test_lock(hass, device_factory):
|
||||||
state = hass.states.get('lock.lock_1')
|
state = hass.states.get('lock.lock_1')
|
||||||
assert state is not None
|
assert state is not None
|
||||||
assert state.state == 'locked'
|
assert state.state == 'locked'
|
||||||
|
assert state.attributes['method'] == 'Manual'
|
||||||
|
assert state.attributes['lock_state'] == 'locked'
|
||||||
|
assert state.attributes['code_name'] == 'Code 1'
|
||||||
|
assert state.attributes['used_code'] == 'Code 2'
|
||||||
|
assert state.attributes['lock_name'] == 'Front Door'
|
||||||
|
assert 'code_id' not in state.attributes
|
||||||
|
|
||||||
|
|
||||||
async def test_unlock(hass, device_factory):
|
async def test_unlock(hass, device_factory):
|
||||||
|
|
Loading…
Reference in New Issue