3

我是单元测试的新手,我正在尝试在我正在处理的现有项目中开始使用 PHPUnit。

我面临的问题是我有很多单元测试需要一个足够公平的数据库。我已经建立了一个 SQLite 数据库,仅用于单元测试。有时我想为新测试删除并重新创建数据库(我指的是每个单独的类),以防止不必要的数据冲突。

但是,如果我在同一个类中有相互依赖的单元测试,有时我不希望这种情况发生;这些可能需要访问在先前测试中保存的数据。

我目前在每个类的 setUp() 函数中都获得了一个“新鲜”的数据库。我没想到的是这个函数(与 __construct() 一样)会在所述类中的每个测试用例之后运行。

有没有办法可以用每个测试类刷新数据库?还是我对整个过程的处理不正确?

任何提示表示赞赏,谢谢。

4

2 回答 2

3

我最近(大约一年前)也开始使用 PHPUnit。我做的第一件事是为我当时正在从事的项目设置单元测试。我认为测试数据访问层也是一个好主意,并为您做了类似的事情。我花了几天的时间来设置,最后我完成了需要 8 分钟才能运行的单元测试!99% 的时间都花在了设置和拆除测试数据库上。这悲剧!

我所做的是重构项目,这样实际上只有一个类需要与数据库对话,并为此进行了集成测试,但没有单元测试。这意味着我的项目现在必须使用依赖注入来促进测试。我最终得到了一套大约在 2-3 秒内运行的测试和一个几乎可以自己编写的项目。维护和进行更改/添加是一个梦想,我希望我所有的代码都是这样编写的。

基本上,我想说的是,您应该将代码更改为易于测试,而不是尝试强制单元测试以适应并非以测试驱动方式设计的代码。您现在投资的时间(如果可以的话)将在以后用红利偿还!

咬紧牙关,现在重构!

于 2012-07-30T17:41:21.813 回答
2

setUp 和 tearDown 功能完全按照您提到的方式进行,即为每次测试执行设置测试环境,然后在每次测试用例执行后进行清理。

您可能想要做的是在套件级别设置数据库数据提供程序。

套房级固定装置

这可能不是真正获得真正独立单元测试的最佳方法(即,您可以为 DB 等设置模拟数据提供程序)。但这是你可以做的事情,应该满足你的直接需求。

于 2012-07-30T17:11:23.977 回答