2017-02-12 11:31:46 -08:00
|
|
|
"""Test hassbian config."""
|
|
|
|
import asyncio
|
|
|
|
from unittest.mock import patch
|
|
|
|
|
|
|
|
from homeassistant.bootstrap import async_setup_component
|
|
|
|
from homeassistant.components import config
|
2019-05-21 07:21:31 +02:00
|
|
|
from homeassistant.components.websocket_api.const import TYPE_RESULT
|
|
|
|
from homeassistant.const import CONF_UNIT_SYSTEM, CONF_UNIT_SYSTEM_IMPERIAL
|
|
|
|
import homeassistant.util.dt as dt_util
|
2017-05-25 21:13:53 -07:00
|
|
|
from tests.common import mock_coro
|
2017-02-12 11:31:46 -08:00
|
|
|
|
2019-05-21 07:21:31 +02:00
|
|
|
ORIG_TIME_ZONE = dt_util.DEFAULT_TIME_ZONE
|
2017-02-12 11:31:46 -08:00
|
|
|
|
2019-05-21 07:21:31 +02:00
|
|
|
|
|
|
|
async def test_validate_config_ok(hass, hass_client):
|
2017-02-13 21:34:36 -08:00
|
|
|
"""Test checking config."""
|
2017-02-12 11:31:46 -08:00
|
|
|
with patch.object(config, 'SECTIONS', ['core']):
|
2019-05-21 07:21:31 +02:00
|
|
|
await async_setup_component(hass, 'config', {})
|
2017-02-12 11:31:46 -08:00
|
|
|
|
2019-05-21 07:21:31 +02:00
|
|
|
await asyncio.sleep(0.1, loop=hass.loop)
|
2017-03-01 05:33:19 +01:00
|
|
|
|
2019-05-21 07:21:31 +02:00
|
|
|
client = await hass_client()
|
2017-02-12 11:31:46 -08:00
|
|
|
|
|
|
|
with patch(
|
|
|
|
'homeassistant.components.config.core.async_check_ha_config_file',
|
2017-02-15 23:19:34 -08:00
|
|
|
return_value=mock_coro()):
|
2019-05-21 07:21:31 +02:00
|
|
|
resp = await client.post('/api/config/core/check_config')
|
2017-02-12 11:31:46 -08:00
|
|
|
|
|
|
|
assert resp.status == 200
|
2019-05-21 07:21:31 +02:00
|
|
|
result = await resp.json()
|
2017-02-12 11:31:46 -08:00
|
|
|
assert result['result'] == 'valid'
|
|
|
|
assert result['errors'] is None
|
|
|
|
|
|
|
|
with patch(
|
|
|
|
'homeassistant.components.config.core.async_check_ha_config_file',
|
2017-02-15 23:19:34 -08:00
|
|
|
return_value=mock_coro('beer')):
|
2019-05-21 07:21:31 +02:00
|
|
|
resp = await client.post('/api/config/core/check_config')
|
2017-02-12 11:31:46 -08:00
|
|
|
|
|
|
|
assert resp.status == 200
|
2019-05-21 07:21:31 +02:00
|
|
|
result = await resp.json()
|
2017-02-12 11:31:46 -08:00
|
|
|
assert result['result'] == 'invalid'
|
|
|
|
assert result['errors'] == 'beer'
|
2019-05-21 07:21:31 +02:00
|
|
|
|
|
|
|
|
|
|
|
async def test_websocket_core_update(hass, hass_ws_client):
|
|
|
|
"""Test core config update websocket command."""
|
|
|
|
with patch.object(config, 'SECTIONS', ['core']):
|
|
|
|
await async_setup_component(hass, 'config', {})
|
|
|
|
|
|
|
|
assert hass.config.latitude != 60
|
|
|
|
assert hass.config.longitude != 50
|
|
|
|
assert hass.config.elevation != 25
|
|
|
|
assert hass.config.location_name != 'Huis'
|
|
|
|
assert hass.config.units.name != CONF_UNIT_SYSTEM_IMPERIAL
|
|
|
|
assert hass.config.time_zone.zone != 'America/New_York'
|
|
|
|
|
|
|
|
client = await hass_ws_client(hass)
|
|
|
|
await client.send_json({
|
|
|
|
'id': 5,
|
|
|
|
'type': 'config/core/update',
|
|
|
|
'latitude': 60,
|
|
|
|
'longitude': 50,
|
|
|
|
'elevation': 25,
|
|
|
|
'location_name': 'Huis',
|
|
|
|
CONF_UNIT_SYSTEM: CONF_UNIT_SYSTEM_IMPERIAL,
|
|
|
|
'time_zone': 'America/New_York',
|
|
|
|
})
|
|
|
|
|
|
|
|
msg = await client.receive_json()
|
|
|
|
|
|
|
|
assert msg['id'] == 5
|
|
|
|
assert msg['type'] == TYPE_RESULT
|
|
|
|
assert msg['success']
|
|
|
|
assert hass.config.latitude == 60
|
|
|
|
assert hass.config.longitude == 50
|
|
|
|
assert hass.config.elevation == 25
|
|
|
|
assert hass.config.location_name == 'Huis'
|
|
|
|
assert hass.config.units.name == CONF_UNIT_SYSTEM_IMPERIAL
|
|
|
|
assert hass.config.time_zone.zone == 'America/New_York'
|
|
|
|
|
|
|
|
dt_util.set_default_time_zone(ORIG_TIME_ZONE)
|
|
|
|
|
|
|
|
|
|
|
|
async def test_websocket_core_update_not_admin(
|
|
|
|
hass, hass_ws_client, hass_admin_user):
|
|
|
|
"""Test core config fails for non admin."""
|
|
|
|
hass_admin_user.groups = []
|
|
|
|
with patch.object(config, 'SECTIONS', ['core']):
|
|
|
|
await async_setup_component(hass, 'config', {})
|
|
|
|
|
|
|
|
client = await hass_ws_client(hass)
|
|
|
|
await client.send_json({
|
|
|
|
'id': 6,
|
|
|
|
'type': 'config/core/update',
|
|
|
|
'latitude': 123,
|
|
|
|
})
|
|
|
|
|
|
|
|
msg = await client.receive_json()
|
|
|
|
|
|
|
|
assert msg['id'] == 6
|
|
|
|
assert msg['type'] == TYPE_RESULT
|
|
|
|
assert not msg['success']
|
|
|
|
assert msg['error']['code'] == 'unauthorized'
|
|
|
|
|
|
|
|
|
|
|
|
async def test_websocket_bad_core_update(hass, hass_ws_client):
|
|
|
|
"""Test core config update fails with bad parameters."""
|
|
|
|
with patch.object(config, 'SECTIONS', ['core']):
|
|
|
|
await async_setup_component(hass, 'config', {})
|
|
|
|
|
|
|
|
client = await hass_ws_client(hass)
|
|
|
|
await client.send_json({
|
|
|
|
'id': 7,
|
|
|
|
'type': 'config/core/update',
|
|
|
|
'latituude': 123,
|
|
|
|
})
|
|
|
|
|
|
|
|
msg = await client.receive_json()
|
|
|
|
|
|
|
|
assert msg['id'] == 7
|
|
|
|
assert msg['type'] == TYPE_RESULT
|
|
|
|
assert not msg['success']
|
|
|
|
assert msg['error']['code'] == 'invalid_format'
|