class HelloWorld(object):
def say_it(self):
return 'Hello I am Hello World'
def i_call_hello_world(hw_obj):
print 'here... check type: %s' %type(HelloWorld)
if isinstance(hw_obj, HelloWorld):
print hw_obj.say_it()
from mock import patch, MagicMock
import unittest
class TestInstance(unittest.TestCase):
@patch('__main__.HelloWorld', spec=HelloWorld)
def test_mock(self,MK):
print type(MK)
MK.say_it.return_value = 'I am fake'
v = i_call_hello_world(MK)
print v
if __name__ == '__main__':
c = HelloWorld()
i_call_hello_world(c)
print isinstance(c, HelloWorld)
unittest.main()
这是回溯
here... check type: <type 'type'>
Hello I am Hello World
True
<class 'mock.MagicMock'>
here... check type: <class 'mock.MagicMock'>
E
======================================================================
ERROR: test_mock (__main__.TestInstance)
----------------------------------------------------------------------
Traceback (most recent call last):
File "/usr/local/lib/python2.7/dist-packages/mock.py", line 1224, in patched
return func(*args, **keywargs)
File "t.py", line 18, in test_mock
v = i_call_hello_world(MK)
File "t.py", line 7, in i_call_hello_world
if isinstance(hw_obj, HelloWorld):
TypeError: isinstance() arg 2 must be a class, type, or tuple of classes and types
----------------------------------------------------------------------
Ran 1 test in 0.002s
Q1。 为什么抛出这个错误?它们是 <class type='MagicMock>
Q2。 如果错误已修复,如何暂停模拟以便第一行通过?
从 文档:
通常,对象的
__class__
属性将返回其类型。对于具有规范的模拟对象,__class__
返回规范类。这允许模拟对象通过isinstance()
测试它们正在替换/伪装的对象:mock = Mock(spec=3) isinstance(mock, int) True
原文由 CppLearner 发布,翻译遵循 CC BY-SA 4.0 许可协议
不要使用
isinstance
,而是检查say_it
方法是否存在。如果该方法存在,请调用它:无论如何,这是一个更好的设计:依赖类型信息要脆弱得多。