我正在编写一些单元测试,在每次测试之前我都需要做一些准备,并且在每次测试后我应该撤消这些准备。因此,我使用 setUp 来准备它们,使用列表列出我已执行的操作,并在tearDown 中,撤消所述列表中列出的操作并清除列表。
但是当我进行以下测试时,列表的状态与tearDown离开时的状态不同,而是处于先前setUp离开时的状态。而且感觉很奇怪。我在这里做错了什么吗?
这是一个简短的示例,没有我的业务代码:
class MyTest(TestCase):
val = []
def setUp(self):
super().setUp()
print("before setup, val = {}".format(self.val))
self.val.append("AAA")
print("after setup: val = {}".format(self.val))
def tearDown(self):
super().tearDown()
print("before teardown, val = {}".format(self.val))
self.val = [] # or whatever
print("after teardown, val = {}".format(self.val))
def test_one(self):
assert True
def test_two(self):
assert True
会回来
before start, val = []
after setup: val = ['AAA']
before teardown, val = ['AAA']
after teardown, val = []
.
before start, val = ['AAA'] # <- why is this not []??
after setup: val = ['AAA', 'AAA']
before teardown, val = ['AAA', 'AAA']
after teardown, val = []
.
第二个测试的setUp不应该找到.val == []吗?该值似乎没有被之前的tearDown改变,我不知道为什么。 有什么想法吗?
最佳答案
将 self.val
替换为 MyTest.val
。 val
是类级别变量,而不是对象级别变量。另一种方法是在 setUp
中初始化 self.val
,而不是使其成为类级变量。
关于python - unittest 的tearDown 和setUp 不会以相同的方式更新属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49578050/