A test of the `new' module. The new.code() test is fairly bogus since
I'm really not sure what the proper inputs are. I do flex the function call though by passing in arguments of the proper type. I don't try to exec the code object that gets returned!
This commit is contained in:
parent
0f150e41be
commit
924e5d55b7
|
@ -0,0 +1,44 @@
|
|||
import sys
|
||||
import new
|
||||
|
||||
class Eggs:
|
||||
def get_yolks(self):
|
||||
return self.yolks
|
||||
|
||||
m = new.module('Spam')
|
||||
m.Eggs = Eggs
|
||||
sys.modules['Spam'] = m
|
||||
import Spam
|
||||
|
||||
def get_more_yolks(self):
|
||||
return self.yolks + 3
|
||||
|
||||
C = new.classobj('Spam', (Spam.Eggs,), {'get_more_yolks': get_more_yolks})
|
||||
c = new.instance(C, {'yolks': 3})
|
||||
|
||||
def break_yolks(self):
|
||||
self.yolks = self.yolks - 2
|
||||
im = new.instancemethod(break_yolks, c, C)
|
||||
|
||||
if c.get_yolks() <> 3 and c.get_more_yolks() <> 6:
|
||||
print 'Broken call of hand-crafted class instance'
|
||||
im()
|
||||
if c.get_yolks() <> 1 and c.get_more_yolks() <> 4:
|
||||
print 'Broken call of hand-crafted instance method'
|
||||
|
||||
codestr = '''
|
||||
a = 1
|
||||
b = 2
|
||||
c = a + b
|
||||
'''
|
||||
|
||||
ccode = compile(codestr, '<string>', 'exec')
|
||||
g = {'c': 0, '__builtins__': __builtins__}
|
||||
# this test could be more robust
|
||||
func = new.function(ccode, g)
|
||||
func()
|
||||
if g['c'] <> 3:
|
||||
print 'Could not create a proper function object'
|
||||
|
||||
# bogus test of new.code()
|
||||
new.code(3, 3, 3, codestr, (), (), (), "<string>", "<name>")
|
Loading…
Reference in New Issue