Refactor DNS resolution tests to use AsyncMock and improve timeout handling
This commit is contained in:
parent
d7ca9cc87f
commit
8d99cfe53c
3 changed files with 50 additions and 27 deletions
|
@ -115,7 +115,10 @@ class TestResolveHostname:
|
|||
@pytest.mark.asyncio
|
||||
async def test_timeout_resolution(self):
|
||||
"""Test hostname resolution timeout."""
|
||||
with patch("asyncio.wait_for", side_effect=asyncio.TimeoutError()):
|
||||
async def mock_wait_for(*args, **kwargs):
|
||||
raise asyncio.TimeoutError()
|
||||
|
||||
with patch("asyncio.wait_for", side_effect=mock_wait_for) as mock_wait_for:
|
||||
resolution = await resolve_hostname("slow.example", timeout=1.0)
|
||||
|
||||
assert resolution.hostname == "slow.example"
|
||||
|
@ -161,7 +164,7 @@ class TestResolveHostnamesBatch:
|
|||
"""Test successful batch hostname resolution."""
|
||||
hostnames = ["example.com", "test.example"]
|
||||
|
||||
with patch("src.hosts.core.dns.resolve_hostname") as mock_resolve:
|
||||
with patch("src.hosts.core.dns.resolve_hostname", new_callable=AsyncMock) as mock_resolve:
|
||||
# Mock successful resolutions
|
||||
mock_resolve.side_effect = [
|
||||
DNSResolution(
|
||||
|
@ -191,23 +194,26 @@ class TestResolveHostnamesBatch:
|
|||
"""Test batch resolution with mixed success/failure."""
|
||||
hostnames = ["example.com", "nonexistent.example"]
|
||||
|
||||
with patch("src.hosts.core.dns.resolve_hostname") as mock_resolve:
|
||||
# Mock mixed results
|
||||
mock_resolve.side_effect = [
|
||||
DNSResolution(
|
||||
hostname="example.com",
|
||||
resolved_ip="192.0.2.1",
|
||||
status=DNSResolutionStatus.RESOLVED,
|
||||
resolved_at=datetime.now(),
|
||||
),
|
||||
DNSResolution(
|
||||
hostname="nonexistent.example",
|
||||
resolved_ip=None,
|
||||
status=DNSResolutionStatus.RESOLUTION_FAILED,
|
||||
resolved_at=datetime.now(),
|
||||
error_message="Name not found",
|
||||
),
|
||||
]
|
||||
with patch("src.hosts.core.dns.resolve_hostname", new_callable=AsyncMock) as mock_resolve:
|
||||
# Mock mixed results - use side_effect as a proper async function
|
||||
async def mock_side_effect(hostname, timeout=5.0):
|
||||
if hostname == "example.com":
|
||||
return DNSResolution(
|
||||
hostname="example.com",
|
||||
resolved_ip="192.0.2.1",
|
||||
status=DNSResolutionStatus.RESOLVED,
|
||||
resolved_at=datetime.now(),
|
||||
)
|
||||
else:
|
||||
return DNSResolution(
|
||||
hostname="nonexistent.example",
|
||||
resolved_ip=None,
|
||||
status=DNSResolutionStatus.RESOLUTION_FAILED,
|
||||
resolved_at=datetime.now(),
|
||||
error_message="Name not found",
|
||||
)
|
||||
|
||||
mock_resolve.side_effect = mock_side_effect
|
||||
|
||||
resolutions = await resolve_hostnames_batch(hostnames)
|
||||
|
||||
|
@ -270,7 +276,7 @@ class TestDNSService:
|
|||
"""Test async resolution when service is enabled."""
|
||||
service = DNSService(enabled=True)
|
||||
|
||||
with patch("src.hosts.core.dns.resolve_hostname") as mock_resolve:
|
||||
with patch("src.hosts.core.dns.resolve_hostname", new_callable=AsyncMock) as mock_resolve:
|
||||
mock_resolution = DNSResolution(
|
||||
hostname="example.com",
|
||||
resolved_ip="192.0.2.1",
|
||||
|
@ -301,7 +307,7 @@ class TestDNSService:
|
|||
"""Test manual entry refresh."""
|
||||
service = DNSService(enabled=True)
|
||||
|
||||
with patch("src.hosts.core.dns.resolve_hostname") as mock_resolve:
|
||||
with patch("src.hosts.core.dns.resolve_hostname", new_callable=AsyncMock) as mock_resolve:
|
||||
mock_resolution = DNSResolution(
|
||||
hostname="example.com",
|
||||
resolved_ip="192.0.2.1",
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue