mirror of
https://github.com/home-assistant/core.git
synced 2025-07-22 20:57:21 +00:00
Ensure kraken tracked pairs can be deselected (#117461)
This commit is contained in:
parent
03aba7e7ab
commit
e0d8c4d726
@ -69,6 +69,17 @@ class KrakenOptionsFlowHandler(OptionsFlow):
|
|||||||
get_tradable_asset_pairs, api
|
get_tradable_asset_pairs, api
|
||||||
)
|
)
|
||||||
tradable_asset_pairs_for_multi_select = {v: v for v in tradable_asset_pairs}
|
tradable_asset_pairs_for_multi_select = {v: v for v in tradable_asset_pairs}
|
||||||
|
|
||||||
|
# Ensure that a previously selected tracked asset pair is still available in multiselect
|
||||||
|
# even if it is not tradable anymore
|
||||||
|
tracked_asset_pairs = self.config_entry.options.get(
|
||||||
|
CONF_TRACKED_ASSET_PAIRS, []
|
||||||
|
)
|
||||||
|
for tracked_asset_pair in tracked_asset_pairs:
|
||||||
|
tradable_asset_pairs_for_multi_select[tracked_asset_pair] = (
|
||||||
|
tracked_asset_pair
|
||||||
|
)
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
vol.Optional(
|
vol.Optional(
|
||||||
CONF_SCAN_INTERVAL,
|
CONF_SCAN_INTERVAL,
|
||||||
@ -78,7 +89,7 @@ class KrakenOptionsFlowHandler(OptionsFlow):
|
|||||||
): int,
|
): int,
|
||||||
vol.Optional(
|
vol.Optional(
|
||||||
CONF_TRACKED_ASSET_PAIRS,
|
CONF_TRACKED_ASSET_PAIRS,
|
||||||
default=self.config_entry.options.get(CONF_TRACKED_ASSET_PAIRS, []),
|
default=tracked_asset_pairs,
|
||||||
): cv.multi_select(tradable_asset_pairs_for_multi_select),
|
): cv.multi_select(tradable_asset_pairs_for_multi_select),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,7 +7,11 @@ from homeassistant.const import CONF_SCAN_INTERVAL
|
|||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.data_entry_flow import FlowResultType
|
from homeassistant.data_entry_flow import FlowResultType
|
||||||
|
|
||||||
from .const import TICKER_INFORMATION_RESPONSE, TRADEABLE_ASSET_PAIR_RESPONSE
|
from .const import (
|
||||||
|
MISSING_PAIR_TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
TICKER_INFORMATION_RESPONSE,
|
||||||
|
TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
)
|
||||||
|
|
||||||
from tests.common import MockConfigEntry
|
from tests.common import MockConfigEntry
|
||||||
|
|
||||||
@ -94,3 +98,64 @@ async def test_options(hass: HomeAssistant) -> None:
|
|||||||
assert ada_eth_sensor.state == "0.0003494"
|
assert ada_eth_sensor.state == "0.0003494"
|
||||||
|
|
||||||
assert hass.states.get("sensor.xbt_usd_ask") is None
|
assert hass.states.get("sensor.xbt_usd_ask") is None
|
||||||
|
|
||||||
|
|
||||||
|
async def test_deselect_removed_pair(hass: HomeAssistant) -> None:
|
||||||
|
"""Test options for Kraken."""
|
||||||
|
entry = MockConfigEntry(
|
||||||
|
domain=DOMAIN,
|
||||||
|
options={
|
||||||
|
CONF_SCAN_INTERVAL: 60,
|
||||||
|
CONF_TRACKED_ASSET_PAIRS: [
|
||||||
|
"XBT/USD",
|
||||||
|
],
|
||||||
|
},
|
||||||
|
)
|
||||||
|
entry.add_to_hass(hass)
|
||||||
|
|
||||||
|
with (
|
||||||
|
patch(
|
||||||
|
"homeassistant.components.kraken.config_flow.KrakenAPI.get_tradable_asset_pairs",
|
||||||
|
return_value=TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
),
|
||||||
|
patch(
|
||||||
|
"pykrakenapi.KrakenAPI.get_tradable_asset_pairs",
|
||||||
|
return_value=TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
),
|
||||||
|
patch(
|
||||||
|
"pykrakenapi.KrakenAPI.get_ticker_information",
|
||||||
|
return_value=TICKER_INFORMATION_RESPONSE,
|
||||||
|
),
|
||||||
|
):
|
||||||
|
await hass.config_entries.async_setup(entry.entry_id)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
with (
|
||||||
|
patch(
|
||||||
|
"homeassistant.components.kraken.config_flow.KrakenAPI.get_tradable_asset_pairs",
|
||||||
|
return_value=MISSING_PAIR_TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
),
|
||||||
|
patch(
|
||||||
|
"pykrakenapi.KrakenAPI.get_tradable_asset_pairs",
|
||||||
|
return_value=MISSING_PAIR_TRADEABLE_ASSET_PAIR_RESPONSE,
|
||||||
|
),
|
||||||
|
patch(
|
||||||
|
"pykrakenapi.KrakenAPI.get_ticker_information",
|
||||||
|
return_value=TICKER_INFORMATION_RESPONSE,
|
||||||
|
),
|
||||||
|
):
|
||||||
|
result = await hass.config_entries.options.async_init(entry.entry_id)
|
||||||
|
schema = result["data_schema"].schema
|
||||||
|
assert "XBT/USD" in schema.get(CONF_TRACKED_ASSET_PAIRS).options
|
||||||
|
result = await hass.config_entries.options.async_configure(
|
||||||
|
result["flow_id"],
|
||||||
|
{
|
||||||
|
CONF_SCAN_INTERVAL: 10,
|
||||||
|
CONF_TRACKED_ASSET_PAIRS: ["ADA/ETH"],
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
ada_eth_sensor = hass.states.get("sensor.ada_eth_ask")
|
||||||
|
assert ada_eth_sensor.state == "0.0003494"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user