Enhance device MAC address handling in tests to ensure lowercase normalization and skip tests when web protection is disabled

This commit is contained in:
Jokob @NetAlertX
2026-03-02 10:42:36 +00:00
parent 3a73817048
commit bc4f419927
3 changed files with 35 additions and 11 deletions

View File

@@ -99,9 +99,9 @@ def test_copy_device(client, api_token, test_mac):
)
assert resp.status_code == 200
# Step 2: Generate a target MAC
# Step 2: Generate a target MAC (lowercase to match DB trigger normalisation)
target_mac = "aa:bb:cc:" + ":".join(
f"{random.randint(0, 255):02X}" for _ in range(3)
f"{random.randint(0, 255):02x}" for _ in range(3)
)
# Step 3: Copy device

View File

@@ -78,7 +78,8 @@ class TestAlertDownNullCoercion:
"SELECT devMac FROM DevicesView WHERE devAlertDown != 0 AND devPresentLastScan = 0"
)
macs = [r["devMac"] for r in cur.fetchall()]
assert "AA:BB:CC:DD:EE:03" in macs
# DevicesView returns LOWER(devMac), so compare against lowercase
assert "aa:bb:cc:dd:ee:03" in macs
def test_online_device_not_in_down_event_query(self):
"""An online device (devPresentLastScan=1) should never fire a down event."""
@@ -116,7 +117,8 @@ class TestIsSleepingSuppression:
)
conn.commit()
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'BB:BB:BB:BB:BB:01'")
# DevicesView returns LOWER(devMac); query must use lowercase
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'bb:bb:bb:bb:bb:01'")
row = cur.fetchone()
assert row["devIsSleeping"] == 1
@@ -138,7 +140,8 @@ class TestIsSleepingSuppression:
AND devPresentLastScan = 0
""")
macs = [r["devMac"] for r in cur.fetchall()]
assert "BB:BB:BB:BB:BB:02" not in macs
# DevicesView returns LOWER(devMac)
assert "bb:bb:bb:bb:bb:02" not in macs
def test_expired_sleep_window_fires_down(self):
"""After the sleep window expires, the device must appear as Down."""
@@ -151,7 +154,8 @@ class TestIsSleepingSuppression:
)
conn.commit()
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'BB:BB:BB:BB:BB:03'")
# DevicesView returns LOWER(devMac); query must use lowercase
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'bb:bb:bb:bb:bb:03'")
assert cur.fetchone()["devIsSleeping"] == 0
cur.execute("""
@@ -161,7 +165,7 @@ class TestIsSleepingSuppression:
AND devPresentLastScan = 0
""")
macs = [r["devMac"] for r in cur.fetchall()]
assert "BB:BB:BB:BB:BB:03" in macs
assert "bb:bb:bb:bb:bb:03" in macs
def test_can_sleep_zero_device_is_not_sleeping(self):
"""devCanSleep=0 device recently offline → devIsSleeping must be 0."""
@@ -174,7 +178,8 @@ class TestIsSleepingSuppression:
)
conn.commit()
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'BB:BB:BB:BB:BB:04'")
# DevicesView returns LOWER(devMac); query must use lowercase
cur.execute("SELECT devIsSleeping FROM DevicesView WHERE devMac = 'bb:bb:bb:bb:bb:04'")
assert cur.fetchone()["devIsSleeping"] == 0
def test_devstatus_sleeping(self):
@@ -188,7 +193,8 @@ class TestIsSleepingSuppression:
)
conn.commit()
cur.execute("SELECT devStatus FROM DevicesView WHERE devMac = 'BB:BB:BB:BB:BB:05'")
# DevicesView returns LOWER(devMac); query must use lowercase
cur.execute("SELECT devStatus FROM DevicesView WHERE devMac = 'bb:bb:bb:bb:bb:05'")
assert cur.fetchone()["devStatus"] == "Sleeping"
def test_devstatus_down_after_window_expires(self):
@@ -202,5 +208,6 @@ class TestIsSleepingSuppression:
)
conn.commit()
cur.execute("SELECT devStatus FROM DevicesView WHERE devMac = 'BB:BB:BB:BB:BB:06'")
# DevicesView returns LOWER(devMac); query must use lowercase
cur.execute("SELECT devStatus FROM DevicesView WHERE devMac = 'bb:bb:bb:bb:bb:06'")
assert cur.fetchone()["devStatus"] == "Down"

View File

@@ -8,6 +8,7 @@ import sys
import os
import time
import pytest
from selenium.webdriver.common.by import By
# Add test directory to path
@@ -73,6 +74,16 @@ def get_login_password():
return None
def require_login_page(driver):
"""Skip the test if the login form is not present (web protection disabled)."""
fields = driver.find_elements(By.NAME, "loginpassword")
if not fields:
pytest.skip(
"Web protection is disabled (SETPWD_enable_password != true); "
"login page is not shown on this instance"
)
def perform_login(driver, password=None):
"""Helper function to perform login with optional password fallback
@@ -83,6 +94,7 @@ def perform_login(driver, password=None):
if password is None:
password = "123456" # Default test password
require_login_page(driver)
password_input = driver.find_element(By.NAME, "loginpassword")
password_input.send_keys(password)
@@ -100,7 +112,9 @@ def test_login_page_loads(driver):
driver.get(f"{BASE_URL}/index.php")
wait_for_page_load(driver)
# Check that login form is present
# Skip if web protection is disabled (page redirected away from login form)
require_login_page(driver)
password_field = driver.find_element(By.NAME, "loginpassword")
assert password_field, "Password field should be present"
@@ -230,6 +244,9 @@ def test_url_hash_hidden_input_present(driver):
driver.get(f"{BASE_URL}/index.php")
wait_for_page_load(driver)
# Skip if web protection is disabled (login form not shown)
require_login_page(driver)
# Verify the hidden input field exists
url_hash_input = driver.find_element(By.ID, "url_hash")
assert url_hash_input, "Hidden url_hash input field should be present"