我想测试一个方法,但模拟它调用的其他方法。我创建了一个简单的例子来说明这个概念:
class myClass():
def one_method(self):
print "hey"
def two_deep(self):
self.one_method()
def three_deep(self):
self.two_deep()
我使用了一个名为Mox的python模拟框架,并编写了以下代码来实现这一点:
def test_partial(self):
self_mox = mox.Mox()
some_object = myClass()
## 1. make your mock
my_mock = mox.MockObject(some_object)
my_mock.one_method().AndReturn('some_value')
self_mox.ReplayAll()
ret = my_mock.three_deep() ## *** SEE NOTE BELOW called "comment":
self_mox.VerifyAll()
评论:
我想,如果我在一个没有被覆盖的方法上调用这个mock,那么mock将默认为原始代码,然后我可以获得我想要的调用链,最后一个调用将被替换。。。但它不能做到这一点。我不知道如何在没有插入方法的测试对象中嵌入mock对象。
我研究了部分模型和链式模型来解决这个问题,但我找不到实现这个目标的方法
感谢您的帮助:)
--Peter
检查StubOutWithMock的文档:https://code.google.com/p/pymox/wiki/MoxDocumentation#Stub_Outhttps://code.google.com/p/pymox/wiki/MoxRecipes#Mock_a_method_in_the_class_under_test.
所以你需要的是:
def test_partial(self):
self_mox = mox.Mox()
# Create the class as is, instead of doing mock.
some_object = myClass()
# Stub your particular method using the StubOutWithMock.
m.StubOutWithMock(some_object, "one_method")
some_object.one_method().AndReturn('some_value')
self_mox.ReplayAll()
ret = some_object.three_deep()
self_mox.UnsetStubs()
self_mox.VerifyAll()