我有一个抽象基类:
import abc
import six
@six.add_metaclass(abc.ABCMeta)
class A(object):
@abc.abstractmethod
def f(self, arg1):
pass
我想使用此类作为模拟的规范。
import mock
mock_a = mock.Mock(spec=A)
这部分起作用。例如,mock_a.x
结果为AttribureError("Mock object has no attribute 'x')
。但是mock_a.f
,并未基于的抽象方法进行说明A.f
。无论传递给的参数数量如何,它都会返回一个模拟f
。
mock_a = mock.Mock(spec=A)
# Succeeds
print mock_a.f(1)
# Should fail, but returns a mock
print mock_a.f(1,2)
# Correctly fails
print mock_a.x
模拟可以创建speced一个模拟A.f
带create_autospec
...
f_spec = mock.create_autospec(A.f)
# Succeeds
f_spec(mock_a, 1)
# Correctly fails
f_spec(mock_a, 1, 2)
...但是对于A的属性却不这样做
如何创建可以准确实现抽象基类的模拟?
申请mock.create_autospec()
上课:
>>> mock_a = mock.create_autospec(spec=A)
>>>
>>> # Should succeed
>>> print mock_a.f(1)
<MagicMock name='mock.f()' id='140401932347984'>
>>>
>>> # Should fail
>>> print mock_a.f(1,2)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/dist-packages/mock/mock.py", line 1061, in __call__
_mock_self._mock_check_sig(*args, **kwargs)
File "/usr/lib/python2.7/dist-packages/mock/mock.py", line 227, in checksig
sig.bind(*args, **kwargs)
File "/usr/lib/python2.7/dist-packages/mock/mock.py", line 95, in fixedbind
return self._bind(args, kwargs)
File "/usr/lib/python2.7/dist-packages/funcsigs/__init__.py", line 712, in _bind
raise TypeError('too many positional arguments')
TypeError: too many positional arguments
>>>
>>> # Should fail
>>> print mock_a.x
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/dist-packages/mock/mock.py", line 716, in __getattr__
raise AttributeError("Mock object has no attribute %r" % name)
AttributeError: Mock object has no attribute 'x'
>>>
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句