我想测试一个方法但是模拟掉它调用的其他方法。我创建了这个简单的例子来说明这个概念:
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()
注释:
我认为如果我在一个尚未被覆盖的方法上调用此模拟,那么模拟将默认为原始代码,然后我可以获得我想要的调用链,最后一个调用被替换。 ..但它没有这样做。我无法弄清楚如何在没有插入方法的测试对象中嵌入模拟对象。
我调查了Partial Mocks和Chained Mocks来解决这个问题,但我找不到办法解决这个问题。
感谢您的帮助:)
- 彼得
答案 0 :(得分:0)
检查StubOutWithMock的文档: https://code.google.com/p/pymox/wiki/MoxDocumentation#Stub_Out https://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()