Fix missing mocking in nextdns tests (#114541)

This commit is contained in:
J. Nick Koston 2024-04-01 06:53:49 -10:00 committed by GitHub
parent 429b5d22cf
commit 96120b64e0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 32 additions and 50 deletions

View File

@ -1,5 +1,6 @@
"""Tests for the NextDNS integration.""" """Tests for the NextDNS integration."""
from contextlib import contextmanager
from unittest.mock import patch from unittest.mock import patch
from nextdns import ( from nextdns import (
@ -113,16 +114,9 @@ SETTINGS = Settings(
) )
async def init_integration(hass: HomeAssistant) -> MockConfigEntry: @contextmanager
"""Set up the NextDNS integration in Home Assistant.""" def mock_nextdns():
entry = MockConfigEntry( """Mock the NextDNS class."""
domain=DOMAIN,
title="Fake Profile",
unique_id="xyz12",
data={CONF_API_KEY: "fake_api_key", CONF_PROFILE_ID: "xyz12"},
entry_id="d9aa37407ddac7b964a99e86312288d6",
)
with ( with (
patch( patch(
"homeassistant.components.nextdns.NextDns.get_profiles", "homeassistant.components.nextdns.NextDns.get_profiles",
@ -157,7 +151,22 @@ async def init_integration(hass: HomeAssistant) -> MockConfigEntry:
return_value=CONNECTION_STATUS, return_value=CONNECTION_STATUS,
), ),
): ):
yield
async def init_integration(hass: HomeAssistant) -> MockConfigEntry:
"""Set up the NextDNS integration in Home Assistant."""
entry = MockConfigEntry(
domain=DOMAIN,
title="Fake Profile",
unique_id="xyz12",
data={CONF_API_KEY: "fake_api_key", CONF_PROFILE_ID: "xyz12"},
entry_id="d9aa37407ddac7b964a99e86312288d6",
)
entry.add_to_hass(hass) entry.add_to_hass(hass)
with mock_nextdns():
await hass.config_entries.async_setup(entry.entry_id) await hass.config_entries.async_setup(entry.entry_id)
await hass.async_block_till_done() await hass.async_block_till_done()

View File

@ -10,7 +10,7 @@ from homeassistant.core import HomeAssistant
from homeassistant.helpers import entity_registry as er from homeassistant.helpers import entity_registry as er
from homeassistant.util.dt import utcnow from homeassistant.util.dt import utcnow
from . import CONNECTION_STATUS, init_integration from . import init_integration, mock_nextdns
from tests.common import async_fire_time_changed from tests.common import async_fire_time_changed
@ -57,19 +57,16 @@ async def test_availability(hass: HomeAssistant) -> None:
side_effect=ApiError("API Error"), side_effect=ApiError("API Error"),
): ):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("binary_sensor.fake_profile_device_connection_status") state = hass.states.get("binary_sensor.fake_profile_device_connection_status")
assert state assert state
assert state.state == STATE_UNAVAILABLE assert state.state == STATE_UNAVAILABLE
future = utcnow() + timedelta(minutes=20) future = utcnow() + timedelta(minutes=20)
with patch( with mock_nextdns():
"homeassistant.components.nextdns.NextDns.connection_status",
return_value=CONNECTION_STATUS,
):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("binary_sensor.fake_profile_device_connection_status") state = hass.states.get("binary_sensor.fake_profile_device_connection_status")
assert state assert state

View File

@ -11,7 +11,7 @@ from homeassistant.core import HomeAssistant
from homeassistant.helpers import entity_registry as er from homeassistant.helpers import entity_registry as er
from homeassistant.util.dt import utcnow from homeassistant.util.dt import utcnow
from . import DNSSEC, ENCRYPTION, IP_VERSIONS, PROTOCOLS, STATUS, init_integration from . import init_integration, mock_nextdns
from tests.common import async_fire_time_changed from tests.common import async_fire_time_changed
@ -332,7 +332,7 @@ async def test_availability(
), ),
): ):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("sensor.fake_profile_dns_queries") state = hass.states.get("sensor.fake_profile_dns_queries")
assert state assert state
@ -355,30 +355,9 @@ async def test_availability(
assert state.state == STATE_UNAVAILABLE assert state.state == STATE_UNAVAILABLE
future = utcnow() + timedelta(minutes=20) future = utcnow() + timedelta(minutes=20)
with ( with mock_nextdns():
patch(
"homeassistant.components.nextdns.NextDns.get_analytics_status",
return_value=STATUS,
),
patch(
"homeassistant.components.nextdns.NextDns.get_analytics_encryption",
return_value=ENCRYPTION,
),
patch(
"homeassistant.components.nextdns.NextDns.get_analytics_dnssec",
return_value=DNSSEC,
),
patch(
"homeassistant.components.nextdns.NextDns.get_analytics_ip_versions",
return_value=IP_VERSIONS,
),
patch(
"homeassistant.components.nextdns.NextDns.get_analytics_protocols",
return_value=PROTOCOLS,
),
):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("sensor.fake_profile_dns_queries") state = hass.states.get("sensor.fake_profile_dns_queries")
assert state assert state

View File

@ -22,7 +22,7 @@ from homeassistant.exceptions import HomeAssistantError
from homeassistant.helpers import entity_registry as er from homeassistant.helpers import entity_registry as er
from homeassistant.util.dt import utcnow from homeassistant.util.dt import utcnow
from . import SETTINGS, init_integration from . import init_integration, mock_nextdns
from tests.common import async_fire_time_changed from tests.common import async_fire_time_changed
@ -693,19 +693,16 @@ async def test_availability(hass: HomeAssistant) -> None:
side_effect=ApiError("API Error"), side_effect=ApiError("API Error"),
): ):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("switch.fake_profile_web3") state = hass.states.get("switch.fake_profile_web3")
assert state assert state
assert state.state == STATE_UNAVAILABLE assert state.state == STATE_UNAVAILABLE
future = utcnow() + timedelta(minutes=20) future = utcnow() + timedelta(minutes=20)
with patch( with mock_nextdns():
"homeassistant.components.nextdns.NextDns.get_settings",
return_value=SETTINGS,
):
async_fire_time_changed(hass, future) async_fire_time_changed(hass, future)
await hass.async_block_till_done() await hass.async_block_till_done(wait_background_tasks=True)
state = hass.states.get("switch.fake_profile_web3") state = hass.states.get("switch.fake_profile_web3")
assert state assert state