Complete test coverage for Tankerkonig (#115920)
* complete tests * update snapshots after rebase
This commit is contained in:
parent
72ed16c3e0
commit
35db2e4101
9 changed files with 262 additions and 33 deletions
|
@ -1408,11 +1408,6 @@ omit =
|
||||||
homeassistant/components/tado/water_heater.py
|
homeassistant/components/tado/water_heater.py
|
||||||
homeassistant/components/tami4/button.py
|
homeassistant/components/tami4/button.py
|
||||||
homeassistant/components/tank_utility/sensor.py
|
homeassistant/components/tank_utility/sensor.py
|
||||||
homeassistant/components/tankerkoenig/__init__.py
|
|
||||||
homeassistant/components/tankerkoenig/binary_sensor.py
|
|
||||||
homeassistant/components/tankerkoenig/coordinator.py
|
|
||||||
homeassistant/components/tankerkoenig/entity.py
|
|
||||||
homeassistant/components/tankerkoenig/sensor.py
|
|
||||||
homeassistant/components/tapsaff/binary_sensor.py
|
homeassistant/components/tapsaff/binary_sensor.py
|
||||||
homeassistant/components/tautulli/__init__.py
|
homeassistant/components/tautulli/__init__.py
|
||||||
homeassistant/components/tautulli/coordinator.py
|
homeassistant/components/tautulli/coordinator.py
|
||||||
|
|
|
@ -6,20 +6,11 @@ from unittest.mock import AsyncMock, patch
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
from homeassistant.components.tankerkoenig import DOMAIN
|
from homeassistant.components.tankerkoenig import DOMAIN
|
||||||
from homeassistant.components.tankerkoenig.const import CONF_FUEL_TYPES, CONF_STATIONS
|
from homeassistant.const import CONF_SHOW_ON_MAP
|
||||||
from homeassistant.const import (
|
|
||||||
CONF_API_KEY,
|
|
||||||
CONF_LATITUDE,
|
|
||||||
CONF_LOCATION,
|
|
||||||
CONF_LONGITUDE,
|
|
||||||
CONF_NAME,
|
|
||||||
CONF_RADIUS,
|
|
||||||
CONF_SHOW_ON_MAP,
|
|
||||||
)
|
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.setup import async_setup_component
|
from homeassistant.setup import async_setup_component
|
||||||
|
|
||||||
from .const import NEARBY_STATIONS, PRICES, STATION
|
from .const import CONFIG_DATA, NEARBY_STATIONS, PRICES, STATION
|
||||||
|
|
||||||
from tests.common import MockConfigEntry
|
from tests.common import MockConfigEntry
|
||||||
|
|
||||||
|
@ -55,16 +46,7 @@ async def mock_config_entry(hass: HomeAssistant) -> MockConfigEntry:
|
||||||
options={
|
options={
|
||||||
CONF_SHOW_ON_MAP: True,
|
CONF_SHOW_ON_MAP: True,
|
||||||
},
|
},
|
||||||
data={
|
data=CONFIG_DATA,
|
||||||
CONF_NAME: "Home",
|
|
||||||
CONF_API_KEY: "269534f6-xxxx-xxxx-xxxx-yyyyzzzzxxxx",
|
|
||||||
CONF_FUEL_TYPES: ["e5"],
|
|
||||||
CONF_LOCATION: {CONF_LATITUDE: 51.0, CONF_LONGITUDE: 13.0},
|
|
||||||
CONF_RADIUS: 2.0,
|
|
||||||
CONF_STATIONS: [
|
|
||||||
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
|
||||||
],
|
|
||||||
},
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,16 @@
|
||||||
|
|
||||||
from aiotankerkoenig import PriceInfo, Station, Status
|
from aiotankerkoenig import PriceInfo, Station, Status
|
||||||
|
|
||||||
|
from homeassistant.components.tankerkoenig.const import CONF_FUEL_TYPES, CONF_STATIONS
|
||||||
|
from homeassistant.const import (
|
||||||
|
CONF_API_KEY,
|
||||||
|
CONF_LATITUDE,
|
||||||
|
CONF_LOCATION,
|
||||||
|
CONF_LONGITUDE,
|
||||||
|
CONF_NAME,
|
||||||
|
CONF_RADIUS,
|
||||||
|
)
|
||||||
|
|
||||||
NEARBY_STATIONS = [
|
NEARBY_STATIONS = [
|
||||||
Station(
|
Station(
|
||||||
id="3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
id="3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
||||||
|
@ -49,6 +59,25 @@ STATION = Station(
|
||||||
state="xxXX",
|
state="xxXX",
|
||||||
)
|
)
|
||||||
|
|
||||||
|
STATION_MISSING_FUELTYPE = Station(
|
||||||
|
id="3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
||||||
|
name="Station ABC",
|
||||||
|
brand="Station",
|
||||||
|
street="Somewhere Street",
|
||||||
|
house_number="1",
|
||||||
|
post_code=1234,
|
||||||
|
place="Somewhere",
|
||||||
|
opening_times=[],
|
||||||
|
overrides=[],
|
||||||
|
whole_day=True,
|
||||||
|
is_open=True,
|
||||||
|
e5=1.719,
|
||||||
|
e10=1.659,
|
||||||
|
lat=51.1,
|
||||||
|
lng=13.1,
|
||||||
|
state="xxXX",
|
||||||
|
)
|
||||||
|
|
||||||
PRICES = {
|
PRICES = {
|
||||||
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8": PriceInfo(
|
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8": PriceInfo(
|
||||||
status=Status.OPEN,
|
status=Status.OPEN,
|
||||||
|
@ -57,3 +86,22 @@ PRICES = {
|
||||||
diesel=1.659,
|
diesel=1.659,
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PRICES_MISSING_FUELTYPE = {
|
||||||
|
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8": PriceInfo(
|
||||||
|
status=Status.OPEN,
|
||||||
|
e5=1.719,
|
||||||
|
e10=1.659,
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
|
CONFIG_DATA = {
|
||||||
|
CONF_NAME: "Home",
|
||||||
|
CONF_API_KEY: "269534f6-xxxx-xxxx-xxxx-yyyyzzzzxxxx",
|
||||||
|
CONF_FUEL_TYPES: ["e5"],
|
||||||
|
CONF_LOCATION: {CONF_LATITUDE: 51.0, CONF_LONGITUDE: 13.0},
|
||||||
|
CONF_RADIUS: 2.0,
|
||||||
|
CONF_STATIONS: [
|
||||||
|
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
# serializer version: 1
|
||||||
|
# name: test_binary_sensor
|
||||||
|
ReadOnlyDict({
|
||||||
|
'device_class': 'door',
|
||||||
|
'friendly_name': 'Station Somewhere Street 1 Status',
|
||||||
|
'latitude': 51.1,
|
||||||
|
'longitude': 13.1,
|
||||||
|
})
|
||||||
|
# ---
|
52
tests/components/tankerkoenig/snapshots/test_sensor.ambr
Normal file
52
tests/components/tankerkoenig/snapshots/test_sensor.ambr
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
# serializer version: 1
|
||||||
|
# name: test_sensor
|
||||||
|
ReadOnlyDict({
|
||||||
|
'attribution': 'Data provided by https://www.tankerkoenig.de',
|
||||||
|
'brand': 'Station',
|
||||||
|
'city': 'Somewhere',
|
||||||
|
'friendly_name': 'Station Somewhere Street 1 Super E10',
|
||||||
|
'fuel_type': <GasType.E10: 'e10'>,
|
||||||
|
'house_number': '1',
|
||||||
|
'latitude': 51.1,
|
||||||
|
'longitude': 13.1,
|
||||||
|
'postcode': 1234,
|
||||||
|
'state_class': <SensorStateClass.MEASUREMENT: 'measurement'>,
|
||||||
|
'station_name': 'Station ABC',
|
||||||
|
'street': 'Somewhere Street',
|
||||||
|
'unit_of_measurement': '€',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
|
# name: test_sensor.1
|
||||||
|
ReadOnlyDict({
|
||||||
|
'attribution': 'Data provided by https://www.tankerkoenig.de',
|
||||||
|
'brand': 'Station',
|
||||||
|
'city': 'Somewhere',
|
||||||
|
'friendly_name': 'Station Somewhere Street 1 Super',
|
||||||
|
'fuel_type': <GasType.E5: 'e5'>,
|
||||||
|
'house_number': '1',
|
||||||
|
'latitude': 51.1,
|
||||||
|
'longitude': 13.1,
|
||||||
|
'postcode': 1234,
|
||||||
|
'state_class': <SensorStateClass.MEASUREMENT: 'measurement'>,
|
||||||
|
'station_name': 'Station ABC',
|
||||||
|
'street': 'Somewhere Street',
|
||||||
|
'unit_of_measurement': '€',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
|
# name: test_sensor.2
|
||||||
|
ReadOnlyDict({
|
||||||
|
'attribution': 'Data provided by https://www.tankerkoenig.de',
|
||||||
|
'brand': 'Station',
|
||||||
|
'city': 'Somewhere',
|
||||||
|
'friendly_name': 'Station Somewhere Street 1 Diesel',
|
||||||
|
'fuel_type': <GasType.DIESEL: 'diesel'>,
|
||||||
|
'house_number': '1',
|
||||||
|
'latitude': 51.1,
|
||||||
|
'longitude': 13.1,
|
||||||
|
'postcode': 1234,
|
||||||
|
'state_class': <SensorStateClass.MEASUREMENT: 'measurement'>,
|
||||||
|
'station_name': 'Station ABC',
|
||||||
|
'street': 'Somewhere Street',
|
||||||
|
'unit_of_measurement': '€',
|
||||||
|
})
|
||||||
|
# ---
|
25
tests/components/tankerkoenig/test_binary_sensor.py
Normal file
25
tests/components/tankerkoenig/test_binary_sensor.py
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
"""Tests for the Tankerkoening integration."""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
from syrupy import SnapshotAssertion
|
||||||
|
|
||||||
|
from homeassistant.const import STATE_ON
|
||||||
|
from homeassistant.core import HomeAssistant
|
||||||
|
|
||||||
|
from tests.common import MockConfigEntry
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.usefixtures("setup_integration")
|
||||||
|
async def test_binary_sensor(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
config_entry: MockConfigEntry,
|
||||||
|
snapshot: SnapshotAssertion,
|
||||||
|
) -> None:
|
||||||
|
"""Test the tankerkoenig binary sensors."""
|
||||||
|
|
||||||
|
state = hass.states.get("binary_sensor.station_somewhere_street_1_status")
|
||||||
|
assert state
|
||||||
|
assert state.state == STATE_ON
|
||||||
|
assert state.attributes == snapshot
|
|
@ -1,6 +1,6 @@
|
||||||
"""Tests for Tankerkoenig config flow."""
|
"""Tests for Tankerkoenig config flow."""
|
||||||
|
|
||||||
from unittest.mock import patch
|
from unittest.mock import AsyncMock, patch
|
||||||
|
|
||||||
from aiotankerkoenig.exceptions import TankerkoenigInvalidKeyError
|
from aiotankerkoenig.exceptions import TankerkoenigInvalidKeyError
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ from homeassistant.const import (
|
||||||
)
|
)
|
||||||
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 homeassistant.setup import async_setup_component
|
||||||
|
|
||||||
from .const import NEARBY_STATIONS
|
from .const import NEARBY_STATIONS
|
||||||
|
|
||||||
|
@ -208,7 +209,7 @@ async def test_reauth(hass: HomeAssistant, config_entry: MockConfigEntry) -> Non
|
||||||
assert entry.data[CONF_API_KEY] == "269534f6-aaaa-bbbb-cccc-yyyyzzzzxxxx"
|
assert entry.data[CONF_API_KEY] == "269534f6-aaaa-bbbb-cccc-yyyyzzzzxxxx"
|
||||||
|
|
||||||
|
|
||||||
async def test_options_flow(hass: HomeAssistant) -> None:
|
async def test_options_flow(hass: HomeAssistant, tankerkoenig: AsyncMock) -> None:
|
||||||
"""Test options flow."""
|
"""Test options flow."""
|
||||||
|
|
||||||
mock_config = MockConfigEntry(
|
mock_config = MockConfigEntry(
|
||||||
|
@ -218,10 +219,17 @@ async def test_options_flow(hass: HomeAssistant) -> None:
|
||||||
unique_id=f"{DOMAIN}_{MOCK_USER_DATA[CONF_LOCATION][CONF_LATITUDE]}_{MOCK_USER_DATA[CONF_LOCATION][CONF_LONGITUDE]}",
|
unique_id=f"{DOMAIN}_{MOCK_USER_DATA[CONF_LOCATION][CONF_LATITUDE]}_{MOCK_USER_DATA[CONF_LOCATION][CONF_LONGITUDE]}",
|
||||||
)
|
)
|
||||||
mock_config.add_to_hass(hass)
|
mock_config.add_to_hass(hass)
|
||||||
|
assert await async_setup_component(hass, DOMAIN, {})
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
with patch(
|
with (
|
||||||
"homeassistant.components.tankerkoenig.config_flow.Tankerkoenig.nearby_stations",
|
patch(
|
||||||
return_value=NEARBY_STATIONS,
|
"homeassistant.components.tankerkoenig.config_flow.Tankerkoenig.nearby_stations",
|
||||||
|
return_value=NEARBY_STATIONS,
|
||||||
|
),
|
||||||
|
patch(
|
||||||
|
"homeassistant.config_entries.ConfigEntries.async_reload"
|
||||||
|
) as mock_async_reload,
|
||||||
):
|
):
|
||||||
result = await hass.config_entries.options.async_init(mock_config.entry_id)
|
result = await hass.config_entries.options.async_init(mock_config.entry_id)
|
||||||
assert result["type"] is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
|
@ -237,6 +245,10 @@ async def test_options_flow(hass: HomeAssistant) -> None:
|
||||||
assert result["type"] is FlowResultType.CREATE_ENTRY
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
assert not mock_config.options[CONF_SHOW_ON_MAP]
|
assert not mock_config.options[CONF_SHOW_ON_MAP]
|
||||||
|
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
assert mock_async_reload.call_count == 1
|
||||||
|
|
||||||
|
|
||||||
async def test_options_flow_error(hass: HomeAssistant) -> None:
|
async def test_options_flow_error(hass: HomeAssistant) -> None:
|
||||||
"""Test options flow."""
|
"""Test options flow."""
|
||||||
|
|
|
@ -15,14 +15,20 @@ import pytest
|
||||||
|
|
||||||
from homeassistant.components.binary_sensor import DOMAIN as BINARY_SENSOR_DOMAIN
|
from homeassistant.components.binary_sensor import DOMAIN as BINARY_SENSOR_DOMAIN
|
||||||
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN
|
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN
|
||||||
from homeassistant.components.tankerkoenig.const import DEFAULT_SCAN_INTERVAL, DOMAIN
|
from homeassistant.components.tankerkoenig.const import (
|
||||||
|
CONF_STATIONS,
|
||||||
|
DEFAULT_SCAN_INTERVAL,
|
||||||
|
DOMAIN,
|
||||||
|
)
|
||||||
from homeassistant.config_entries import ConfigEntryState
|
from homeassistant.config_entries import ConfigEntryState
|
||||||
from homeassistant.const import ATTR_ID, STATE_UNAVAILABLE
|
from homeassistant.const import ATTR_ID, CONF_SHOW_ON_MAP, STATE_UNAVAILABLE
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
||||||
from homeassistant.setup import async_setup_component
|
from homeassistant.setup import async_setup_component
|
||||||
import homeassistant.util.dt as dt_util
|
import homeassistant.util.dt as dt_util
|
||||||
|
|
||||||
|
from .const import CONFIG_DATA
|
||||||
|
|
||||||
from tests.common import MockConfigEntry, async_fire_time_changed
|
from tests.common import MockConfigEntry, async_fire_time_changed
|
||||||
|
|
||||||
|
|
||||||
|
@ -190,3 +196,38 @@ async def test_automatic_registry_cleanup(
|
||||||
len(dr.async_entries_for_config_entry(device_registry, config_entry.entry_id))
|
len(dr.async_entries_for_config_entry(device_registry, config_entry.entry_id))
|
||||||
== 1
|
== 1
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
async def test_many_stations_warning(
|
||||||
|
hass: HomeAssistant, tankerkoenig: AsyncMock, caplog: pytest.LogCaptureFixture
|
||||||
|
) -> None:
|
||||||
|
"""Test the warning about morethan 10 selected stations."""
|
||||||
|
mock_config = MockConfigEntry(
|
||||||
|
domain=DOMAIN,
|
||||||
|
data={
|
||||||
|
**CONFIG_DATA,
|
||||||
|
CONF_STATIONS: [
|
||||||
|
"3bcd61da-xxxx-xxxx-xxxx-19d5523a7ae8",
|
||||||
|
"36b4b812-xxxx-xxxx-xxxx-c51735325858",
|
||||||
|
"54e2b642-xxxx-xxxx-xxxx-87cd4e9867f1",
|
||||||
|
"11b5c130-xxxx-xxxx-xxxx-856b8489b528",
|
||||||
|
"a9137924-xxxx-xxxx-xxxx-7029d7eb073f",
|
||||||
|
"57c6d275-xxxx-xxxx-xxxx-7f6ad9e6d638",
|
||||||
|
"bbc3c3a2-xxxx-xxxx-xxxx-840cc3d496b6",
|
||||||
|
"1db63dd9-xxxx-xxxx-xxxx-a889b53cbc65",
|
||||||
|
"18d7262e-xxxx-xxxx-xxxx-4a61ad302e14",
|
||||||
|
"a8041aa3-xxxx-xxxx-xxxx-7c6b180e5a40",
|
||||||
|
"739aa0eb-xxxx-xxxx-xxxx-a3d7b6c8a42f",
|
||||||
|
"9ad9fb26-xxxx-xxxx-xxxx-84e6a02b3096",
|
||||||
|
"74267867-xxxx-xxxx-xxxx-74ce3d45882c",
|
||||||
|
"86657222-xxxx-xxxx-xxxx-a2b795ab3cf9",
|
||||||
|
],
|
||||||
|
},
|
||||||
|
options={CONF_SHOW_ON_MAP: True},
|
||||||
|
unique_id="51.0_13.0",
|
||||||
|
)
|
||||||
|
mock_config.add_to_hass(hass)
|
||||||
|
assert await async_setup_component(hass, DOMAIN, {})
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
assert "Found more than 10 stations to check" in caplog.text
|
||||||
|
|
65
tests/components/tankerkoenig/test_sensor.py
Normal file
65
tests/components/tankerkoenig/test_sensor.py
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
"""Tests for the Tankerkoening integration."""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from unittest.mock import AsyncMock
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
from syrupy import SnapshotAssertion
|
||||||
|
|
||||||
|
from homeassistant.components.tankerkoenig import DOMAIN
|
||||||
|
from homeassistant.core import HomeAssistant
|
||||||
|
from homeassistant.setup import async_setup_component
|
||||||
|
|
||||||
|
from .const import PRICES_MISSING_FUELTYPE, STATION_MISSING_FUELTYPE
|
||||||
|
|
||||||
|
from tests.common import MockConfigEntry
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.usefixtures("setup_integration")
|
||||||
|
async def test_sensor(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
tankerkoenig: AsyncMock,
|
||||||
|
config_entry: MockConfigEntry,
|
||||||
|
snapshot: SnapshotAssertion,
|
||||||
|
) -> None:
|
||||||
|
"""Test the tankerkoenig sensors."""
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_super_e10")
|
||||||
|
assert state
|
||||||
|
assert state.state == "1.659"
|
||||||
|
assert state.attributes == snapshot
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_super")
|
||||||
|
assert state
|
||||||
|
assert state.state == "1.719"
|
||||||
|
assert state.attributes == snapshot
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_diesel")
|
||||||
|
assert state
|
||||||
|
assert state.state == "1.659"
|
||||||
|
assert state.attributes == snapshot
|
||||||
|
|
||||||
|
|
||||||
|
async def test_sensor_missing_fueltype(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
tankerkoenig: AsyncMock,
|
||||||
|
config_entry: MockConfigEntry,
|
||||||
|
) -> None:
|
||||||
|
"""Test the tankerkoenig sensors."""
|
||||||
|
tankerkoenig.station_details.return_value = STATION_MISSING_FUELTYPE
|
||||||
|
tankerkoenig.prices.return_value = PRICES_MISSING_FUELTYPE
|
||||||
|
|
||||||
|
config_entry.add_to_hass(hass)
|
||||||
|
|
||||||
|
assert await async_setup_component(hass, DOMAIN, {})
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_super_e10")
|
||||||
|
assert state
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_super")
|
||||||
|
assert state
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.station_somewhere_street_1_diesel")
|
||||||
|
assert not state
|
Loading…
Add table
Reference in a new issue