Files
FESADev/scripts/test_reference_model_agent_config.py
T
2026-06-12 01:15:14 +09:00

91 lines
3.2 KiB
Python

import unittest
from pathlib import Path
try:
import tomllib
except ModuleNotFoundError: # pragma: no cover
import tomli as tomllib
ROOT = Path(__file__).resolve().parents[1]
AGENT_PATH = ROOT / ".codex" / "agents" / "reference-model-agent.toml"
REFERENCE_MODELS_README = ROOT / "docs" / "reference-models" / "README.md"
class ReferenceModelAgentConfigTests(unittest.TestCase):
def test_reference_model_agent_toml_has_required_codex_fields(self):
data = tomllib.loads(AGENT_PATH.read_text(encoding="utf-8"))
self.assertEqual(data["name"], "reference-model-agent")
self.assertIn("reference model packages", data["description"])
self.assertEqual(data["sandbox_mode"], "read-only")
self.assertEqual(data["model_reasoning_effort"], "extra high")
self.assertIn("developer_instructions", data)
def test_reference_model_agent_instructions_enforce_boundaries(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Do not implement code.",
"Do not implement parsers.",
"Do not design C++ APIs",
"Do not run Abaqus, Nastran, or any reference solver.",
"Do not generate or modify Abaqus reference CSV files.",
"Do not compare solver results.",
"Do not approve release readiness.",
):
self.assertIn(required_text, instructions)
def test_reference_model_agent_instructions_define_reference_contract(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"FESA reference models use Abaqus input files.",
"reference/<model-id>/",
"model.inp",
"metadata.json",
"<model-id>_displacements.csv",
"<model-id>_reactions.csv",
"<model-id>_internalforces.csv",
"<model-id>_stresses.csv",
):
self.assertIn(required_text, instructions)
self.assertNotIn("reference" ".h5", instructions)
self.assertNotIn("references/" "<feature-id>/<model-id>/", instructions)
def test_reference_model_agent_instructions_define_output_contract(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Reference Strategy",
"Model Inventory",
"Abaqus Input Requirements",
"Artifact Bundle Contract",
"Metadata JSON Contract",
"Abaqus Reference CSV Requirements",
"Coverage Matrix",
"Downstream Handoff",
):
self.assertIn(required_text, instructions)
def test_reference_model_document_guide_defines_output_contract(self):
guide = REFERENCE_MODELS_README.read_text(encoding="utf-8")
for required_text in (
"Reference Strategy",
"Model Inventory",
"Abaqus Input Requirements",
"Artifact Bundle Contract",
"Metadata JSON Contract",
"Abaqus Reference CSV Requirements",
"Coverage Matrix",
"Downstream Handoff",
"reference/<model-id>/",
):
self.assertIn(required_text, guide)
if __name__ == "__main__":
unittest.main()