我有以下结构:
ClassB():
def foo():
Class A():
def __init__(self, B):
#some initialisations
def method1():
#complex logic
B.foo()
我正在尝试编写一个单元测试方法 1 并想测试 foo 是否被调用一次。我怎样才能做到这一点?我应该嘲笑什么?
我有以下结构:
ClassB():
def foo():
Class A():
def __init__(self, B):
#some initialisations
def method1():
#complex logic
B.foo()
我正在尝试编写一个单元测试方法 1 并想测试 foo 是否被调用一次。我怎样才能做到这一点?我应该嘲笑什么?
根据OP提供的进一步信息,对答案进行了返工。
下面的代码已经在CentOS 8上用Python3.8.3本地测试过,运行python3 -m unittest
看看测试结果。
功能代码(sub.py):
class B():
def foo(self):
pass
class A():
def __init__(self, B):
self.b = B
def method1(self):
self.b.foo()
测试代码(test.py):
from unittest import TestCase
from unittest.mock import patch
from sub import A, B
class Test(TestCase):
def test_A(self):
with patch('sub.B.foo') as mock_foo:
a = A(B)
a.method1()
mock_foo.assert_called_once()
基本上,测试代码会尝试模拟该B.foo
方法并检查该方法是否在被调用时A.method1
被调用过一次。
a = A(B)
线路不调用B.foo
a.method1()
线路呼叫B.foo
总共B.foo
只调用一次,所以mock_foo.assert_called_once()
会通过。如果上述任何参数被证明无效,则断言将失败。如果您只需要检查B.foo
是否已至少调用一次,请mock_foo.assert_called()
改用。
关于 mock 系统的详细信息,我建议阅读官方文档。
您应该创建一个 Mock for B
,将其传递给 of 的构造函数A
并检查该函数是否被调用过一次。
您可以自己编写 Mock。例如:
class B_Mock():
def __init__(self):
self.foo_calls = 0
def foo(self):
self.foo_calls += 1
而不是检查foo_calls
你的 B_Mock 实例的属性assert