如何只模拟在测试对象中调用的一个方法



我想测试一个方法,但模拟它调用的其他方法。我创建了一个简单的例子来说明这个概念:

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()

相关内容

  • 没有找到相关文章

最新更新