2

我正在开发一个 CherryPy 应用程序,我想为它编写一些自动化测试。我选择使用鼻子测试。该应用程序使用 sqlalchemy 作为数据库后端,因此我需要使用fixture 包来提供固定数据集。我也想做网络测试。这是我将它们组合在一起的方式:

init_model(test = False)在创建所有模型的文件中有一个辅助函数。它连接到生产或测试(如果 test == True 或 cherrypy.request.app.test == True)数据库并调用create_all

然后我为这样的测试创建了一个基类:

class BaseTest(DataTestCase):
def __init__(self):
    init_model(True)
    application.test = True
    self.app = TestApp(application)
    self.fixture = SQLAlchemyFixture(env = models, engine = meta.engine, style = NamedDataStyle())
    self.datasets = (
        # all the datasets go here
        )

现在我通过创建 BaseTest 的子类并调用self.app.some_method()

这是我第一次在 python 中进行测试,这一切看起来都非常复杂。我想知道我是否按照作者的意图使用上述软件包,以及它是否过于复杂。

4

1 回答 1

1

对于任何规模的系统,这看起来很像普通的测试胶水。换句话说,它并不过分复杂。

事实上,我建议在一个方面稍微复杂一些:我认为您会发现在每个子测试类中设置一个新数据库非常慢。每次运行至少设置一次所有表格而不是每个班级一次更常见。然后,您要么让每个测试方法创建它自己需要的所有数据,和/或在事务中运行每个测试用例,然后将其全部回滚到一个finally:块中。

于 2011-01-27T02:26:32.977 回答