Ejemplo n.º 1
0
async def test_flow_works(hass, aioclient_mock):
    """Test that config flow works."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER,
                       json=[{
                           'id': 'id',
                           'internalipaddress': '1.2.3.4',
                           'internalport': 80
                       }])
    aioclient_mock.post('http://1.2.3.4:80/api',
                        json=[{
                            "success": {
                                "username": "******"
                            }
                        }])

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    await flow.async_step_user()
    await flow.async_step_link(user_input={})
    result = await flow.async_step_options(user_input={
        'allow_clip_sensor': True,
        'allow_deconz_groups': True
    })

    assert result['type'] == 'create_entry'
    assert result['title'] == 'deCONZ-id'
    assert result['data'] == {
        'bridgeid': 'id',
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF',
        'allow_clip_sensor': True,
        'allow_deconz_groups': True
    }
Ejemplo n.º 2
0
async def test_create_entry(hass, aioclient_mock):
    """Test that _create_entry work and that bridgeid can be requested."""
    aioclient_mock.get(
        "http://1.2.3.4:80/api/1234567890ABCDEF/config",
        json={
            "bridgeid": "123ABC",
            "uuid": "456DEF"
        },
        headers={"content-type": "application/json"},
    )

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        config_flow.CONF_HOST: "1.2.3.4",
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: "1234567890ABCDEF",
    }

    result = await flow._create_entry()

    assert result["type"] == "create_entry"
    assert result["title"] == "deCONZ-123ABC"
    assert result["data"] == {
        config_flow.CONF_BRIDGEID: "123ABC",
        config_flow.CONF_HOST: "1.2.3.4",
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: "1234567890ABCDEF",
        config_flow.CONF_UUID: "456DEF",
    }
Ejemplo n.º 3
0
async def test_bridge_discovery_config_file(hass):
    """Test a bridge being discovered with a corresponding config file."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    with patch.object(config_flow,
                      'load_json',
                      return_value={
                          'host': '1.2.3.4',
                          'port': 8080,
                          'api_key': '1234567890ABCDEF'
                      }):
        result = await flow.async_step_discovery({
            'host': '1.2.3.4',
            'port': 80,
            'serial': 'id'
        })

    assert result['type'] == 'create_entry'
    assert result['title'] == 'deCONZ-id'
    assert result['data'] == {
        'bridgeid': 'id',
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF',
        'allow_clip_sensor': True,
        'allow_deconz_groups': True
    }
Ejemplo n.º 4
0
async def test_options(hass, aioclient_mock):
    """Test that options work and that bridgeid can be requested."""
    aioclient_mock.get('http://1.2.3.4:80/api/1234567890ABCDEF/config',
                       json={"bridgeid": "id"})
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF'
    }
    result = await flow.async_step_options(user_input={
        'allow_clip_sensor': False,
        'allow_deconz_groups': False
    })
    assert result['type'] == 'create_entry'
    assert result['title'] == 'deCONZ-id'
    assert result['data'] == {
        'bridgeid': 'id',
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF',
        'allow_clip_sensor': False,
        'allow_deconz_groups': False
    }
Ejemplo n.º 5
0
async def test_flow_no_discovered_bridges(hass, aioclient_mock):
    """Test config flow discovers no bridges."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER, json=[])
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()
    assert result['type'] == 'abort'
Ejemplo n.º 6
0
async def test_flow_already_registered_bridge(hass):
    """Test config flow don't allow more than one bridge to be registered."""
    MockConfigEntry(domain='deconz', data={
        'host': '1.2.3.4'
    }).add_to_hass(hass)
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()
    assert result['type'] == 'abort'
Ejemplo n.º 7
0
async def test_flow_bridge_discovery_fails(hass, aioclient_mock):
    """Test config flow works when discovery fails."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    with patch('pydeconz.utils.async_discovery',
               side_effect=asyncio.TimeoutError):
        result = await flow.async_step_user()

    assert result['type'] == 'form'
    assert result['step_id'] == 'init'
Ejemplo n.º 8
0
async def test_flow_one_bridge_discovered(hass, aioclient_mock):
    """Test config flow discovers one bridge."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER, json=[
        {'id': 'id', 'internalipaddress': '1.2.3.4', 'internalport': 80}
    ])
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_init()
    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
Ejemplo n.º 9
0
async def test_import_without_api_key(hass):
    """Test importing a host without an API key."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_import({
        'host': '1.2.3.4',
    })

    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
Ejemplo n.º 10
0
async def test_link_no_api_key(hass, aioclient_mock):
    """Test config flow should abort if no API key was possible to retrieve."""
    aioclient_mock.post('http://1.2.3.4:80/api', json=[])
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {'host': '1.2.3.4', 'port': 80}

    result = await flow.async_step_link(user_input={})
    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert result['errors'] == {'base': 'no_key'}
Ejemplo n.º 11
0
async def test_bridge_discovery(hass):
    """Test a bridge being discovered."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    result = await flow.async_step_discovery({
        'host': '1.2.3.4',
        'port': 80,
        'serial': 'id'
    })

    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
