百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>网页制作> PHP测试框架PHPUnit根本运用
分享文章到:

PHP测试框架PHPUnit根本运用

发布时间:09/01 来源:未知 浏览: 关键词:
一、前言

在这篇文章中,我们使用 composer 的依靠保证理工具停止phpunit包安置和治理,composer 官方地址 https://getcomposer.org/,依照提醒停止全局安置即可,别的,我们也会使用一个非常好用的Monolog记载日志组件记载日志,利便我们查看。

在根名目下创立 coomposer.json 的配置文件,输入以下内容:

{
    "autoload": {
        "classmap": [
            "./"
        ]
    }
}

上面的意思是将根名目下的所有的类文件都加载进来, 在命令行施行 composer install 后,在根名目会生成出一个vendor的文件夹,我们今后通过 composer 安置的任何第三方代码都会被生成在这里。

二、为什么要单元测试?

只要你想到输入一些东西到print语句或调试表达式中,就用测试代替它。 --Martin Fowler

PHPUnit 是一个用PHP编程说话开发的开源软件,是一个单元测试框架。PHPUnit由Sebastian Bergmann创立,源于Kent Beck的SUnit,是xUnit家族的框架之一。

单元测试是对独自的代码对象停止测试的历程,比方对函数、类、办法停止测试。单元测试可以使用任意一段已经写好的测试代码,也可以使用一些已经存在的测试框架,比方JUnit、PHPUnit或者Cantata++,单元测试框架供给了一系列共同、有用的功效来帮忙人们编写主动化的检测单元,例如检查一个实际的值可否相符我们盼望的值的断言。单元测试框架经常会包括每个测试的报告,乃至给出你已经覆盖到的代码覆盖率。

总之一句话,使用 phpunit 停止主动测试,会使你的代码更强健,减少后期保护的成本,也是一种比力标准的标准,现如今流行的PHP框架都带了单元测试,如Laraval,Symfony,Yii2等,单元测试已经成了标准配置。

别的,单元测试用例是通过命令操控测试足本的,而不是通过阅读器拜访URL的。

三、安置PHPUnit

使用 composer 方式安置 PHPUnit,其他安置方式请看这里

composer require --dev phpunit/phpunit ^6.2

安置 Monolog 日志包,做 phpunit 测试记载日志用。

composer require monolog/monolog

安置好之后,我们可以看coomposer.json 文件已经有这两个扩展包了:

"require": {  
     "monolog/monolog": "^1.23",
    },
"require-dev": {
        "phpunit/phpunit": "^6.2"
    },

四、PHPUnit简便用途

1、单个文件测试

创立名目tests,创建文件 StackTest.php,编纂如下:

<?php
/**
 * 1、composer 安置Monolog日志扩展,安置phpunit单元测试扩展包
 * 2、引入autoload.php文件
 * 3、测试案例
 *
 *
 */
namespace App\tests;
require_once __DIR__ . '/../vendor/autoload.php';
define("ROOT_PATH", dirname(__DIR__) . "/");
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
use PHPUnit\Framework\TestCase;
class StackTest extends TestCase
{
    public function testPushAndPop()
    {
        $stack = [];
        $this->assertEquals(0, count($stack));
        array_push($stack, 'foo');
        // 增加日志文件,假如没有安置monolog,则有关monolog的代码都可以注释掉
        $this->Log()->error('hello', $stack);
        $this->assertEquals('foo', $stack[count($stack)-1]);
        $this->assertEquals(1, count($stack));
        $this->assertEquals('foo', array_pop($stack));
        $this->assertEquals(0, count($stack));
    }
    public function Log()
    {
        // create a log channel
        $log = new Logger('Tester');
        $log->pushHandler(new StreamHandler(ROOT_PATH . 'storage/logs/app.log', Logger::WARNING));
        $log->error("Error");
        return $log;
    }
}

代码说明:

StackTest为测试类

StackTest 继承于 PHPUnit\Framework\TestCase

