mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +00:00 
			
		
		
		
	 04f357cffe
			
		
	
	
		04f357cffe
		
	
	
	
	
		
			
			imports e.g. test_support must do so using an absolute package name such as "import test.test_support" or "from test import test_support". This also updates the README in Lib/test, and gets rid of the duplicate data dirctory in Lib/test/data (replaced by Lib/email/test/data). Now Tim and Jack can have at it. :)
		
			
				
	
	
		
			59 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Test compiler changes for unary ops (+, -, ~) introduced in Python 2.2"""
 | |
| 
 | |
| import unittest
 | |
| from test.test_support import run_unittest, have_unicode
 | |
| 
 | |
| class UnaryOpTestCase(unittest.TestCase):
 | |
| 
 | |
|     def test_negative(self):
 | |
|         self.assert_(-2 == 0 - 2)
 | |
|         self.assert_(-0 == 0)
 | |
|         self.assert_(--2 == 2)
 | |
|         self.assert_(-2L == 0 - 2L)
 | |
|         self.assert_(-2.0 == 0 - 2.0)
 | |
|         self.assert_(-2j == 0 - 2j)
 | |
| 
 | |
|     def test_positive(self):
 | |
|         self.assert_(+2 == 2)
 | |
|         self.assert_(+0 == 0)
 | |
|         self.assert_(++2 == 2)
 | |
|         self.assert_(+2L == 2L)
 | |
|         self.assert_(+2.0 == 2.0)
 | |
|         self.assert_(+2j == 2j)
 | |
| 
 | |
|     def test_invert(self):
 | |
|         self.assert_(-2 == 0 - 2)
 | |
|         self.assert_(-0 == 0)
 | |
|         self.assert_(--2 == 2)
 | |
|         self.assert_(-2L == 0 - 2L)
 | |
| 
 | |
|     def test_no_overflow(self):
 | |
|         nines = "9" * 32
 | |
|         self.assert_(eval("+" + nines) == eval("+" + nines + "L"))
 | |
|         self.assert_(eval("-" + nines) == eval("-" + nines + "L"))
 | |
|         self.assert_(eval("~" + nines) == eval("~" + nines + "L"))
 | |
| 
 | |
|     def test_negation_of_exponentiation(self):
 | |
|         # Make sure '**' does the right thing; these form a
 | |
|         # regression test for SourceForge bug #456756.
 | |
|         self.assertEqual(-2 ** 3, -8)
 | |
|         self.assertEqual((-2) ** 3, -8)
 | |
|         self.assertEqual(-2 ** 4, -16)
 | |
|         self.assertEqual((-2) ** 4, 16)
 | |
| 
 | |
|     def test_bad_types(self):
 | |
|         for op in '+', '-', '~':
 | |
|             self.assertRaises(TypeError, eval, op + "'a'")
 | |
|             if have_unicode:
 | |
|                 self.assertRaises(TypeError, eval, op + "u'a'")
 | |
| 
 | |
|         self.assertRaises(TypeError, eval, "~2j")
 | |
|         self.assertRaises(TypeError, eval, "~2.0")
 | |
| 
 | |
| 
 | |
| def test_main():
 | |
|     run_unittest(UnaryOpTestCase)
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     test_main()
 |