Ejemplo n.º 12
0
async def test_flow_manual_configuration(hass, aioclient_mock):
    """Test config flow with manual input."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER, json=[])
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    user_input = {'host': '1.2.3.4', 'port': 80}

    result = await flow.async_step_init(user_input)
    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert flow.deconz_config == user_input
Ejemplo n.º 13
0
async def test_flow_no_discovered_bridges(hass, aioclient_mock):
    """Test config flow discovers no bridges."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER,
                       json=[],
                       headers={'content-type': 'application/json'})

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()
    assert result['type'] == 'form'
    assert result['step_id'] == 'init'
Ejemplo n.º 14
0
async def test_link_no_api_key(hass):
    """Test config flow should abort if no API key was possible to retrieve."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {'host': '1.2.3.4', 'port': 80}

    with patch('pydeconz.utils.async_get_api_key',
               side_effect=pydeconz.errors.ResponseError):
        result = await flow.async_step_link(user_input={})

    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert result['errors'] == {'base': 'no_key'}
Ejemplo n.º 15
0
async def test_bridge_discovery(hass):
    """Test a bridge being discovered with no additional config file."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    with patch.object(config_flow, 'load_json', return_value={}):
        result = await flow.async_step_discovery({
            'host': '1.2.3.4',
            'port': 80,
            'serial': 'id'
        })

    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
Ejemplo n.º 16
0
async def test_link_already_registered_bridge(hass):
    """Test that link verifies to only allow one config entry to complete.

    This is possible with discovery which will allow the user to complete
    a second config entry and then complete the discovered config entry.
    """
    MockConfigEntry(domain='deconz', data={
        'host': '1.2.3.4'
    }).add_to_hass(hass)
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {'host': '1.2.3.4', 'port': 80}

    result = await flow.async_step_link(user_input={})
    assert result['type'] == 'abort'
Ejemplo n.º 17
0
async def test_bridge_discovery_already_configured(hass):
    """Test if a discovered bridge has already been configured."""
    MockConfigEntry(domain='deconz', data={
        'host': '1.2.3.4'
    }).add_to_hass(hass)

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_discovery({
        'host': '1.2.3.4',
        'serial': 'id'
    })

    assert result['type'] == 'abort'
Ejemplo n.º 18
0
async def test_create_entry_timeout(hass, aioclient_mock):
    """Test that _create_entry handles a timeout."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        config_flow.CONF_HOST: '1.2.3.4',
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: '1234567890ABCDEF'
    }

    with patch('pydeconz.utils.async_get_bridgeid',
               side_effect=asyncio.TimeoutError):
        result = await flow._create_entry()

    assert result['type'] == 'abort'
    assert result['reason'] == 'no_bridges'
Ejemplo n.º 19
0
async def test_flow_two_bridges_selection(hass, aioclient_mock):
    """Test config flow selection of one of two bridges."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.bridges = [{
        'bridgeid': 'id1',
        'host': '1.2.3.4',
        'port': 80
    }, {
        'bridgeid': 'id2',
        'host': '5.6.7.8',
        'port': 80
    }]

    result = await flow.async_step_user(user_input={'host': '1.2.3.4'})
    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert flow.deconz_config['host'] == '1.2.3.4'
Ejemplo n.º 20
0
async def test_create_entry_timeout(hass, aioclient_mock):
    """Test that _create_entry handles a timeout."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        config_flow.CONF_HOST: "1.2.3.4",
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: "1234567890ABCDEF",
    }

    with patch(
            "homeassistant.components.deconz.config_flow.async_get_gateway_config",
            side_effect=asyncio.TimeoutError,
    ):
        result = await flow._create_entry()

    assert result["type"] == "abort"
    assert result["reason"] == "no_bridges"
Ejemplo n.º 21
0
async def test_flow_two_bridges_discovered(hass, aioclient_mock):
    """Test config flow discovers two bridges."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER, json=[
        {'id': 'id1', 'internalipaddress': '1.2.3.4', 'internalport': 80},
        {'id': 'id2', 'internalipaddress': '5.6.7.8', 'internalport': 80}
    ])
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_init()
    assert result['type'] == 'form'
    assert result['step_id'] == 'init'

    with pytest.raises(vol.Invalid):
        assert result['data_schema']({'host': '0.0.0.0'})

    result['data_schema']({'host': '1.2.3.4'})
    result['data_schema']({'host': '5.6.7.8'})