测试办法testPushAndPop(),测试办法必需为public权限,一样以test开头,或者你也可以选中给其加注释@test来表

在测试办法内,相似于 assertEquals() 这样的断言办法用来对实际值与预测值的匹配做出断言。

命令行施行:

phpunit 命令 测试文件命名

?  framework#  ./vendor/bin/phpunit tests/StackTest.php
// 或者可以省略文件后缀名
//  ./vendor/bin/phpunit tests/StackTest

施行结果:

?  framework# ./vendor/bin/phpunit tests/StackTest.php
PHPUnit 6.4.1 by Sebastian Bergmann and contributors.
.                                                                   1 / 1 (100%)
Time: 56 ms, Memory: 4.00MB
OK (1 test, 5 assertions)

我们可以在app.log文件中查看我们打印的日志信息。

2、类文件引入

Calculator.php

<?php  
class Calculator  
{  
    public function sum($a, $b)  
    {  
        return $a + $b;  
    }  
}  
?>

单元测试类:

CalculatorTest.php

<?php
namespace App\tests;
require_once __DIR__ . '/../vendor/autoload.php';
require "Calculator.php";
use PHPUnit\Framework\TestCase;
class CalculatorTest extends TestCase
{
    public function testSum()
    {
        $obj = new Calculator;
        $this->assertEquals(0, $obj->sum(0, 0));
    }
}

命令施行:

> ./vendor/bin/phpunit tests/CalculatorTest

施行结果:

PHPUnit 6.4.1 by Sebastian Bergmann and contributors.
F                                                                   1 / 1 (100%)
Time: 117 ms, Memory: 4.00MB
There was 1 failure:

假如我们把这里的断言成心写错,$this->assertEquals(1, $obj->sum(0, 0));

看施行结果:

PHPUnit 6.4.1 by Sebastian Bergmann and contributors.
F                                                                   1 / 1 (100%)
Time: 117 ms, Memory: 4.00MB
There was 1 failure:
1) App\tests\CalculatorTest::testSum
Failed asserting that 0 matches expected 1.
/Applications/XAMPP/xamppfiles/htdocs/web/framework/tests/CalculatorTest.php:22
FAILURES!
Tests: 1, Assertions: 1, Failures: 1.

会直接报出办法错误信息及行号,有助于我们快速寻出bug

3、高级用途

你可否已经腻烦了在每一个测试办法命名前面加一个test,可否由于只是调取的参数不一样,却要写多个测试用例而纠结?我最喜爱的高级功效,此刻盛大引荐给你,叫做框架生成器。

Calculator.php

<?php  
class Calculator  
{  
    public function sum($a, $b)  
    {  
        return $a + $b;  
    }  
}  
?>

命令行启动测试用例,使用关键字 --skeleton

> ./vendor/bin/phpunit --skeleton Calculator.php

施行结果:

PHPUnit 6.4.1 by Sebastian Bergmann and contributors.
Wrote test class skeleton for Calculator to CalculatorTest.php.

是不是很简便,由于没有测试数据,所以这里加测试数据,然后从新施行上边的命令

<?php  
class Calculator  
{  
    /** 
     * @assert (0, 0) == 0 
     * @assert (0, 1) == 1 
     * @assert (1, 0) == 1 
     * @assert (1, 1) == 2 
     */  
    public function sum($a, $b)  
    {  
        return $a + $b;  
    }  
}  
?>

原始类中的每个办法都停止@assert注解的检测。这些被改变为测试代码,像这样

    /**
     * Generated from @assert (0, 0) == 0.
     */
    public function testSum() {
        $obj = new Calculator;
        $this->assertEquals(0, $obj->sum(0, 0));
    }

施行结果:

 ./vendor/bin/phpunit tests/CalculatorTest
PHPUnit 6.4.1 by Sebastian Bergmann and contributors. 
  
....  
  
Time: 0 seconds  
  
  
OK (4 tests)

引荐教程:《PHP教程》

以上就是PHP测试框架PHPUnit根本使用的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有153人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板