Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(8)

Delta Between Two Patch Sets: Lib/test/test_range.py

Issue 28376: assertion failure in rangeobject.c
Left Patch Set: Created 3 years, 7 months ago
Right Patch Set: Created 3 years, 7 months ago
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments. Please Sign in to add in-line comments.
Jump to:
Left: Side by side diff | Download
Right: Side by side diff | Download
« no previous file with change/comment | « no previous file | Objects/rangeobject.c » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
1 # Python test set -- built-in functions 1 # Python test set -- built-in functions
2 2
3 import unittest 3 import unittest
4 import sys 4 import sys
5 import pickle 5 import pickle
6 import itertools 6 import itertools
7 import test.support 7 import test.support
8 8
9 # pure Python implementations (3 args only), for comparison 9 # pure Python implementations (3 args only), for comparison
10 def pyrange(start, stop, step): 10 def pyrange(start, stop, step):
(...skipping 483 matching lines...) Expand 10 before | Expand all | Expand 10 after
494 test_id = "reversed(range({}, {}, {}))".format(start, end, step) 494 test_id = "reversed(range({}, {}, {}))".format(start, end, step)
495 self.assert_iterators_equal(iter1, iter2, test_id, limit=100) 495 self.assert_iterators_equal(iter1, iter2, test_id, limit=100)
496 496
497 @test.support.cpython_only 497 @test.support.cpython_only
498 def test_range_iterator_invocation(self): 498 def test_range_iterator_invocation(self):
499 import _testcapi 499 import _testcapi
500 rangeiter_type = type(iter(range(0))) 500 rangeiter_type = type(iter(range(0)))
501 501
502 self.assertWarns(DeprecationWarning, rangeiter_type, 1, 3, 1) 502 self.assertWarns(DeprecationWarning, rangeiter_type, 1, 3, 1)
503 503
504 # rangeiter_new doesn't take keyword arguments 504 with test.support.check_warnings(('', DeprecationWarning)):
505 with self.assertRaises(TypeError): 505 # rangeiter_new doesn't take keyword arguments
506 rangeiter_type(a=1) 506 with self.assertRaises(TypeError):
storchaka 2016/10/08 18:39:33 Aren't all invocations of rangeiter_type emit Depr
507 507 rangeiter_type(a=1)
508 # rangeiter_new takes exactly 3 arguments 508
509 self.assertRaises(TypeError, rangeiter_type) 509 # rangeiter_new takes exactly 3 arguments
510 self.assertRaises(TypeError, rangeiter_type, 1) 510 self.assertRaises(TypeError, rangeiter_type)
511 self.assertRaises(TypeError, rangeiter_type, 1, 1) 511 self.assertRaises(TypeError, rangeiter_type, 1)
512 self.assertRaises(TypeError, rangeiter_type, 1, 1, 1, 1) 512 self.assertRaises(TypeError, rangeiter_type, 1, 1)
513 513 self.assertRaises(TypeError, rangeiter_type, 1, 1, 1, 1)
514 # start, stop and stop must fit in C long 514
515 for good_val in [_testcapi.LONG_MAX, _testcapi.LONG_MIN]: 515 # start, stop and stop must fit in C long
516 rangeiter_type(good_val, good_val, good_val) 516 for good_val in [_testcapi.LONG_MAX, _testcapi.LONG_MIN]:
517 for bad_val in [_testcapi.LONG_MAX + 1, _testcapi.LONG_MIN - 1]: 517 rangeiter_type(good_val, good_val, good_val)
518 self.assertRaises(OverflowError, 518 for bad_val in [_testcapi.LONG_MAX + 1, _testcapi.LONG_MIN - 1]:
519 rangeiter_type, bad_val, 1, 1) 519 self.assertRaises(OverflowError,
520 self.assertRaises(OverflowError, 520 rangeiter_type, bad_val, 1, 1)
521 rangeiter_type, 1, bad_val, 1) 521 self.assertRaises(OverflowError,
522 self.assertRaises(OverflowError, 522 rangeiter_type, 1, bad_val, 1)
523 rangeiter_type, 1, 1, bad_val) 523 self.assertRaises(OverflowError,
524 524 rangeiter_type, 1, 1, bad_val)
525 # step mustn't be zero 525
526 self.assertRaises(ValueError, rangeiter_type, 1, 1, 0) 526 # step mustn't be zero
527 self.assertRaises(ValueError, rangeiter_type, 1, 1, 0)
527 528
528 def test_slice(self): 529 def test_slice(self):
529 def check(start, stop, step=None): 530 def check(start, stop, step=None):
530 i = slice(start, stop, step) 531 i = slice(start, stop, step)
531 self.assertEqual(list(r[i]), list(r)[i]) 532 self.assertEqual(list(r[i]), list(r)[i])
532 self.assertEqual(len(r[i]), len(list(r)[i])) 533 self.assertEqual(len(r[i]), len(list(r)[i]))
533 for r in [range(10), 534 for r in [range(10),
534 range(0), 535 range(0),
535 range(1, 9, 3), 536 range(1, 9, 3),
536 range(8, 0, -3), 537 range(8, 0, -3),
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after
674 675
675 with self.assertRaises(AttributeError): 676 with self.assertRaises(AttributeError):
676 del rangeobj.start 677 del rangeobj.start
677 with self.assertRaises(AttributeError): 678 with self.assertRaises(AttributeError):
678 del rangeobj.stop 679 del rangeobj.stop
679 with self.assertRaises(AttributeError): 680 with self.assertRaises(AttributeError):
680 del rangeobj.step 681 del rangeobj.step
681 682
682 if __name__ == "__main__": 683 if __name__ == "__main__":
683 unittest.main() 684 unittest.main()
LEFTRIGHT

RSS Feeds Recent Issues | This issue
This is Rietveld 894c83f36cb7+