0

在 Python 中,我想__init__使用 minimock 库来模拟一个类的方法。

这就是解释器所做的(ipython):

In [1]: import minimock

In [2]: class A:
   ...:     def __init__(self):
   ...:         print "REAL INIT"
   ...:

In [3]: def new_init(self):
   ...:     print "NEW INIT"
   ...:

In [4]: minimock.mock("A.__init__", returns_func=new_init)

In [5]: a = A()
Called A.__init__()
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-5-144b248f218a> in <module>()
----> 1 a = A()

D:\Tools\Python27\lib\site-packages\minimock\__init__.pyc in __call__(self, *args, **kw)
    492         if self.mock_tracker is not None:
    493             self.mock_tracker.call(self.mock_name, *args, **kw)
--> 494         return self._mock_return(*args, **kw)
    495
    496     def _mock_return(self, *args, **kw):

D:\Tools\Python27\lib\site-packages\minimock\__init__.pyc in _mock_return(self, *args, **kw)
    505                 raise Exception("No more mock return values are present.")
    506         elif self.mock_returns_func is not None:
--> 507             return self.mock_returns_func(*args, **kw)
    508         else:
    509             return None

TypeError: new_init() takes exactly 1 argument (0 given)

但是,如果我从 new_init 中删除 self 参数:

def new_init():
    print "NEW INIT"

实例化 A 类给出:

In [13]: a = A()
Called A.__init__()
NEW INIT

这让我认为 minimock 对“自我”有限制。

您知道是否可以在传递给 minimock 的方法的模拟版本中使用“self”?

4

2 回答 2

2

我真的不明白你为什么要这样做,无论如何答案是你不应该A.__init__直接打电话:

>>> class A(object):
...     def __init__(self):
...             print('Old init - self' + str(self))
>>> def new_init(self):
...     print('New init - self:' + str(self))
... 
>>> A.__init__ = new_init
>>> A.__init__()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: unbound method new_init() must be called with A instance as first argument (got nothing instead)
>>> A()
New init - self:<__main__.A object at 0x2446d90>
<__main__.A object at 0x2446d90>

图书馆minimock没有做错任何事。__init__旨在通过调用类来调用。如果显式调用它,则必须显式传递一个实例作为第一个参数。

无论如何,我强烈建议你重新考虑一下你在做什么,因为你不应该做这样的事情。模拟应该用于模拟整个对象,而不仅仅是一个方法。在你的情况下,我会嘲笑整个班级A,而不仅仅是它的__init__方法。

于 2013-01-22T16:57:26.430 回答
1

您正在定义一个函数作为类外部的参数new_initself既然如此,您需要为该函数提供一个参数。你可能想在类中声明它,所以它是一个类方法。否则没有意义。有关如何使用的更多信息,请参阅此问题self

于 2013-01-22T16:52:39.347 回答