After deactivation the endpoint now calls _run_probe to flush the cached server status immediately, matching the activate_jail behaviour added in Task 5. Without this, the dashboard active-jail count could remain stale for up to 30 s after a deactivation reload. - config.py: capture result, await _run_probe, return result - test_config.py: add test_deactivate_triggers_health_probe; fix 3 pre-existing UP017 ruff warnings (datetime.UTC alias) - test_health.py: update test to assert the new fail2ban field
28 lines
976 B
Python
28 lines
976 B
Python
"""Tests for the health check router."""
|
|
|
|
import pytest
|
|
from httpx import AsyncClient
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_health_check_returns_200(client: AsyncClient) -> None:
|
|
"""``GET /api/health`` must return HTTP 200."""
|
|
response = await client.get("/api/health")
|
|
assert response.status_code == 200
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_health_check_returns_ok_status(client: AsyncClient) -> None:
|
|
"""``GET /api/health`` must contain ``status: ok`` and a ``fail2ban`` field."""
|
|
response = await client.get("/api/health")
|
|
data: dict[str, str] = response.json()
|
|
assert data["status"] == "ok"
|
|
assert data["fail2ban"] in ("online", "offline")
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_health_check_content_type_is_json(client: AsyncClient) -> None:
|
|
"""``GET /api/health`` must set the ``Content-Type`` header to JSON."""
|
|
response = await client.get("/api/health")
|
|
assert "application/json" in response.headers.get("content-type", "")
|