forked from Rockachopa/Timmy-time-dashboard
* polish: streamline nav, extract inline styles, improve tablet UX - Restructure desktop nav from 8+ flat links + overflow dropdown into 5 grouped dropdowns (Core, Agents, Intel, System, More) matching the mobile menu structure to reduce decision fatigue - Extract all inline styles from mission_control.html and base.html notification elements into mission-control.css with semantic classes - Replace JS-built innerHTML with secure DOM construction in notification loader and chat history - Add CONNECTING state to connection indicator (amber) instead of showing OFFLINE before WebSocket connects - Add tablet breakpoint (1024px) with larger touch targets for Apple Pencil / stylus use and safe-area padding for iPad toolbar - Add active-link highlighting in desktop dropdown menus - Rename "Mission Control" page title to "System Overview" to disambiguate from the chat home page - Add "Home — Timmy Time" page title to index.html https://claude.ai/code/session_015uPUoKyYa8M2UAcyk5Gt6h * fix(security): move auth-gate credentials to environment variables Hardcoded username, password, and HMAC secret in auth-gate.py replaced with os.environ lookups. Startup now refuses to run if any variable is unset. Added AUTH_GATE_SECRET/USER/PASS to .env.example. https://claude.ai/code/session_015uPUoKyYa8M2UAcyk5Gt6h * refactor(tooling): migrate from black+isort+bandit to ruff Replace three separate linting/formatting tools with a single ruff invocation. Updates tox.ini (lint, format, pre-push, pre-commit envs), .pre-commit-config.yaml, and CI workflow. Fixes all ruff errors including unused imports, missing raise-from, and undefined names. Ruff config maps existing bandit skips to equivalent S-rules. https://claude.ai/code/session_015uPUoKyYa8M2UAcyk5Gt6h --------- Co-authored-by: Claude <noreply@anthropic.com>
62 lines
1.7 KiB
Python
62 lines
1.7 KiB
Python
"""Tests for system introspection tools."""
|
|
|
|
|
|
def test_get_system_info_returns_dict():
|
|
"""System info should return a dictionary."""
|
|
from timmy.tools_intro import get_system_info
|
|
|
|
info = get_system_info()
|
|
|
|
assert isinstance(info, dict)
|
|
assert "python_version" in info
|
|
assert "platform" in info
|
|
assert "model" in info
|
|
assert "repo_root" in info
|
|
|
|
|
|
def test_get_system_info_contains_model():
|
|
"""System info should include model name."""
|
|
from config import settings
|
|
from timmy.tools_intro import get_system_info
|
|
|
|
info = get_system_info()
|
|
|
|
assert "model" in info
|
|
# Model should come from settings
|
|
assert info["model"] == settings.ollama_model
|
|
|
|
|
|
def test_get_system_info_contains_repo_root():
|
|
"""System info should include repo_root."""
|
|
from config import settings
|
|
from timmy.tools_intro import get_system_info
|
|
|
|
info = get_system_info()
|
|
|
|
assert "repo_root" in info
|
|
assert info["repo_root"] == settings.repo_root
|
|
# In Docker the CWD is /app, so just verify it's a non-empty path
|
|
assert len(info["repo_root"]) > 0
|
|
|
|
|
|
def test_check_ollama_health_returns_dict():
|
|
"""Ollama health check should return a dictionary."""
|
|
from timmy.tools_intro import check_ollama_health
|
|
|
|
result = check_ollama_health()
|
|
|
|
assert isinstance(result, dict)
|
|
assert "accessible" in result
|
|
assert "model" in result
|
|
|
|
|
|
def test_get_memory_status_returns_dict():
|
|
"""Memory status should return a dictionary with tier info."""
|
|
from timmy.tools_intro import get_memory_status
|
|
|
|
status = get_memory_status()
|
|
|
|
assert isinstance(status, dict)
|
|
assert "tier1_hot_memory" in status
|
|
assert "tier2_vault" in status
|