2018-09-12 18:17:52 +00:00
|
|
|
"""Tests for the iOS init file."""
|
|
|
|
from unittest.mock import patch
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from homeassistant import config_entries, data_entry_flow
|
|
|
|
from homeassistant.components import ios
|
2019-12-09 13:21:24 +00:00
|
|
|
from homeassistant.setup import async_setup_component
|
2018-09-12 18:17:52 +00:00
|
|
|
|
|
|
|
from tests.common import mock_component, mock_coro
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def mock_load_json():
|
|
|
|
"""Mock load_json."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch("homeassistant.components.ios.load_json", return_value={}):
|
2018-09-12 18:17:52 +00:00
|
|
|
yield
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def mock_dependencies(hass):
|
|
|
|
"""Mock dependencies loaded."""
|
2019-07-31 19:25:30 +00:00
|
|
|
mock_component(hass, "zeroconf")
|
|
|
|
mock_component(hass, "device_tracker")
|
2018-09-12 18:17:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_creating_entry_sets_up_sensor(hass):
|
|
|
|
"""Test setting up iOS loads the sensor component."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.ios.sensor.async_setup_entry",
|
|
|
|
return_value=mock_coro(True),
|
|
|
|
) as mock_setup:
|
2018-09-12 18:17:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2019-07-31 19:25:30 +00:00
|
|
|
ios.DOMAIN, context={"source": config_entries.SOURCE_USER}
|
|
|
|
)
|
2018-09-21 14:34:37 +00:00
|
|
|
|
|
|
|
# Confirmation form
|
2019-07-31 19:25:30 +00:00
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
2018-09-21 14:34:37 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(result["flow_id"], {})
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
2018-09-12 18:17:52 +00:00
|
|
|
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_configuring_ios_creates_entry(hass):
|
|
|
|
"""Test that specifying config will create an entry."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.ios.async_setup_entry", return_value=mock_coro(True)
|
|
|
|
) as mock_setup:
|
|
|
|
await async_setup_component(hass, ios.DOMAIN, {"ios": {"push": {}}})
|
2018-09-12 18:17:52 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_not_configuring_ios_not_creates_entry(hass):
|
|
|
|
"""Test that no config will not create an entry."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.ios.async_setup_entry", return_value=mock_coro(True)
|
|
|
|
) as mock_setup:
|
2018-09-12 18:17:52 +00:00
|
|
|
await async_setup_component(hass, ios.DOMAIN, {})
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert len(mock_setup.mock_calls) == 0
|