我正在尝试使用PHPunit关注单元测试.
我在这里找到了一个非常好的教程http://blog.nickbelhomme.com/php/phpunit-training-course-for-free_282
但是有些东西我想念并且还不知道该怎么做.
我有一个用户模块,它维护有关用户的所有信息.还有一个功能保存功能可以将用户保存在数据库中.所以我有一个testFunction
public function testCanCreateUser() { $userData = array( 'userName' => 'User1','firstName' => 'Joey','lastName' => 'Hendricks','email' => 'Joey@hendricks.com','password' => 'f$tfe8F' ); $user = new Model_User($userData); $user->save(); }
我将第一次参加我的测试.由于数据库是空的.但是当我第二次运行我的测试时它将无法工作,因为我的系统不允许同一个用户在数据库中两次.所以为了做到这一点,我必须在每次运行测试之前重新创建我的testdatabase.做这个的最好方式是什么?
或者这个问题是以不同的方式解决的吗?
TNX.
解决方法
如果要测试业务逻辑:模拟数据库类并返回虚假数据
如果你想测试触发sql语句的类(并且你也可以测试它,因为我有点想知道我的代码是否在后端使用真正的数据库工作正常)它有点复杂但有办法做到这一点:
>在运行测试之前使用setUp()和tearDown()为您获取数据的一致状态是(imho)编写数据库驱动的单元测试的好方法.尽管手动编写大量自定义sql会很烦人.
>为了让您的生活更轻松,您可以查看DbUnit extension并查看它是否适用于您的应用程序.
>如果您真的想深入了解Unittesting数据库交互,那么关于该主题的最佳读物是(imho)Sebastian Bergmanns phpqa book中关于db-unittesting的章节.>您的应用程序是否允许自定义数据库名称和所有表的自动设置,也可以使用大量testdata将数据库设置为一次,并在所有测试中使用该数据.你可能会小心,尽管一个测试不依赖于另一个测试所写的数据.