Compare commits

..

1 Commits

Author SHA1 Message Date
Alexander Whitestone
8758f4e9d8 docs: add phase-4 sovereignty audit (#551)
Some checks failed
Smoke Test / smoke (pull_request) Failing after 16s
2026-04-15 00:48:26 -04:00
5 changed files with 254 additions and 1029 deletions

View File

@@ -0,0 +1,206 @@
# Phase 4 Sovereignty Audit
Generated: 2026-04-15 00:45:01 EDT
Issue: #551
Scope: repo-grounded audit of whether `timmy-home` currently proves **[PHASE-4] Sovereignty - Zero Cloud Dependencies**
## Phase Definition
Issue #551 defines Phase 4 as:
- no API call leaves your infrastructure
- no rate limits
- no censorship
- no shutdown dependency
- trigger condition: all Phase-3 buildings operational and all models running locally
The milestone sentence is explicit:
> “A model ran locally for the first time. No cloud. No rate limits. No one can turn it off.”
This audit asks a narrower, truthful question:
**Does the current `timmy-home` repo prove that the Timmy harness is already in Phase 4?**
## Current Repo Evidence
### 1. The repo already contains a local-only cutover diagnosis — and it says the harness is not there yet
Primary source:
- `specs/2026-03-29-local-only-harness-cutover-plan.md`
That plan records a live-state audit from 2026-03-29 and names concrete blockers:
- active cloud default in `~/.hermes/config.yaml`
- cloud fallback entries
- enabled cron inheritance risk
- legacy remote ops scripts still on the active path
- optional Groq offload still present in the Nexus path
Direct repo-grounded examples from that file:
- `model.default: gpt-5.4`
- `model.provider: openai-codex`
- `model.base_url: https://chatgpt.com/backend-api/codex`
- custom provider: Google Gemini
- fallback path still pointing to Gemini
- active cloud escape path via `groq_worker.py`
The same cutover plan defines “done” in stricter terms than the issue body and plainly says those conditions were not yet met.
### 2. The baseline report says sovereignty is still overwhelmingly cloud-backed
Primary source:
- `reports/production/2026-03-29-local-timmy-baseline.md`
That report gives the clearest quantitative evidence in this repo:
- sovereignty score: `0.7%` local
- sessions: `403 total | 3 local | 400 cloud`
- estimated cloud cost: `$125.83`
That is incompatible with any honest claim that Phase 4 has already been reached.
The same baseline also says:
- local mind: alive
- local session partner: usable
- local Hermes agent: not ready
So the repo's own truthful baseline says local capability exists, but zero-cloud operational sovereignty does not.
### 3. The model tracker is built to measure local-vs-cloud reality because the transition is not finished
Primary source:
- `metrics/model_tracker.py`
This file tracks:
- `local_sessions`
- `cloud_sessions`
- `local_pct`
- `est_cloud_cost`
- `est_saved`
That means the repo is architected to monitor a sovereignty transition, not to assume it is already complete.
### 4. There is already a proof harness — and its existence implies proof is still needed
Primary source:
- `scripts/local_timmy_proof_test.py`
This script explicitly searches for cloud/remote markers including:
- `chatgpt.com/backend-api/codex`
- `generativelanguage.googleapis.com`
- `api.groq.com`
- `143.198.27.163`
It also frames the output question as:
- is the active harness already local-only?
- why or why not?
A repo does not add a proof script like this if the zero-cloud cutover is already a settled fact.
### 5. The local subtree is stronger than the harness, but it is still only the target architecture
Primary sources:
- `LOCAL_Timmy_REPORT.md`
- `timmy-local/README.md`
`LOCAL_Timmy_REPORT.md` documents real local-first building blocks:
- local caching
- local Evennia world shell
- local ingestion pipeline
- prompt warming
Those are important Phase-4-aligned components.
But the broader repo still includes evidence of non-sovereign dependencies or remote references, such as:
- `scripts/evennia/bootstrap_local_evennia.py` defaulting operator email to `alexpaynex@gmail.com`
- `timmy-local/evennia/commands/tools.py` hardcoding `http://143.198.27.163:3000/...`
- `uni-wizard/tools/network_tools.py` hardcoding `GITEA_URL = "http://143.198.27.163:3000"`
- `uni-wizard/v2/task_router_daemon.py` defaulting `--gitea-url` to that same remote endpoint
These are not necessarily cloud inference dependencies, but they are still external dependency anchors inconsistent with the spirit of “No cloud. No rate limits. No one can turn it off.”
## Contradictions and Drift
### Contradiction A — local architecture exists, but repo evidence says cutover is incomplete
- `LOCAL_Timmy_REPORT.md` celebrates local infrastructure delivery.
- `reports/production/2026-03-29-local-timmy-baseline.md` still records `400 cloud` sessions and `0.7%` local.
These are not actually contradictory if read honestly:
- the local stack was delivered
- the fleet had not yet switched over to it
### Contradiction B — the local README was overstating current reality
Before this PR, `timmy-local/README.md` said the stack:
- “Runs entirely on your hardware with no cloud dependencies for core functionality.”
That sentence was too strong given the rest of the repo evidence:
- cloud defaults were still documented in the cutover plan
- cloud session volume was still quantified in the baseline report
- remote service references still existed across multiple scripts
This PR fixes that wording so the README describes `timmy-local` as the destination shape, not proof that the whole harness is already sovereign.
### Contradiction C — Phase 4 wants zero cloud dependencies, but the repo still documents explicit cloud-era markers
The repo itself still names or scans for:
- `openai-codex`
- `chatgpt.com/backend-api/codex`
- `generativelanguage.googleapis.com`
- `api.groq.com`
- `GROQ_API_KEY`
That does not mean the system can never become sovereign. It does mean the repo currently documents an unfinished migration boundary.
## Verdict
**Phase 4 is not yet reached.**
Why:
1. the repo's own baseline report still shows `403 total | 3 local | 400 cloud`
2. the repo's cutover plan still lists active cloud defaults and fallback paths as unresolved work
3. proof/guard scripts exist specifically to detect unresolved cloud and remote dependency markers
4. multiple runtime/ops files still point at external services such as `143.198.27.163`, `alexpaynex@gmail.com`, and Groq/OpenAI/Gemini-era paths
The truthful repo-grounded statement is:
- **local-first infrastructure exists**
- **zero-cloud sovereignty is the target**
- **the migration was not yet complete at the time this repo evidence was written**
## Highest-Leverage Next Actions
1. **Eliminate cloud defaults and hidden fallbacks first**
- follow `specs/2026-03-29-local-only-harness-cutover-plan.md`
- remove `openai-codex`, Gemini fallback, and any active cloud default path
2. **Kill cron inheritance bugs**
- no enabled cron should run with null model/provider if cloud defaults still exist anywhere
3. **Quarantine remote-ops scripts and hardcoded remote endpoints**
- `143.198.27.163` still appears in active repo scripts and command surfaces
- move legacy remote ops into quarantine or replace with local truth surfaces
4. **Run and preserve proof artifacts, not just intentions**
- the repo already has `scripts/local_timmy_proof_test.py`
- use it as the phase-gate proof generator
5. **Use the sovereignty scoreboard as a real gate**
- Phase 4 should not be declared complete while reports still show materially nonzero cloud sessions as the operating norm
## Definition of Done
Issue #551 should only be considered truly complete when the repo can point to evidence that all of the following are true:
1. no active model default points to a remote inference API
2. no fallback path silently escapes to cloud inference
3. no enabled cron can inherit a remote model/provider
4. active runtime paths no longer depend on Groq/OpenAI/Gemini-era inference markers
5. operator-critical services do not depend on external platforms like Gmail
6. remote hardcoded ops endpoints such as `143.198.27.163` are removed from the active Timmy path or clearly quarantined
7. the local proof script passes end-to-end
8. the sovereignty scoreboard shows cloud usage reduced to the point that “Zero Cloud Dependencies” is a truthful operational statement, not just an architectural aspiration
## Recommendation for This PR
This PR should **advance** Phase 4 by making the repo's public local-first docs honest and by recording a clear audit of why the milestone remains open.
That means the right PR reference style is:
- `Refs #551`
not:
- `Closes #551`
because the evidence in this repo shows the milestone is still in progress.
*Sovereignty and service always.*

View File

@@ -1,290 +0,0 @@
#!/usr/bin/env python3
"""Codebase Test Generator — Fill Coverage Gaps (#667)."""
import ast
import os
import sys
import argparse
from dataclasses import dataclass, field
from pathlib import Path
from typing import Dict, List, Optional, Set, Tuple
@dataclass
class FunctionInfo:
name: str
module_path: str
class_name: Optional[str] = None
lineno: int = 0
args: List[str] = field(default_factory=list)
is_async: bool = False
is_private: bool = False
is_property: bool = False
docstring: Optional[str] = None
has_return: bool = False
raises: List[str] = field(default_factory=list)
decorators: List[str] = field(default_factory=list)
@property
def qualified_name(self):
if self.class_name:
return f"{self.class_name}.{self.name}"
return self.name
@property
def test_name(self):
safe_mod = self.module_path.replace("/", "_").replace(".py", "").replace("-", "_")
safe_cls = self.class_name + "_" if self.class_name else ""
return f"test_{safe_mod}_{safe_cls}{self.name}"
@dataclass
class CoverageGap:
func: FunctionInfo
reason: str
test_priority: int
class SourceAnalyzer(ast.NodeVisitor):
def __init__(self, module_path: str):
self.module_path = module_path
self.functions: List[FunctionInfo] = []
self._class_stack: List[str] = []
def visit_ClassDef(self, node):
self._class_stack.append(node.name)
self.generic_visit(node)
self._class_stack.pop()
def visit_FunctionDef(self, node):
self._collect(node, False)
self.generic_visit(node)
def visit_AsyncFunctionDef(self, node):
self._collect(node, True)
self.generic_visit(node)
def _collect(self, node, is_async):
cls = self._class_stack[-1] if self._class_stack else None
args = [a.arg for a in node.args.args if a.arg not in ("self", "cls")]
has_ret = any(isinstance(c, ast.Return) and c.value for c in ast.walk(node))
raises = []
for c in ast.walk(node):
if isinstance(c, ast.Raise) and c.exc:
if isinstance(c.exc, ast.Call) and isinstance(c.exc.func, ast.Name):
raises.append(c.exc.func.id)
decos = []
for d in node.decorator_list:
if isinstance(d, ast.Name): decos.append(d.id)
elif isinstance(d, ast.Attribute): decos.append(d.attr)
self.functions.append(FunctionInfo(
name=node.name, module_path=self.module_path, class_name=cls,
lineno=node.lineno, args=args, is_async=is_async,
is_private=node.name.startswith("_") and not node.name.startswith("__"),
is_property="property" in decos,
docstring=ast.get_docstring(node), has_return=has_ret,
raises=raises, decorators=decos))
def analyze_file(filepath, base_dir):
module_path = os.path.relpath(filepath, base_dir)
try:
with open(filepath, "r", errors="replace") as f:
tree = ast.parse(f.read(), filename=filepath)
except (SyntaxError, UnicodeDecodeError):
return []
a = SourceAnalyzer(module_path)
a.visit(tree)
return a.functions
def find_source_files(source_dir):
exclude = {"__pycache__", ".git", "venv", ".venv", "node_modules", ".tox", "build", "dist"}
files = []
for root, dirs, fs in os.walk(source_dir):
dirs[:] = [d for d in dirs if d not in exclude and not d.startswith(".")]
for f in fs:
if f.endswith(".py") and f != "__init__.py" and not f.startswith("test_"):
files.append(os.path.join(root, f))
return sorted(files)
def find_existing_tests(test_dir):
existing = set()
for root, dirs, fs in os.walk(test_dir):
for f in fs:
if f.startswith("test_") and f.endswith(".py"):
try:
with open(os.path.join(root, f)) as fh:
tree = ast.parse(fh.read())
for node in ast.walk(tree):
if isinstance(node, ast.FunctionDef) and node.name.startswith("test_"):
existing.add(node.name)
except (SyntaxError, UnicodeDecodeError):
pass
return existing
def identify_gaps(functions, existing_tests):
gaps = []
for func in functions:
if func.name.startswith("__") and func.name != "__init__":
continue
covered = func.name in str(existing_tests)
if not covered:
pri = 3 if func.is_private else (1 if (func.raises or func.has_return) else 2)
gaps.append(CoverageGap(func=func, reason="no test found", test_priority=pri))
gaps.sort(key=lambda g: (g.test_priority, g.func.module_path, g.func.name))
return gaps
def generate_test(gap):
func = gap.func
lines = []
lines.append(f" # AUTO-GENERATED -- review before merging")
lines.append(f" # Source: {func.module_path}:{func.lineno}")
lines.append(f" # Function: {func.qualified_name}")
lines.append("")
mod_imp = func.module_path.replace("/", ".").replace("-", "_").replace(".py", "")
call_args = []
for a in func.args:
if a in ("self", "cls"): continue
if "path" in a or "file" in a or "dir" in a: call_args.append(f"{a}='/tmp/test'")
elif "name" in a: call_args.append(f"{a}='test'")
elif "id" in a or "key" in a: call_args.append(f"{a}='test_id'")
elif "message" in a or "text" in a: call_args.append(f"{a}='test msg'")
elif "count" in a or "num" in a or "size" in a: call_args.append(f"{a}=1")
elif "flag" in a or "enabled" in a or "verbose" in a: call_args.append(f"{a}=False")
else: call_args.append(f"{a}=None")
args_str = ", ".join(call_args)
if func.is_async:
lines.append(" @pytest.mark.asyncio")
lines.append(f" def {func.test_name}(self):")
lines.append(f' """Test {func.qualified_name} -- auto-generated."""')
if func.class_name:
lines.append(f" try:")
lines.append(f" from {mod_imp} import {func.class_name}")
if func.is_private:
lines.append(f" pytest.skip('Private method')")
elif func.is_property:
lines.append(f" obj = {func.class_name}()")
lines.append(f" _ = obj.{func.name}")
else:
if func.raises:
lines.append(f" with pytest.raises(({', '.join(func.raises)})):")
lines.append(f" {func.class_name}().{func.name}({args_str})")
else:
lines.append(f" obj = {func.class_name}()")
lines.append(f" result = obj.{func.name}({args_str})")
if func.has_return:
lines.append(f" assert result is not None or result is None # Placeholder")
lines.append(f" except ImportError:")
lines.append(f" pytest.skip('Module not importable')")
else:
lines.append(f" try:")
lines.append(f" from {mod_imp} import {func.name}")
if func.is_private:
lines.append(f" pytest.skip('Private function')")
else:
if func.raises:
lines.append(f" with pytest.raises(({', '.join(func.raises)})):")
lines.append(f" {func.name}({args_str})")
else:
lines.append(f" result = {func.name}({args_str})")
if func.has_return:
lines.append(f" assert result is not None or result is None # Placeholder")
lines.append(f" except ImportError:")
lines.append(f" pytest.skip('Module not importable')")
return chr(10).join(lines)
def generate_test_suite(gaps, max_tests=50):
by_module = {}
for gap in gaps[:max_tests]:
by_module.setdefault(gap.func.module_path, []).append(gap)
lines = []
lines.append('"""Auto-generated test suite -- Codebase Genome (#667).')
lines.append("")
lines.append("Generated by scripts/codebase_test_generator.py")
lines.append("Coverage gaps identified from AST analysis.")
lines.append("")
lines.append("These tests are starting points. Review before merging.")
lines.append('"""')
lines.append("")
lines.append("import pytest")
lines.append("from unittest.mock import MagicMock, patch")
lines.append("")
lines.append("")
lines.append("# AUTO-GENERATED -- DO NOT EDIT WITHOUT REVIEW")
for module, mgaps in sorted(by_module.items()):
safe = module.replace("/", "_").replace(".py", "").replace("-", "_")
cls_name = "".join(w.title() for w in safe.split("_"))
lines.append("")
lines.append(f"class Test{cls_name}Generated:")
lines.append(f' """Auto-generated tests for {module}."""')
for gap in mgaps:
lines.append("")
lines.append(generate_test(gap))
lines.append("")
return chr(10).join(lines)
def main():
parser = argparse.ArgumentParser(description="Codebase Test Generator")
parser.add_argument("--source", default=".")
parser.add_argument("--output", default="tests/test_genome_generated.py")
parser.add_argument("--max-tests", type=int, default=50)
parser.add_argument("--dry-run", action="store_true")
parser.add_argument("--include-private", action="store_true")
args = parser.parse_args()
source_dir = os.path.abspath(args.source)
test_dir = os.path.join(source_dir, "tests")
print(f"Scanning: {source_dir}")
source_files = find_source_files(source_dir)
print(f"Source files: {len(source_files)}")
all_funcs = []
for f in source_files:
all_funcs.extend(analyze_file(f, source_dir))
print(f"Functions/methods: {len(all_funcs)}")
existing = find_existing_tests(test_dir)
print(f"Existing tests: {len(existing)}")
gaps = identify_gaps(all_funcs, existing)
if not args.include_private:
gaps = [g for g in gaps if not g.func.is_private]
print(f"Coverage gaps: {len(gaps)}")
by_pri = {1: 0, 2: 0, 3: 0}
for g in gaps:
by_pri[g.test_priority] += 1
print(f" High: {by_pri[1]}, Medium: {by_pri[2]}, Low: {by_pri[3]}")
if args.dry_run:
for g in gaps[:10]:
print(f" {g.func.module_path}:{g.func.lineno} {g.func.qualified_name}")
return
if gaps:
content = generate_test_suite(gaps, max_tests=args.max-tests if hasattr(args, 'max-tests') else args.max_tests)
out = os.path.join(source_dir, args.output)
os.makedirs(os.path.dirname(out), exist_ok=True)
with open(out, "w") as f:
f.write(content)
print(f"Generated {min(len(gaps), args.max_tests)} tests -> {args.output}")
else:
print("No gaps found!")
if __name__ == "__main__":
main()

View File

@@ -0,0 +1,46 @@
from pathlib import Path
REPORT = Path("reports/evaluations/2026-04-15-phase-4-sovereignty-audit.md")
README = Path("timmy-local/README.md")
def _report() -> str:
return REPORT.read_text()
def _readme() -> str:
return README.read_text()
def test_phase4_audit_report_exists() -> None:
assert REPORT.exists()
def test_phase4_audit_report_has_required_sections() -> None:
content = _report()
assert "# Phase 4 Sovereignty Audit" in content
assert "## Phase Definition" in content
assert "## Current Repo Evidence" in content
assert "## Contradictions and Drift" in content
assert "## Verdict" in content
assert "## Highest-Leverage Next Actions" in content
assert "## Definition of Done" in content
def test_phase4_audit_captures_key_repo_findings() -> None:
content = _report()
assert "#551" in content
assert "0.7%" in content
assert "400 cloud" in content
assert "openai-codex" in content
assert "GROQ_API_KEY" in content
assert "143.198.27.163" in content
assert "not yet reached" in content.lower()
def test_timmy_local_readme_is_honest_about_phase4_status() -> None:
content = _readme()
assert "Phase 4" in content
assert "zero-cloud sovereignty is not yet complete" in content
assert "no cloud dependencies for core functionality" not in content

View File

@@ -1,737 +0,0 @@
"""Auto-generated test suite -- Codebase Genome (#667).
Generated by scripts/codebase_test_generator.py
Coverage gaps identified from AST analysis.
These tests are starting points. Review before merging.
"""
import pytest
from unittest.mock import MagicMock, patch
# AUTO-GENERATED -- DO NOT EDIT WITHOUT REVIEW
class TestAngbandMcpServerGenerated:
"""Auto-generated tests for angband/mcp_server.py."""
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:319
# Function: call_tool
@pytest.mark.asyncio
def test_angband_mcp_server_call_tool(self):
"""Test call_tool -- auto-generated."""
try:
from angband.mcp_server import call_tool
result = call_tool(name='test', arguments=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:64
# Function: capture_screen
def test_angband_mcp_server_capture_screen(self):
"""Test capture_screen -- auto-generated."""
try:
from angband.mcp_server import capture_screen
result = capture_screen(lines=None, session_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:74
# Function: has_save
def test_angband_mcp_server_has_save(self):
"""Test has_save -- auto-generated."""
try:
from angband.mcp_server import has_save
result = has_save(user=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:234
# Function: keypress
def test_angband_mcp_server_keypress(self):
"""Test keypress -- auto-generated."""
try:
from angband.mcp_server import keypress
result = keypress(key='test_id', wait_ms=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:141
# Function: launch_game
def test_angband_mcp_server_launch_game(self):
"""Test launch_game -- auto-generated."""
try:
from angband.mcp_server import launch_game
result = launch_game(user=None, new_game=None, continue_splash=None, width='test_id', height=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:253
# Function: list_tools
@pytest.mark.asyncio
def test_angband_mcp_server_list_tools(self):
"""Test list_tools -- auto-generated."""
try:
from angband.mcp_server import list_tools
result = list_tools()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:130
# Function: maybe_continue_splash
def test_angband_mcp_server_maybe_continue_splash(self):
"""Test maybe_continue_splash -- auto-generated."""
try:
from angband.mcp_server import maybe_continue_splash
result = maybe_continue_splash(session_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:226
# Function: observe
def test_angband_mcp_server_observe(self):
"""Test observe -- auto-generated."""
try:
from angband.mcp_server import observe
result = observe(lines=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:57
# Function: pane_id
def test_angband_mcp_server_pane_id(self):
"""Test pane_id -- auto-generated."""
try:
from angband.mcp_server import pane_id
result = pane_id(session_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:108
# Function: send_key
def test_angband_mcp_server_send_key(self):
"""Test send_key -- auto-generated."""
try:
from angband.mcp_server import send_key
with pytest.raises((RuntimeError)):
send_key(key='test_id', session_name='test')
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:123
# Function: send_text
def test_angband_mcp_server_send_text(self):
"""Test send_text -- auto-generated."""
try:
from angband.mcp_server import send_text
with pytest.raises((RuntimeError)):
send_text(text='test msg', session_name='test')
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:53
# Function: session_exists
def test_angband_mcp_server_session_exists(self):
"""Test session_exists -- auto-generated."""
try:
from angband.mcp_server import session_exists
result = session_exists(session_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:203
# Function: stop_game
def test_angband_mcp_server_stop_game(self):
"""Test stop_game -- auto-generated."""
try:
from angband.mcp_server import stop_game
result = stop_game()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:46
# Function: tmux
def test_angband_mcp_server_tmux(self):
"""Test tmux -- auto-generated."""
try:
from angband.mcp_server import tmux
with pytest.raises((RuntimeError)):
tmux(args=None, check=None)
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: angband/mcp_server.py:243
# Function: type_and_observe
def test_angband_mcp_server_type_and_observe(self):
"""Test type_and_observe -- auto-generated."""
try:
from angband.mcp_server import type_and_observe
result = type_and_observe(text='test msg', wait_ms=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaTimmyWorldGameGenerated:
"""Auto-generated tests for evennia/timmy_world/game.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:495
# Function: ActionSystem.get_available_actions
def test_evennia_timmy_world_game_ActionSystem_get_available_actions(self):
"""Test ActionSystem.get_available_actions -- auto-generated."""
try:
from evennia.timmy_world.game import ActionSystem
obj = ActionSystem()
result = obj.get_available_actions(char_name='test', world=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:1485
# Function: PlayerInterface.get_available_actions
def test_evennia_timmy_world_game_PlayerInterface_get_available_actions(self):
"""Test PlayerInterface.get_available_actions -- auto-generated."""
try:
from evennia.timmy_world.game import PlayerInterface
obj = PlayerInterface()
result = obj.get_available_actions()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:55
# Function: get_narrative_phase
def test_evennia_timmy_world_game_get_narrative_phase(self):
"""Test get_narrative_phase -- auto-generated."""
try:
from evennia.timmy_world.game import get_narrative_phase
result = get_narrative_phase(tick=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:65
# Function: get_phase_transition_event
def test_evennia_timmy_world_game_get_phase_transition_event(self):
"""Test get_phase_transition_event -- auto-generated."""
try:
from evennia.timmy_world.game import get_phase_transition_event
result = get_phase_transition_event(old_phase=None, new_phase=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:347
# Function: World.get_room_desc
def test_evennia_timmy_world_game_World_get_room_desc(self):
"""Test World.get_room_desc -- auto-generated."""
try:
from evennia.timmy_world.game import World
obj = World()
result = obj.get_room_desc(room_name='test', char_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:1045
# Function: GameEngine.load_game
def test_evennia_timmy_world_game_GameEngine_load_game(self):
"""Test GameEngine.load_game -- auto-generated."""
try:
from evennia.timmy_world.game import GameEngine
obj = GameEngine()
result = obj.load_game()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:556
# Function: NPCAI.make_choice
def test_evennia_timmy_world_game_NPCAI_make_choice(self):
"""Test NPCAI.make_choice -- auto-generated."""
try:
from evennia.timmy_world.game import NPCAI
obj = NPCAI()
result = obj.make_choice(char_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:1454
# Function: GameEngine.play_turn
def test_evennia_timmy_world_game_GameEngine_play_turn(self):
"""Test GameEngine.play_turn -- auto-generated."""
try:
from evennia.timmy_world.game import GameEngine
obj = GameEngine()
result = obj.play_turn(action=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/game.py:1076
# Function: GameEngine.run_tick
def test_evennia_timmy_world_game_GameEngine_run_tick(self):
"""Test GameEngine.run_tick -- auto-generated."""
try:
from evennia.timmy_world.game import GameEngine
obj = GameEngine()
result = obj.run_tick(timmy_action=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaTimmyWorldServerConfWebPluginsGenerated:
"""Auto-generated tests for evennia/timmy_world/server/conf/web_plugins.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/server/conf/web_plugins.py:31
# Function: at_webproxy_root_creation
def test_evennia_timmy_world_server_conf_web_plugins_at_webproxy_root_creation(self):
"""Test at_webproxy_root_creation -- auto-generated."""
try:
from evennia.timmy_world.server.conf.web_plugins import at_webproxy_root_creation
result = at_webproxy_root_creation(web_root=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/server/conf/web_plugins.py:6
# Function: at_webserver_root_creation
def test_evennia_timmy_world_server_conf_web_plugins_at_webserver_root_creation(self):
"""Test at_webserver_root_creation -- auto-generated."""
try:
from evennia.timmy_world.server.conf.web_plugins import at_webserver_root_creation
result = at_webserver_root_creation(web_root=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaTimmyWorldWorldGameGenerated:
"""Auto-generated tests for evennia/timmy_world/world/game.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:400
# Function: ActionSystem.get_available_actions
def test_evennia_timmy_world_world_game_ActionSystem_get_available_actions(self):
"""Test ActionSystem.get_available_actions -- auto-generated."""
try:
from evennia.timmy_world.world.game import ActionSystem
obj = ActionSystem()
result = obj.get_available_actions(char_name='test', world=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:1289
# Function: PlayerInterface.get_available_actions
def test_evennia_timmy_world_world_game_PlayerInterface_get_available_actions(self):
"""Test PlayerInterface.get_available_actions -- auto-generated."""
try:
from evennia.timmy_world.world.game import PlayerInterface
obj = PlayerInterface()
result = obj.get_available_actions()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:254
# Function: World.get_room_desc
def test_evennia_timmy_world_world_game_World_get_room_desc(self):
"""Test World.get_room_desc -- auto-generated."""
try:
from evennia.timmy_world.world.game import World
obj = World()
result = obj.get_room_desc(room_name='test', char_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:880
# Function: GameEngine.load_game
def test_evennia_timmy_world_world_game_GameEngine_load_game(self):
"""Test GameEngine.load_game -- auto-generated."""
try:
from evennia.timmy_world.world.game import GameEngine
obj = GameEngine()
result = obj.load_game()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:461
# Function: NPCAI.make_choice
def test_evennia_timmy_world_world_game_NPCAI_make_choice(self):
"""Test NPCAI.make_choice -- auto-generated."""
try:
from evennia.timmy_world.world.game import NPCAI
obj = NPCAI()
result = obj.make_choice(char_name='test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:1258
# Function: GameEngine.play_turn
def test_evennia_timmy_world_world_game_GameEngine_play_turn(self):
"""Test GameEngine.play_turn -- auto-generated."""
try:
from evennia.timmy_world.world.game import GameEngine
obj = GameEngine()
result = obj.play_turn(action=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:911
# Function: GameEngine.run_tick
def test_evennia_timmy_world_world_game_GameEngine_run_tick(self):
"""Test GameEngine.run_tick -- auto-generated."""
try:
from evennia.timmy_world.world.game import GameEngine
obj = GameEngine()
result = obj.run_tick(timmy_action=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia/timmy_world/world/game.py:749
# Function: DialogueSystem.select
def test_evennia_timmy_world_world_game_DialogueSystem_select(self):
"""Test DialogueSystem.select -- auto-generated."""
try:
from evennia.timmy_world.world.game import DialogueSystem
obj = DialogueSystem()
result = obj.select(char_name='test', listener=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaToolsLayoutGenerated:
"""Auto-generated tests for evennia_tools/layout.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia_tools/layout.py:58
# Function: grouped_exits
def test_evennia_tools_layout_grouped_exits(self):
"""Test grouped_exits -- auto-generated."""
try:
from evennia_tools.layout import grouped_exits
result = grouped_exits()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia_tools/layout.py:54
# Function: room_keys
def test_evennia_tools_layout_room_keys(self):
"""Test room_keys -- auto-generated."""
try:
from evennia_tools.layout import room_keys
result = room_keys()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaToolsTelemetryGenerated:
"""Auto-generated tests for evennia_tools/telemetry.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia_tools/telemetry.py:8
# Function: telemetry_dir
def test_evennia_tools_telemetry_telemetry_dir(self):
"""Test telemetry_dir -- auto-generated."""
try:
from evennia_tools.telemetry import telemetry_dir
result = telemetry_dir(base_dir='/tmp/test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvenniaToolsTrainingGenerated:
"""Auto-generated tests for evennia_tools/training.py."""
# AUTO-GENERATED -- review before merging
# Source: evennia_tools/training.py:18
# Function: example_eval_path
def test_evennia_tools_training_example_eval_path(self):
"""Test example_eval_path -- auto-generated."""
try:
from evennia_tools.training import example_eval_path
result = example_eval_path(repo_root=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: evennia_tools/training.py:14
# Function: example_trace_path
def test_evennia_tools_training_example_trace_path(self):
"""Test example_trace_path -- auto-generated."""
try:
from evennia_tools.training import example_trace_path
result = example_trace_path(repo_root=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvolutionBitcoinScripterGenerated:
"""Auto-generated tests for evolution/bitcoin_scripter.py."""
# AUTO-GENERATED -- review before merging
# Source: evolution/bitcoin_scripter.py:18
# Function: BitcoinScripter.generate_script
def test_evolution_bitcoin_scripter_BitcoinScripter_generate_script(self):
"""Test BitcoinScripter.generate_script -- auto-generated."""
try:
from evolution.bitcoin_scripter import BitcoinScripter
obj = BitcoinScripter()
result = obj.generate_script(requirements=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvolutionLightningClientGenerated:
"""Auto-generated tests for evolution/lightning_client.py."""
# AUTO-GENERATED -- review before merging
# Source: evolution/lightning_client.py:18
# Function: LightningClient.plan_payment_route
def test_evolution_lightning_client_LightningClient_plan_payment_route(self):
"""Test LightningClient.plan_payment_route -- auto-generated."""
try:
from evolution.lightning_client import LightningClient
obj = LightningClient()
result = obj.plan_payment_route(destination=None, amount_sats=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestEvolutionSovereignAccountantGenerated:
"""Auto-generated tests for evolution/sovereign_accountant.py."""
# AUTO-GENERATED -- review before merging
# Source: evolution/sovereign_accountant.py:17
# Function: SovereignAccountant.generate_financial_report
def test_evolution_sovereign_accountant_SovereignAccountant_generate_financial_report(self):
"""Test SovereignAccountant.generate_financial_report -- auto-generated."""
try:
from evolution.sovereign_accountant import SovereignAccountant
obj = SovereignAccountant()
result = obj.generate_financial_report(transaction_history=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestInfrastructureTimmyBridgeClientTimmyClientGenerated:
"""Auto-generated tests for infrastructure/timmy-bridge/client/timmy_client.py."""
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/client/timmy_client.py:108
# Function: TimmyClient.create_artifact
def test_infrastructure_timmy_bridge_client_timmy_client_TimmyClient_create_artifact(self):
"""Test TimmyClient.create_artifact -- auto-generated."""
try:
from infrastructure.timmy_bridge.client.timmy_client import TimmyClient
obj = TimmyClient()
result = obj.create_artifact()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/client/timmy_client.py:167
# Function: TimmyClient.create_event
def test_infrastructure_timmy_bridge_client_timmy_client_TimmyClient_create_event(self):
"""Test TimmyClient.create_event -- auto-generated."""
try:
from infrastructure.timmy_bridge.client.timmy_client import TimmyClient
obj = TimmyClient()
result = obj.create_event(kind=None, content=None, tags=None)
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/client/timmy_client.py:74
# Function: TimmyClient.generate_observation
def test_infrastructure_timmy_bridge_client_timmy_client_TimmyClient_generate_observation(self):
"""Test TimmyClient.generate_observation -- auto-generated."""
try:
from infrastructure.timmy_bridge.client.timmy_client import TimmyClient
obj = TimmyClient()
result = obj.generate_observation()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
class TestInfrastructureTimmyBridgeMlxMlxIntegrationGenerated:
"""Auto-generated tests for infrastructure/timmy-bridge/mlx/mlx_integration.py."""
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/mlx/mlx_integration.py:122
# Function: MLXInference.available
def test_infrastructure_timmy_bridge_mlx_mlx_integration_MLXInference_available(self):
"""Test MLXInference.available -- auto-generated."""
try:
from infrastructure.timmy_bridge.mlx.mlx_integration import MLXInference
obj = MLXInference()
_ = obj.available
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/mlx/mlx_integration.py:125
# Function: MLXInference.get_stats
def test_infrastructure_timmy_bridge_mlx_mlx_integration_MLXInference_get_stats(self):
"""Test MLXInference.get_stats -- auto-generated."""
try:
from infrastructure.timmy_bridge.mlx.mlx_integration import MLXInference
obj = MLXInference()
result = obj.get_stats()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/mlx/mlx_integration.py:30
# Function: MLXInference.load_model
def test_infrastructure_timmy_bridge_mlx_mlx_integration_MLXInference_load_model(self):
"""Test MLXInference.load_model -- auto-generated."""
try:
from infrastructure.timmy_bridge.mlx.mlx_integration import MLXInference
obj = MLXInference()
result = obj.load_model(model_path='/tmp/test')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/mlx/mlx_integration.py:93
# Function: MLXInference.reflect
def test_infrastructure_timmy_bridge_mlx_mlx_integration_MLXInference_reflect(self):
"""Test MLXInference.reflect -- auto-generated."""
try:
from infrastructure.timmy_bridge.mlx.mlx_integration import MLXInference
obj = MLXInference()
result = obj.reflect()
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')
# AUTO-GENERATED -- review before merging
# Source: infrastructure/timmy-bridge/mlx/mlx_integration.py:108
# Function: MLXInference.respond_to
def test_infrastructure_timmy_bridge_mlx_mlx_integration_MLXInference_respond_to(self):
"""Test MLXInference.respond_to -- auto-generated."""
try:
from infrastructure.timmy_bridge.mlx.mlx_integration import MLXInference
obj = MLXInference()
result = obj.respond_to(message='test msg', context='test msg')
assert result is not None or result is None # Placeholder
except ImportError:
pytest.skip('Module not importable')

View File

@@ -1,6 +1,6 @@
# Timmy Local — Sovereign AI Infrastructure
Local infrastructure for Timmy's sovereign AI operation. Runs entirely on your hardware with no cloud dependencies for core functionality.
Local infrastructure for Timmy's sovereign AI operation. This subtree is the local-first target architecture, but **Phase 4 zero-cloud sovereignty is not yet complete** across the wider Timmy harness.
## Quick Start
@@ -176,7 +176,7 @@ gitea:
└────────┘ └────────┘ └────────┘
```
Local Timmy operates sovereignly. Cloud backends provide additional capacity but Timmy survives without them.
Local Timmy is the sovereign target architecture for the fleet. The wider harness still contains cloud-era defaults, remote service references, and cutover work tracked under Phase 4, so this repo should be read as the destination shape rather than proof that zero-cloud sovereignty is already complete.
## Performance Targets