7

我对单元测试相当陌生,并且正在尝试找出该事物的最佳实践。我在这里看到了几个与单元测试继承一个本身包含多个测试的基类有关的问题,例如:

class TestBase(unittest.TestCase):
    # some standard tests

class AnotherTest(TestBase):
    # run some more tests in addition to the standard tests

我认为我从社区收集到的是,为每个实现编写单独的测试并使用多重继承是一个更好的主意。但是,如果该基类实际上不包含任何测试怎么办——只是所有其他测试的助手。例如,假设我有一些基本测试类,我用它来存储一些常用方法,即使不是所有其他测试都会使用这些方法。我们还假设我有一个models.py名为的数据库模型ContentModel

test_base.py

import webtest
from google.appengine.ext import testbed
from models import ContentModel

class TestBase(unittest.TestCase):

    def setUp(self):
        self.ContentModel = ContentModel
        self.testbed = testbed.Testbed()
        self.testbed.activate()
        # other useful stuff

    def tearDown(self):
        self.testbed.deactivate()

    def createUser(self, admin=False):
        # create a user that may or may not be an admin

    # possibly other useful things

看来这可以为我在所有其他测试上节省大量时间:

另一个_test.py

from test_base import TestBase

class AnotherTest(TestBase):
    def test_something_authorized(self):
        self.createUser(admin=True)
        # run a test

    def test_something_unauthorized(self):
        self.createUser(admin=False)
        # run a test

    def test_some_interaction_with_the_content_model(self):
        new_instance = self.ContentModel('foo' = 'bar').put()
        # run a test

注意:这是基于我在谷歌应用引擎上的 webapp2 中的一些工作,但我预计几乎所有 python web 应用程序都会出现类似的情况

我的问题

使用包含所有其他测试继承的有用方法/变量的基类/辅助类是一种好习惯,还是每个测试类都应该是“自包含的”?

谢谢!

4

2 回答 2

3

很棒的问题。我认为您所做的几乎所有自动化测试的工作都非常出色。也就是说,测试确实是唯一可靠的文档来源。所以测试应该很容易阅读和理解。与评论不同,测试是可靠的,因为它们显示了软件的真正作用以及如何使用它。

我喜欢这种方法。但你也可以试试鼻子。Nose 设置起来有点“轻量级”,如果您使用Jenkins之类的持续集成路线进行自动构建/测试/部署,它会得到很好的支持。Nose 的消息格式不如 xUnit 样式好(当然是 IMO)。但对于很多事情,你可能愿意放弃。

顺便提一句。Python 不是 Java。因此,仅重用一个普通的旧 python 函数进行重用是完全可以接受的。

于 2014-02-13T00:25:12.377 回答
1

对于某些用途,基类是一个不错的选择——只要您不测试基类中的任何内容。我一直使用基类。

另外,想想在测试类中查看代码的价值。一个很好的例子是我一直使用的基类(在 c#.NET 中):我使用需要许可证的 SDK - Esri 的 ArcObjects。在正常执行中,这是在其他地方处理的,但在测试中,我必须先签出(或激活)许可证,然后才能使用库中的对象。这与我在测试类中测试的代码的功能完全无关,但需要使测试运行。因此,我决定将这个功能隐藏在一个基类中,该基类在测试前签出许可证,然后再将其签入。需要许可证的测试只是从这个基类继承而来。

最后,要非常小心设置和拆除测试的先决条件。如果一些在基类中完成,而另一些在子类中完成,它可能会变得混乱。

于 2014-02-13T12:38:36.623 回答