phpunit中执行指定测试case的方法

一. 问题

一个测试文件中,可能包含多个case,如何只执行其中的某个或某几个case呢?php

好比下面的这段测试代码(demotest.php),是否能够只执行针对FuncA的两个测试~testFuncA_1,testFuncA_2呢?mysql

<?php
use PHPUnit\Framework\TestCase;

class Unittest_Demo extends TestCase{
    public function testFuncA_1(){
        echo "\nFuncA1 test\n";
        $this->assertTrue(true);
    }
    
    public function testFuncA_2(){
        echo "\nFuncA2 test\n";
        $this->assertTrue(true);
    }

    public function testFuncB_1(){
        echo "\nFuncB1 test\n";
        $this->assertTrue(true);
    }

    public function testFuncB_2(){
        echo "\nFuncB2 test\n";
        $this->assertTrue(true);
    }
}

二. 解决

2.1 方法一 @group

能够用 @group 标注来标记某个case属于一个或多个组,就像这样:sql

class MyTest extends PHPUnit_Framework_TestCase{
    /**
     * @group specification
     */
    public function testSomething(){
    }

    /**
     * @group regresssion
     * @group bug2204
     */
    public function testSomethingElse(){
    }
}

测试能够基于组来选择性的执行,使用命令行phpunit的 --group选项+组名,能够执行对应测试组的测试。测试

对于1中的问题,咱们能够作以下标注:this

class Unittest_Demo extends TestCase{
    /** 
     *@group FuncA
     * */
    public function testFuncA_1(){
        ... ...
    }
    /** 
     *@group FuncA
     * */
    public function testFuncA_2(){
         ... ...
    }
    
    ...

执行spa

phpunit test.php --group FuncA

获得结果.net

PHPUnit 6.5.3 by Sebastian Bergmann and contributors.

.
FuncA1 test
.                                                              2 / 2 (100%)
FuncA2 test


Time: 88 ms, Memory: 8.00MB

OK (2 tests, 2 assertions)

可使用--list-group选项,查看文件中存在的group。
好比针对上例,咱们执行的效果以下:命令行

phpunit test.php --list-group
PHPUnit 6.5.3 by Sebastian Bergmann and contributors.

Available test group(s):
 - FuncA
 - default

default分组就是未特别标识的case(testFuncB_1,testFuncB_2)。有须要,你可使用以下命令执行这些case。code

phpunit test.php --group default

特别注意

@group是以注释的形式存在,注释的第一行必须是/**,不然phpunit将不识别。ci

2.2 方法二 --filter

命令行的phpunit支持以下选项:

--filter <pattern>

能够用于筛选知足条件的用例。

对于1中的问题,咱们能够执行经过以下命令达到目的。

phpunit test.php --filter FuncA

说明

  • pattern部分相似于mysql的like,即%FuncA%。所以命中了名为testFuncA_1,testFuncA_2的两个case。

做者:跑马溜溜的球 连接:https://www.jianshu.com/p/fc85d763cbb8 来源:简书 简书著做权归做者全部,任何形式的转载都请联系做者得到受权并注明出处。

相关文章
相关标签/搜索