mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 10:26:02 +00:00 
			
		
		
		
	 fea6a94b3b
			
		
	
	
		fea6a94b3b
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r64365 | raymond.hettinger | 2008-06-17 19:56:57 -0500 (Tue, 17 Jun 2008) | 1 line Fix double decref. ........ r64370 | mark.dickinson | 2008-06-18 04:20:17 -0500 (Wed, 18 Jun 2008) | 2 lines Typo fix ........ r64406 | andrew.kuchling | 2008-06-19 09:02:30 -0500 (Thu, 19 Jun 2008) | 1 line Only include update_lines_cols() function when it's actually going to be used ........ r64408 | amaury.forgeotdarc | 2008-06-19 14:57:39 -0500 (Thu, 19 Jun 2008) | 2 lines test_macos can be skipped on non-mac platforms. ........ r64409 | andrew.kuchling | 2008-06-19 15:33:31 -0500 (Thu, 19 Jun 2008) | 1 line Put threading in front of thread ........ r64412 | amaury.forgeotdarc | 2008-06-19 16:17:12 -0500 (Thu, 19 Jun 2008) | 3 lines In test_site, correctly escape backslashes in path names. This allows the test to pass when the username begins with a lowercase 't'... ........ r64416 | vinay.sajip | 2008-06-19 17:40:17 -0500 (Thu, 19 Jun 2008) | 2 lines Bug #3136: fileConfig()'s disabling of old loggers is now conditional via an optional disable_existing_loggers parameter, but the default value is such that the old behaviour is preserved. Thanks to Leandro Lucarella for the patch. ........ r64417 | vinay.sajip | 2008-06-19 17:41:08 -0500 (Thu, 19 Jun 2008) | 1 line Updated with fix for #3136. ........ r64420 | andrew.kuchling | 2008-06-19 21:05:57 -0500 (Thu, 19 Jun 2008) | 1 line Various items ........ r64421 | andrew.kuchling | 2008-06-19 21:11:42 -0500 (Thu, 19 Jun 2008) | 1 line Fix comment typos ........ r64425 | andrew.kuchling | 2008-06-20 06:39:54 -0500 (Fri, 20 Jun 2008) | 1 line Various items ........ r64426 | mark.dickinson | 2008-06-20 09:53:43 -0500 (Fri, 20 Jun 2008) | 4 lines Issue #3004: Minor fix to slice.indices(). slice(-10).indices(9) now returns (0, 0, 1) instead of (0, -1, 1), and slice(None, 10, -1).indices(10) returns (9, 9, -1) instead of (9, 10, -1). ........ r64427 | mark.dickinson | 2008-06-20 10:17:41 -0500 (Fri, 20 Jun 2008) | 2 lines Fix outdated count of the number of new math module functions. ........ r64428 | mark.dickinson | 2008-06-20 10:26:19 -0500 (Fri, 20 Jun 2008) | 2 lines Fix another typo in math_sum comment ........
		
			
				
	
	
		
			135 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # tests for slice objects; in particular the indices method.
 | |
| 
 | |
| import unittest
 | |
| from test import support
 | |
| from pickle import loads, dumps
 | |
| 
 | |
| import sys
 | |
| 
 | |
| class SliceTest(unittest.TestCase):
 | |
| 
 | |
|     def test_constructor(self):
 | |
|         self.assertRaises(TypeError, slice)
 | |
|         self.assertRaises(TypeError, slice, 1, 2, 3, 4)
 | |
| 
 | |
|     def test_repr(self):
 | |
|         self.assertEqual(repr(slice(1, 2, 3)), "slice(1, 2, 3)")
 | |
| 
 | |
|     def test_hash(self):
 | |
|         # Verify clearing of SF bug #800796
 | |
|         self.assertRaises(TypeError, hash, slice(5))
 | |
|         self.assertRaises(TypeError, slice(5).__hash__)
 | |
| 
 | |
|     def test_cmp(self):
 | |
|         s1 = slice(1, 2, 3)
 | |
|         s2 = slice(1, 2, 3)
 | |
|         s3 = slice(1, 2, 4)
 | |
|         self.assertEqual(s1, s2)
 | |
|         self.assertNotEqual(s1, s3)
 | |
|         self.assertNotEqual(s1, None)
 | |
|         self.assertNotEqual(s1, (1, 2, 3))
 | |
|         self.assertNotEqual(s1, "")
 | |
| 
 | |
|         class Exc(Exception):
 | |
|             pass
 | |
| 
 | |
|         class BadCmp(object):
 | |
|             def __eq__(self, other):
 | |
|                 raise Exc
 | |
| 
 | |
|         s1 = slice(BadCmp())
 | |
|         s2 = slice(BadCmp())
 | |
|         self.assertEqual(s1, s1)
 | |
|         self.assertRaises(Exc, lambda: s1 == s2)
 | |
| 
 | |
