import sys import pathlib import sqlite3 import random import string import uuid import pytest from datetime import datetime, timedelta INSTALL_PATH = "/app" sys.path.extend([f"{INSTALL_PATH}/front/plugins", f"{INSTALL_PATH}/server"]) from helper import timeNowTZ, get_setting_value from api_server.api_server_start import app @pytest.fixture(scope="session") def api_token(): return get_setting_value("API_TOKEN") @pytest.fixture def client(): with app.test_client() as client: yield client @pytest.fixture def test_mac(): # Generate a unique MAC for each test run return "AA:BB:CC:" + ":".join(f"{random.randint(0,255):02X}" for _ in range(3)) def auth_headers(token): return {"Authorization": f"Bearer {token}"} def test_get_setting_unauthorized(client): resp = client.get("/settings/API_TOKEN") # no auth header assert resp.status_code == 403 assert resp.json.get("error") == "Forbidden" def test_get_setting_valid_key(client, api_token): # We know API_TOKEN exists in settings resp = client.get("/settings/API_TOKEN", headers=auth_headers(api_token)) assert resp.status_code == 200 assert resp.json.get("success") is True # The value should equal the token itself assert resp.json.get("value") == api_token def test_get_setting_invalid_key(client, api_token): resp = client.get("/settings/DOES_NOT_EXIST", headers=auth_headers(api_token)) assert resp.status_code == 200 assert resp.json.get("success") is True # Depending on implementation, might be None or "" assert resp.json.get("value") in (None, "")