|
2 | 2 | import os |
3 | 3 | import unittest |
4 | 4 | import sys |
| 5 | +import operator |
5 | 6 | from test import support |
6 | 7 |
|
7 | 8 | # |
@@ -496,12 +497,81 @@ def test_trigger_memory_error(self): |
496 | 497 | file=sys.stderr) |
497 | 498 | self.assertRaises(MemoryError, parser.expr, e) |
498 | 499 |
|
| 500 | +class STObjectTestCase(unittest.TestCase): |
| 501 | + """Test operations on ST objects themselves""" |
| 502 | + |
| 503 | + def test_comparisons(self): |
| 504 | + # ST objects should support order and equality comparisons |
| 505 | + st1 = parser.expr('2 + 3') |
| 506 | + st2 = parser.suite('x = 2; y = x + 3') |
| 507 | + st3 = parser.expr('list(x**3 for x in range(20))') |
| 508 | + st1_copy = parser.expr('2 + 3') |
| 509 | + st2_copy = parser.suite('x = 2; y = x + 3') |
| 510 | + st3_copy = parser.expr('list(x**3 for x in range(20))') |
| 511 | + |
| 512 | + # exercise fast path for object identity |
| 513 | + self.assertEquals(st1 == st1, True) |
| 514 | + self.assertEquals(st2 == st2, True) |
| 515 | + self.assertEquals(st3 == st3, True) |
| 516 | + # slow path equality |
| 517 | + self.assertEqual(st1, st1_copy) |
| 518 | + self.assertEqual(st2, st2_copy) |
| 519 | + self.assertEqual(st3, st3_copy) |
| 520 | + self.assertEquals(st1 == st2, False) |
| 521 | + self.assertEquals(st1 == st3, False) |
| 522 | + self.assertEquals(st2 == st3, False) |
| 523 | + self.assertEquals(st1 != st1, False) |
| 524 | + self.assertEquals(st2 != st2, False) |
| 525 | + self.assertEquals(st3 != st3, False) |
| 526 | + self.assertEquals(st1 != st1_copy, False) |
| 527 | + self.assertEquals(st2 != st2_copy, False) |
| 528 | + self.assertEquals(st3 != st3_copy, False) |
| 529 | + self.assertEquals(st2 != st1, True) |
| 530 | + self.assertEquals(st1 != st3, True) |
| 531 | + self.assertEquals(st3 != st2, True) |
| 532 | + # we don't particularly care what the ordering is; just that |
| 533 | + # it's usable and self-consistent |
| 534 | + self.assertEquals(st1 < st2, not (st2 <= st1)) |
| 535 | + self.assertEquals(st1 < st3, not (st3 <= st1)) |
| 536 | + self.assertEquals(st2 < st3, not (st3 <= st2)) |
| 537 | + self.assertEquals(st1 < st2, st2 > st1) |
| 538 | + self.assertEquals(st1 < st3, st3 > st1) |
| 539 | + self.assertEquals(st2 < st3, st3 > st2) |
| 540 | + self.assertEquals(st1 <= st2, st2 >= st1) |
| 541 | + self.assertEquals(st3 <= st1, st1 >= st3) |
| 542 | + self.assertEquals(st2 <= st3, st3 >= st2) |
| 543 | + # transitivity |
| 544 | + bottom = min(st1, st2, st3) |
| 545 | + top = max(st1, st2, st3) |
| 546 | + mid = sorted([st1, st2, st3])[1] |
| 547 | + self.assert_(bottom < mid) |
| 548 | + self.assert_(bottom < top) |
| 549 | + self.assert_(mid < top) |
| 550 | + self.assert_(bottom <= mid) |
| 551 | + self.assert_(bottom <= top) |
| 552 | + self.assert_(mid <= top) |
| 553 | + self.assert_(bottom <= bottom) |
| 554 | + self.assert_(mid <= mid) |
| 555 | + self.assert_(top <= top) |
| 556 | + # interaction with other types |
| 557 | + self.assertEquals(st1 == 1588.602459, False) |
| 558 | + self.assertEquals('spanish armada' != st2, True) |
| 559 | + self.assertRaises(TypeError, operator.ge, st3, None) |
| 560 | + self.assertRaises(TypeError, operator.le, False, st1) |
| 561 | + self.assertRaises(TypeError, operator.lt, st1, 1815) |
| 562 | + self.assertRaises(TypeError, operator.gt, b'waterloo', st2) |
| 563 | + |
| 564 | + |
| 565 | + # XXX tests for pickling and unpickling of ST objects should go here |
| 566 | + |
| 567 | + |
499 | 568 | def test_main(): |
500 | 569 | support.run_unittest( |
501 | 570 | RoundtripLegalSyntaxTestCase, |
502 | 571 | IllegalSyntaxTestCase, |
503 | 572 | CompileTestCase, |
504 | 573 | ParserStackLimitTestCase, |
| 574 | + STObjectTestCase, |
505 | 575 | ) |
506 | 576 |
|
507 | 577 |
|
|
0 commit comments