Ejemplo n.º 22
0
async def test_user_step_one_bridge_discovered(hass, aioclient_mock):
    """Test config flow discovers one bridge."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER,
                       json=[{
                           'id': 'id',
                           'internalipaddress': '1.2.3.4',
                           'internalport': 80
                       }],
                       headers={'content-type': 'application/json'})

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()

    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert flow.deconz_config[config_flow.CONF_HOST] == '1.2.3.4'
Ejemplo n.º 23
0
async def test_link_no_api_key(hass):
    """Test config flow should abort if no API key was possible to retrieve."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        config_flow.CONF_HOST: "1.2.3.4",
        config_flow.CONF_PORT: 80
    }

    with patch(
            "homeassistant.components.deconz.config_flow.async_get_api_key",
            side_effect=pydeconz.errors.ResponseError,
    ):
        result = await flow.async_step_link(user_input={})

    assert result["type"] == "form"
    assert result["step_id"] == "link"
    assert result["errors"] == {"base": "no_key"}
Ejemplo n.º 24
0
async def test_user_step_two_bridges_selection(hass, aioclient_mock):
    """Test config flow selection of one of two bridges."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.bridges = [{
        config_flow.CONF_BRIDGEID: 'id1',
        config_flow.CONF_HOST: '1.2.3.4',
        config_flow.CONF_PORT: 80
    }, {
        config_flow.CONF_BRIDGEID: 'id2',
        config_flow.CONF_HOST: '5.6.7.8',
        config_flow.CONF_PORT: 80
    }]

    result = await flow.async_step_user(
        user_input={config_flow.CONF_HOST: '1.2.3.4'})
    assert result['type'] == 'form'
    assert result['step_id'] == 'link'
    assert flow.deconz_config[config_flow.CONF_HOST] == '1.2.3.4'
Ejemplo n.º 25
0
async def test_flow_two_bridges_discovered(hass, aioclient_mock):
    """Test config flow discovers two bridges."""
    aioclient_mock.get(pydeconz.utils.URL_DISCOVER,
                       json=[{
                           'id': 'id1',
                           'internalipaddress': '1.2.3.4',
                           'internalport': 80
                       }, {
                           'id': 'id2',
                           'internalipaddress': '5.6.7.8',
                           'internalport': 80
                       }],
                       headers={'content-type': 'application/json'})

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()
    assert result['data_schema']({'host': '1.2.3.4'})
    assert result['data_schema']({'host': '5.6.7.8'})
Ejemplo n.º 26
0
async def test_import_with_api_key(hass):
    """Test importing a host with an API key."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_import({
        'bridgeid': 'id',
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF'
    })

    assert result['type'] == 'create_entry'
    assert result['title'] == 'deCONZ-id'
    assert result['data'] == {
        'bridgeid': 'id',
        'host': '1.2.3.4',
        'port': 80,
        'api_key': '1234567890ABCDEF'
    }
Ejemplo n.º 27
0
async def test_user_step_one_bridge_discovered(hass, aioclient_mock):
    """Test config flow discovers one bridge."""
    aioclient_mock.get(
        pydeconz.utils.URL_DISCOVER,
        json=[{
            "id": "id",
            "internalipaddress": "1.2.3.4",
            "internalport": 80
        }],
        headers={"content-type": "application/json"},
    )

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass

    result = await flow.async_step_user()

    assert result["type"] == "form"
    assert result["step_id"] == "link"
    assert flow.deconz_config[config_flow.CONF_HOST] == "1.2.3.4"
Ejemplo n.º 28
0
async def test_user_step_two_bridges_selection(hass, aioclient_mock):
    """Test config flow selection of one of two bridges."""
    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.bridges = [
        {
            config_flow.CONF_BRIDGEID: "id1",
            config_flow.CONF_HOST: "1.2.3.4",
            config_flow.CONF_PORT: 80,
        },
        {
            config_flow.CONF_BRIDGEID: "id2",
            config_flow.CONF_HOST: "5.6.7.8",
            config_flow.CONF_PORT: 80,
        },
    ]

    result = await flow.async_step_user(
        user_input={config_flow.CONF_HOST: "1.2.3.4"})
    assert result["type"] == "form"
    assert result["step_id"] == "link"
    assert flow.deconz_config[config_flow.CONF_HOST] == "1.2.3.4"
Ejemplo n.º 29
0
async def test_create_entry(hass, aioclient_mock):
    """Test that _create_entry work and that bridgeid can be requested."""
    aioclient_mock.get('http://1.2.3.4:80/api/1234567890ABCDEF/config',
                       json={"bridgeid": "id"},
                       headers={'content-type': 'application/json'})

    flow = config_flow.DeconzFlowHandler()
    flow.hass = hass
    flow.deconz_config = {
        config_flow.CONF_HOST: '1.2.3.4',
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: '1234567890ABCDEF'
    }

    result = await flow._create_entry()

    assert result['type'] == 'create_entry'
    assert result['title'] == 'deCONZ-id'
    assert result['data'] == {
        config_flow.CONF_BRIDGEID: 'id',
        config_flow.CONF_HOST: '1.2.3.4',
        config_flow.CONF_PORT: 80,
        config_flow.CONF_API_KEY: '1234567890ABCDEF'
    }