1
0
mirror of https://github.com/esphome/esphome.git synced 2025-09-12 08:12:22 +01:00

make sure we did not break password auth

This commit is contained in:
J. Nick Koston
2025-07-11 10:19:33 -10:00
parent 005d4354d5
commit fc8c1ac9dd
2 changed files with 16 additions and 27 deletions

View File

@@ -18,12 +18,7 @@ async def test_host_mode_api_password(
) -> None:
"""Test API authentication with password."""
async with run_compiled(yaml_config):
# First, try to connect without password - should fail
with pytest.raises(APIConnectionError, match="Authentication"):
async with api_client_connected(password=""):
pass # Should not reach here
# Now connect with correct password
# Connect with correct password
async with api_client_connected(password="test_password_123") as client:
# Verify we can get device info
device_info = await client.device_info()
@@ -32,20 +27,27 @@ async def test_host_mode_api_password(
assert device_info.name == "host-mode-api-password"
# Subscribe to states to ensure authenticated connection works
loop = asyncio.get_running_loop()
state_future: asyncio.Future[bool] = loop.create_future()
states = {}
def on_state(state):
states[state.key] = state
if not state_future.done():
state_future.set_result(True)
await client.subscribe_states(on_state)
client.subscribe_states(on_state)
# Wait a bit to receive the test sensor state
await asyncio.sleep(0.5)
# Wait for at least one state with timeout
try:
await asyncio.wait_for(state_future, timeout=5.0)
except asyncio.TimeoutError:
pytest.fail("No states received within timeout")
# Should have received at least one state (the test sensor)
assert len(states) > 0
# Test with wrong password - should fail
with pytest.raises(APIConnectionError, match="Authentication"):
with pytest.raises(APIConnectionError, match="Invalid password"):
async with api_client_connected(password="wrong_password"):
pass # Should not reach here