| 
									
										
										
										
											2002-07-23 19:04:11 +00:00
										 |  |  | from test.test_support import verbose, verify | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | import sys | 
					
						
							|  |  |  | import new | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Eggs: | 
					
						
							|  |  |  |     def get_yolks(self): | 
					
						
							| 
									
										
										
										
											1998-03-26 19:42:58 +00:00
										 |  |  |         return self.yolks | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | print 'new.module()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | m = new.module('Spam') | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | if verbose: | 
					
						
							|  |  |  |     print m | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | m.Eggs = Eggs | 
					
						
							|  |  |  | sys.modules['Spam'] = m | 
					
						
							|  |  |  | import Spam | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_more_yolks(self): | 
					
						
							|  |  |  |     return self.yolks + 3 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | print 'new.classobj()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | C = new.classobj('Spam', (Spam.Eggs,), {'get_more_yolks': get_more_yolks}) | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | if verbose: | 
					
						
							|  |  |  |     print C | 
					
						
							|  |  |  | print 'new.instance()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | c = new.instance(C, {'yolks': 3}) | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | if verbose: | 
					
						
							|  |  |  |     print c | 
					
						
							| 
									
										
										
										
											2001-01-28 03:57:39 +00:00
										 |  |  | o = new.instance(C) | 
					
						
							|  |  |  | verify(o.__dict__ == {}, | 
					
						
							|  |  |  |        "new __dict__ should be empty") | 
					
						
							|  |  |  | del o | 
					
						
							|  |  |  | o = new.instance(C, None) | 
					
						
							|  |  |  | verify(o.__dict__ == {}, | 
					
						
							|  |  |  |        "new __dict__ should be empty") | 
					
						
							|  |  |  | del o | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | def break_yolks(self): | 
					
						
							|  |  |  |     self.yolks = self.yolks - 2 | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | print 'new.instancemethod()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | im = new.instancemethod(break_yolks, c, C) | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | if verbose: | 
					
						
							|  |  |  |     print im | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-01-28 03:57:39 +00:00
										 |  |  | verify(c.get_yolks() == 3 and c.get_more_yolks() == 6, | 
					
						
							|  |  |  |        'Broken call of hand-crafted class instance') | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | im() | 
					
						
							| 
									
										
										
										
											2001-01-28 03:57:39 +00:00
										 |  |  | verify(c.get_yolks() == 1 and c.get_more_yolks() == 4, | 
					
						
							|  |  |  |        'Broken call of hand-crafted instance method') | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-03-23 16:13:30 +00:00
										 |  |  | # It's unclear what the semantics should be for a code object compiled at | 
					
						
							|  |  |  | # module scope, but bound and run in a function.  In CPython, `c' is global | 
					
						
							|  |  |  | # (by accident?) while in Jython, `c' is local.  The intent of the test | 
					
						
							|  |  |  | # clearly is to make `c' global, so let's be explicit about it. | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | codestr = '''
 | 
					
						
							| 
									
										
										
										
											2001-03-23 16:13:30 +00:00
										 |  |  | global c | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | a = 1 | 
					
						
							|  |  |  | b = 2 | 
					
						
							|  |  |  | c = a + b | 
					
						
							|  |  |  | '''
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ccode = compile(codestr, '<string>', 'exec') | 
					
						
							| 
									
										
										
										
											2001-03-23 16:13:30 +00:00
										 |  |  | # Jython doesn't have a __builtins__, so use a portable alternative | 
					
						
							|  |  |  | import __builtin__ | 
					
						
							|  |  |  | g = {'c': 0, '__builtins__': __builtin__} | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | # this test could be more robust | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | print 'new.function()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | func = new.function(ccode, g) | 
					
						
							| 
									
										
										
										
											1996-12-23 23:39:42 +00:00
										 |  |  | if verbose: | 
					
						
							|  |  |  |     print func | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | func() | 
					
						
							| 
									
										
										
										
											2001-01-28 03:57:39 +00:00
										 |  |  | verify(g['c'] == 3, | 
					
						
							|  |  |  |        'Could not create a proper function object') | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-07-11 18:30:27 +00:00
										 |  |  | # test the various extended flavors of function.new | 
					
						
							|  |  |  | def f(x): | 
					
						
							|  |  |  |     def g(y): | 
					
						
							|  |  |  |         return x + y | 
					
						
							|  |  |  |     return g | 
					
						
							|  |  |  | g = f(4) | 
					
						
							|  |  |  | new.function(f.func_code, {}, "blah") | 
					
						
							|  |  |  | g2 = new.function(g.func_code, {}, "blah", (2,), g.func_closure) | 
					
						
							|  |  |  | verify(g2() == 6) | 
					
						
							|  |  |  | g3 = new.function(g.func_code, {}, "blah", None, g.func_closure) | 
					
						
							|  |  |  | verify(g3(5) == 9) | 
					
						
							|  |  |  | def test_closure(func, closure, exc): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         new.function(func.func_code, {}, "", None, closure) | 
					
						
							|  |  |  |     except exc: | 
					
						
							|  |  |  |         pass | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         print "corrupt closure accepted" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test_closure(g, None, TypeError) # invalid closure | 
					
						
							|  |  |  | test_closure(g, (1,), TypeError) # non-cell in closure | 
					
						
							|  |  |  | test_closure(g, (1, 1), ValueError) # closure is wrong size | 
					
						
							|  |  |  | test_closure(f, g.func_closure, ValueError) # no closure needed | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-12-09 10:19:25 +00:00
										 |  |  | print 'new.code()' | 
					
						
							| 
									
										
										
										
											1996-12-10 16:28:53 +00:00
										 |  |  | # bogus test of new.code() | 
					
						
							| 
									
										
										
										
											2001-03-23 16:13:30 +00:00
										 |  |  | # Note: Jython will never have new.code() | 
					
						
							|  |  |  | if hasattr(new, 'code'): | 
					
						
							|  |  |  |     d = new.code(3, 3, 3, 3, codestr, (), (), (), | 
					
						
							|  |  |  |                  "<string>", "<name>", 1, "", (), ()) | 
					
						
							|  |  |  |     # test backwards-compatibility version with no freevars or cellvars | 
					
						
							|  |  |  |     d = new.code(3, 3, 3, 3, codestr, (), (), (), | 
					
						
							|  |  |  |                  "<string>", "<name>", 1, "") | 
					
						
							|  |  |  |     if verbose: | 
					
						
							|  |  |  |         print d |