Yii单元测试 codeception-Fixture的使用

Fixture

本文主要是介绍关于Fixture,Specify的使用和遇到的坑
部分是根据源码摸索,有差错的部分望指出php

Fixture主要是用来提供测试环境下的数据特定的状态
例如:测试中须要一条待评估的方案数据,使用fixture可在测试前自动将所用的特定状态的数据填充入数据库,不用每次重复作没必要要的操做数据库

首先,定义用的Fixture CusMainFixture.php ($modelClass 指定你将要测试须要的表)数组

namespace tests\codeception\backend\unit\fixtures;

 use yii\test\ActiveFixture;

 class CusMainFixture extends ActiveFixture
 {
     public $modelClass = 'backend\models\CusMain';
 }

而后将你本次测试所须要的特定数据,写入fixture下的data目录下,名为 表名.php--CusMain.phpapp

return [
    'user1' => [
        'ID' => '1231231',
        'CNAME'=>'李时珍',
        'SEX'=>'1',
    ],
    'user2' => [
        'ID' => '12314231',
        'CNAME'=>'努尔哈赤',
        'SEX'=>'2',
    ],
];

你能够给某行指定一个 alias 别名,这样在你之后的测试中,你能够经过别名来肯定某行。 在上面的例子中,这两行指定别名为 user1 和 user2。(若是不使用别名,直接使用数组的话可使用CusMain[0],CusMain[1]调用)yii

接着就可使用Fixture了,注意要继承DbTestCase使用,继承就要引用,这里有个坑,在yii的文档中引用的是单元测试

use yii\codeception\DbTestCase;

测试时会报错测试

缘由是 他引用的是yii-codeception的,官方也已经中止维护,不推荐使用了,要使用codeception所带的DbTestCasethis

use tests\codeception\backend\unit\DbTestCase;

经过fixtures方法导入数据spa

namespace  tests\codeception\backend\unit\models;

use backend\models\CusMain;
use tests\codeception\backend\unit\DbTestCase;
use tests\codeception\backend\unit\fixtures\CusMainFixture;

class CusMainTest extends DbTestCase
{
    public function fixtures()
    {
        return [
            'Cusmain' => [
                        'class' => CusMainFixture::className(),
                        'dataFile' => '@tests/codeception/backend/unit/fixtures/data/CusMain.php'
                        ],
           //若是测试同时对多张表进行操做,能够在此继续添加fixture,流程与建立cusmian过程相同
          ];
    }
}

运行测试,能够看到数据库中只有预先fixture的两条特定数据 ;(会清空原有数据插入测试数据)3d

接下来的测试代码中,发现不能在使用普通的断言了,codeception提供了verify,expect的方法,二者基本等价的
官方介绍

If you follow TDD/BDD you'd rather use expect instead of verify. Which are just an alias functions:

$row = $this->Cusmain['user1'];   //取fixture值
$user = CusMain::findOne(['CNAME' => $row['CNAME']]);
$user ->CNAME = 'wewewe';
//判断是否返回true 或false   
verify('false', $user ->save())->true();   
//verify(‘返回错误提示’,判断内容)->指望值
// 12314231
//包含 只要是子集就能够
expect('ID is wrong', $user ->ID)->contains('123');
verify('ID is wrong', $user ->ID)->contains('123');
//是否相同
expect('ID is wrong Num', $user ->ID)->equals('1231231');
verify('ID is wrong Num', $user ->ID)->equals('1231231');

若是想使用断言的话,可使用specify方法

use Codeception\Specify;
........
//断言不成立的时候 返回语句
       $this->specify("ID should be 1231231", function() {
             $row = $this->Cusmain['user1'];
             $user = CusMain::findOne(['CNAME' => $row['CNAME']]);
            $this->assertNotEquals('1231231',  $user->ID);
        });

关于specify和verify的具体用法能够在源码中查询
vendor\codeception\specify\tests\SpecifyTest.php
vendor\codeception\verify\tests\VerifyTest.php

PS:若是报错表不存在,有两种解决方案
1.须要将配置文件db指向所测试的库
2.若是操做跨库多表的状况,将model中代码

public static function tableName()
    {
        return 'cus_main';
    }

    public static function getDb()
    {
        return Yii::$app->get('qmcus');
    }

修改为 codeception只获取到tablename的方法

public static function tableName()
    {
        return 'qmcus.cus_main';
    }

以上是对于单元测试的一段落的总结 不断补充完善

相关文章
相关标签/搜索