Python Unittest:确保对象不包含来自上一次运行的数据

2024-10-01 04:54:30 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用setUp从我创建的类创建一个新对象。我的理解是,该函数将在测试用例中的每个测试之前执行,这将导致为每个测试创建新的对象。似乎这不是正在发生的事情;至少在我的测试中没有

这是我的课:

class Entity:
    def __init__(self, entities = []):
        self.entities = entities

    def add(self, entity: str):
        if entity not in self.entities:
            self.entities.append(entity)

下面是相应的测试:

import unittest
from entity import Entity

class EntityTestCase(unittest.TestCase):
    def setUp(self):
        self.entity = Entity()
        print("Starting Entites = {}".format(self.entity.entities))

    def testA(self):
        self.entity.add("Foo")
        self.assertEqual(self.entity.entities, ["Foo"])

    def testB(self):
        self.entity.add("Bar")
        self.assertEqual(self.entity.entities, ["Bar"])

if __name__ == '__main__':
    unittest.main()

我希望testAtestB将从新的Entity对象开始。也就是说,我希望Entity.entities是每个测试的一个全新列表

我用python -m unittest discover -v运行测试,结果如下:

$ python -m unittest discover -v
testA (test_entity.EntityTestCase) ... Starting Entites = []
ok
testB (test_entity.EntityTestCase) ... Starting Entites = ['Foo']
FAIL

======================================================================
FAIL: testB (test_entity.EntityTestCase)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "/Users/julioguzman/Sites/Foobar/test_entity.py", line 15, in testB
    self.assertEqual(self.entity.entities, ["Bar"])
AssertionError: Lists differ: ['Foo', 'Bar'] != ['Bar']

First differing element 0:
'Foo'
'Bar'

First list contains 1 additional elements.
First extra element 1:
'Bar'

- ['Foo', 'Bar']
+ ['Bar']

----------------------------------------------------------------------
Ran 2 tests in 0.001s

FAILED (failures=1)

如您所见,testB以来自testA的数据开始。这不是期望的行为,尽管它可能是预期的行为

如何确保每次测试的对象都“干净”?为什么会这样


Tags: 对象intestselfaddfoodefbar
1条回答
网友
1楼 · 发布于 2024-10-01 04:54:30

你有

class Entity:
    def __init__(self, entities = []):
        self.entities = entities

其中默认参数被实例化一次,从而导致这个常见问题

只需修改__init__以使用代理项值,并指定一个全新的列表(如果是):

class Entity:
    def __init__(self, entities=NotImplemented):
        if entities is NotImplemented:
            self.entities = []
        else:
            self.entities = entities

另外,这也是编写unittests的原因之一:它们还测试类是否以预期的行为正确创建。当setUp清楚地显示它创建了一个全新的对象时,这不是测试的问题—错误在于它执行了一些意想不到的操作的实现

相关问题 更多 >