|         s1 = slice(1, BadCmp())
 | |
|         s2 = slice(1, BadCmp())
 | |
|         self.assertEqual(s1, s1)
 | |
|         self.assertRaises(Exc, lambda: s1 == s2)
 | |
| 
 | |
|         s1 = slice(1, 2, BadCmp())
 | |
|         s2 = slice(1, 2, BadCmp())
 | |
|         self.assertEqual(s1, s1)
 | |
|         self.assertRaises(Exc, lambda: s1 == s2)
 | |
| 
 | |
|     def test_members(self):
 | |
|         s = slice(1)
 | |
|         self.assertEqual(s.start, None)
 | |
|         self.assertEqual(s.stop, 1)
 | |
|         self.assertEqual(s.step, None)
 | |
| 
 | |
|         s = slice(1, 2)
 | |
|         self.assertEqual(s.start, 1)
 | |
|         self.assertEqual(s.stop, 2)
 | |
|         self.assertEqual(s.step, None)
 | |
| 
 | |
|         s = slice(1, 2, 3)
 | |
|         self.assertEqual(s.start, 1)
 | |
|         self.assertEqual(s.stop, 2)
 | |
|         self.assertEqual(s.step, 3)
 | |
| 
 | |
|         class AnyClass:
 | |
|             pass
 | |
| 
 | |
|         obj = AnyClass()
 | |
|         s = slice(obj)
 | |
|         self.assert_(s.stop is obj)
 | |
| 
 | |
|     def test_indices(self):
 | |
|         self.assertEqual(slice(None           ).indices(10), (0, 10,  1))
 | |
|         self.assertEqual(slice(None,  None,  2).indices(10), (0, 10,  2))
 | |
|         self.assertEqual(slice(1,     None,  2).indices(10), (1, 10,  2))
 | |
|         self.assertEqual(slice(None,  None, -1).indices(10), (9, -1, -1))
 | |
|         self.assertEqual(slice(None,  None, -2).indices(10), (9, -1, -2))
 | |
|         self.assertEqual(slice(3,     None, -2).indices(10), (3, -1, -2))
 | |
|         # issue 3004 tests
 | |
|         self.assertEqual(slice(None, -9).indices(10), (0, 1, 1))
 | |
|         self.assertEqual(slice(None, -10).indices(10), (0, 0, 1))
 | |
|         self.assertEqual(slice(None, -11).indices(10), (0, 0, 1))
 | |
|         self.assertEqual(slice(None, -10, -1).indices(10), (9, 0, -1))
 | |
|         self.assertEqual(slice(None, -11, -1).indices(10), (9, -1, -1))
 | |
|         self.assertEqual(slice(None, -12, -1).indices(10), (9, -1, -1))
 | |
|         self.assertEqual(slice(None, 9).indices(10), (0, 9, 1))
 | |
|         self.assertEqual(slice(None, 10).indices(10), (0, 10, 1))
 | |
|         self.assertEqual(slice(None, 11).indices(10), (0, 10, 1))
 | |
|         self.assertEqual(slice(None, 8, -1).indices(10), (9, 8, -1))
 | |
|         self.assertEqual(slice(None, 9, -1).indices(10), (9, 9, -1))
 | |
|         self.assertEqual(slice(None, 10, -1).indices(10), (9, 9, -1))
 | |
| 
 | |
|         self.assertEqual(
 | |
|             slice(-100,  100     ).indices(10),
 | |
|             slice(None).indices(10)
 | |
|         )
 | |
|         self.assertEqual(
 | |
|             slice(100,  -100,  -1).indices(10),
 | |
|             slice(None, None, -1).indices(10)
 | |
|         )
 | |
|         self.assertEqual(slice(-100, 100, 2).indices(10), (0, 10,  2))
 | |
| 
 | |
|         self.assertEqual(list(range(10))[::sys.maxsize - 1], [0])
 | |
| 
 | |
|         self.assertRaises(OverflowError, slice(None).indices, 1<<100)
 | |
| 
 | |
|     def test_setslice_without_getslice(self):
 | |
|         tmp = []
 | |
|         class X(object):
 | |
|             def __setitem__(self, i, k):
 | |
|                 tmp.append((i, k))
 | |
| 
 | |
|         x = X()
 | |
|         x[1:2] = 42
 | |
|         self.assertEquals(tmp, [(slice(1, 2), 42)])
 | |
| 
 | |
|     def test_pickle(self):
 | |
|         s = slice(10, 20, 3)
 | |
|         for protocol in (0,1,2):
 | |
|             t = loads(dumps(s, protocol))
 | |
|             self.assertEqual(s, t)
 | |
|             self.assertEqual(s.indices(15), t.indices(15))
 | |
|             self.assertNotEqual(id(s), id(t))
 | |
| 
 | |
| def test_main():
 | |
|     support.run_unittest(SliceTest)
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     test_main()
 |