add agents

This commit is contained in:
김경종
2026-06-02 12:28:37 +09:00
parent e54ba13d3b
commit dd50f8c093
9 changed files with 833 additions and 0 deletions
+88
View File
@@ -0,0 +1,88 @@
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" / "formulation-agent.toml"
FORMULATIONS_README = ROOT / "docs" / "formulations" / "README.md"
class FormulationAgentConfigTests(unittest.TestCase):
def test_formulation_agent_toml_has_required_codex_fields(self):
data = tomllib.loads(AGENT_PATH.read_text(encoding="utf-8"))
self.assertEqual(data["name"], "formulation-agent")
self.assertIn("FEM formulation", data["description"])
self.assertEqual(data["sandbox_mode"], "read-only")
self.assertEqual(data["model_reasoning_effort"], "high")
self.assertIn("developer_instructions", data)
def test_formulation_agent_instructions_enforce_boundaries(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Do not implement code.",
"Do not design C++ APIs",
"Do not run Abaqus, Nastran, or any reference solver.",
"Do not generate reference CSVs.",
"Do not approve release readiness.",
"docs/SOLVER_AGENT_DESIGN.md",
"docs/requirements/<feature-id>.md",
"docs/research/<feature-id>-research.md",
):
self.assertIn(required_text, instructions)
def test_formulation_agent_instructions_define_output_contract(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Strong Form and Boundary Conditions",
"Weak or Variational Form",
"Discretization",
"Kinematics",
"Constitutive Contract",
"Element Equations",
"Mapping and Numerical Integration",
"Output Recovery",
"Numerical Risks",
"Downstream Handoff",
):
self.assertIn(required_text, instructions)
def test_formulation_agent_instructions_define_numerical_risk_policy(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"rigid body modes",
"patch test",
"hourglass",
"locking",
"Jacobian",
):
self.assertIn(required_text, instructions)
def test_formulation_document_guide_defines_output_contract(self):
guide = FORMULATIONS_README.read_text(encoding="utf-8")
for required_text in (
"Strong Form and Boundary Conditions",
"Weak or Variational Form",
"Discretization",
"Kinematics",
"Constitutive Contract",
"Element Equations",
"Mapping and Numerical Integration",
"Output Recovery",
"Numerical Risks",
"Downstream Handoff",
):
self.assertIn(required_text, guide)
if __name__ == "__main__":
unittest.main()
+55
View File
@@ -0,0 +1,55 @@
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" / "requirement-agent.toml"
REQUIREMENTS_README = ROOT / "docs" / "requirements" / "README.md"
class RequirementAgentConfigTests(unittest.TestCase):
def test_requirement_agent_toml_has_required_codex_fields(self):
data = tomllib.loads(AGENT_PATH.read_text(encoding="utf-8"))
self.assertEqual(data["name"], "requirement-agent")
self.assertIn("verifiable requirements", data["description"])
self.assertEqual(data["sandbox_mode"], "read-only")
self.assertEqual(data["model_reasoning_effort"], "high")
self.assertIn("developer_instructions", data)
def test_requirement_agent_instructions_enforce_boundaries(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Do not implement code.",
"Do not write finite element formulations.",
"Do not run Abaqus, Nastran, or any reference solver.",
"Do not create reference CSV outputs.",
"Requirement Verification Matrix",
"docs/SOLVER_AGENT_DESIGN.md",
"references/<feature>",
):
self.assertIn(required_text, instructions)
def test_requirement_document_guide_defines_output_contract(self):
guide = REQUIREMENTS_README.read_text(encoding="utf-8")
for required_text in (
"feature_id",
"Verification Quantities",
"Tolerance Policy",
"Reference Artifact Requirements",
"Requirement Verification Matrix",
"Downstream Handoff",
"FESA-REQ-<FEATURE>-001",
):
self.assertIn(required_text, guide)
if __name__ == "__main__":
unittest.main()
+79
View File
@@ -0,0 +1,79 @@
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" / "research-agent.toml"
RESEARCH_README = ROOT / "docs" / "research" / "README.md"
class ResearchAgentConfigTests(unittest.TestCase):
def test_research_agent_toml_has_required_codex_fields(self):
data = tomllib.loads(AGENT_PATH.read_text(encoding="utf-8"))
self.assertEqual(data["name"], "research-agent")
self.assertIn("FEM theory", data["description"])
self.assertEqual(data["sandbox_mode"], "read-only")
self.assertEqual(data["model_reasoning_effort"], "high")
self.assertIn("developer_instructions", data)
def test_research_agent_instructions_enforce_boundaries(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Do not implement code.",
"Do not finalize FEM formulations.",
"Do not run Abaqus, Nastran, or any reference solver.",
"Do not generate reference CSVs.",
"docs/SOLVER_AGENT_DESIGN.md",
"docs/requirements/<feature-id>.md",
"Separate verified facts from inference.",
):
self.assertIn(required_text, instructions)
def test_research_agent_instructions_define_output_contract(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"Source Inventory",
"Candidate Benchmarks",
"Verification Relevance",
"Applicability Limits",
"Downstream Handoff",
):
self.assertIn(required_text, instructions)
def test_research_agent_instructions_define_source_policy(self):
instructions = AGENT_PATH.read_text(encoding="utf-8")
for required_text in (
"ASME V&V 10",
"Abaqus Verification Guide",
"Abaqus Benchmarks Guide",
"NAFEMS benchmarks",
"NASA FEMCI",
"MMS and MES papers",
):
self.assertIn(required_text, instructions)
def test_research_document_guide_defines_output_contract(self):
guide = RESEARCH_README.read_text(encoding="utf-8")
for required_text in (
"Source Reliability Tier",
"Source Inventory",
"Candidate Benchmarks",
"Verification Relevance",
"Applicability Limits",
"Downstream Handoff",
):
self.assertIn(required_text, guide)
if __name__ == "__main__":
unittest.main()