equicompiler-algebraic-port.../tests/test_core.py

40 lines
1.4 KiB
Python

import unittest
from equicompiler_algebraic_portfolio_dsl_to_.core import parse_dsl_to_ir
class TestCore(unittest.TestCase):
def test_parse_basic(self):
dsl = (
"assets: AAPL, MSFT, GOOG\n"
"objectives: maximize_return\n"
"constraints: max_drawdown=0.2, var=0.95"
)
ir = parse_dsl_to_ir(dsl)
self.assertEqual(ir["assets"], ["AAPL", "MSFT", "GOOG"])
self.assertIn("maximize_return", ir["objectives"])
self.assertEqual(ir["constraints"]["max_drawdown"], "0.2")
self.assertEqual(ir["constraints"]["var"], "0.95")
def test_attestations_present_and_digest_format(self):
dsl = (
"assets: AAPL, MSFT, GOOG\n"
"objectives: maximize_return\n"
"constraints: max_drawdown=0.2, var=0.95"
)
ir = parse_dsl_to_ir(dsl)
# Attestations should be present and include digest fields with hex digest
self.assertIn("attestations", ir)
attestations = ir["attestations"]
self.assertIsInstance(attestations, list)
self.assertGreaterEqual(len(attestations), 1)
import re
for att in attestations:
self.assertIn("digest", att)
self.assertIsInstance(att["digest"], str)
self.assertRegex(att["digest"], r"^[0-9a-f]{64}$")
if __name__ == "__main__":
unittest.main()