| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- import unittest
- from src.node import ExpressionNode
- from src.parser import Parser
- from tests.parser import ParserWrapper
- def tree(exp, **kwargs):
- return ParserWrapper(Parser, **kwargs).run([exp])
- def rewrite(exp, **kwargs):
- return ParserWrapper(Parser, **kwargs).run([exp, '@'])
- class RulesTestCase(unittest.TestCase):
- def assertEqualPos(self, possibilities, expected):
- self.assertEqual(len(possibilities), len(expected))
- for p, e in zip(possibilities, expected):
- self.assertEqual(p.root, e.root)
- if p.args == None: # pragma: nocover
- self.assertIsNone(e.args)
- elif e.args == None: # pragma: nocover
- self.assertIsNone(p.args)
- else:
- for pair in zip(p.args, e.args):
- self.assertEqual(*pair)
- self.assertEqual(p, e)
- def assertEqualNodes(self, a, b):
- if not isinstance(a, ExpressionNode):
- return self.assertEqual(a, b)
- self.assertIsInstance(b, ExpressionNode)
- self.assertEqual(a.op, b.op)
- for ca, cb in zip(a, b):
- self.assertEqualNodes(ca, cb)
- def assertRewrite(self, rewrite_chain):
- try:
- for i, exp in enumerate(rewrite_chain[:-1]):
- self.assertMultiLineEqual(str(rewrite(exp)),
- str(rewrite_chain[i + 1]))
- except AssertionError as e: # pragma: nocover
- msg = e.args[0]
- msg += '-' * 30 + '\n'
- msg += 'rewrite failed: "%s" -> "%s"\n' \
- % (str(exp), str(rewrite_chain[i + 1]))
- msg += 'rewrite chain: ---\n'
- chain = []
- for j, c in enumerate(rewrite_chain):
- if i == j:
- chain.append('%2d %s <-- error' % (j, str(c)))
- else:
- chain.append('%2d %s' % (j, str(c)))
- e.message = msg + '\n'.join(chain)
- e.args = (e.message,) + e.args[1:]
- raise
|