单元测试
单元测试位于tests/unit目录中,应该包含所有类型的单元和集成测试。
每个测试用例都扩展了Codeception\Test\Unit类,这是用于单元测试的标准Codeception格式。在Yii中开发完全隔离的单元测试非常困难,因此在每个测试用例之前都要启动一个应用程序。 (推荐学习:yii教程)
在tests/unit.suite.yml启用了Yii2模块的文件中配置测试:
modules: enabled: - Yii2: part: [orm, email]
该模块为一个测试案例启动Yii应用程序,并提供其他帮助程序方法来简化测试。它只有orm和email零件,以排除需要的只是功能性的测试方法。
通过访问$this->tester测试用例中的类,可以使用Yii2模块的方法。因此,如果启用了orm和email部分,则可以调用属于这些部分的方法:
<?php // insert records in database $this->tester->haveRecord('app/model/User', ['username' => 'davert']); // check records in database $this->tester->seeRecord('app/model/User', ['username' => 'davert']); // test email was sent $this->tester->seeEmailIsSent(); // get a last sent emails $this->tester->grabLastSentEmail();
如果启用fixtures零件,您还将获得在测试中加载和使用夹具的方法:
<?php // load fixtures $this->tester->haveFixtures([ 'user' => [ 'class' => UserFixture::className(), // fixture data located in tests/_data/user.php 'dataFile' => codecept_data_dir() . 'user.php' ] ]); // get first user from fixtures $this->tester->grabFixture('user', 0);
如果Yii2启用了模块,则可以安全地Yii::$app在测试内调用,因为在测试后将初始化并清理应用程序。如果你想添加的辅助方法或自定义断言为您的测试情况下,你不应该延长Codeception\Test\Unit,但写自己的独立的辅助类。
Atas ialah kandungan terperinci yii如何写单元测试. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!