以前在学习IOS开发时有专门写过Objective-C的单元测试的文章,IOS开发学习之单元测试,今天再总结下怎么在PHP中使用单元测试。

一、前言

在这篇文章中,我们使用 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;}
}

代码解释:

  1. StackTest为测试类
  2. StackTest 继承于 PHPUnit\Framework\TestCase
  3. 测试方法testPushAndPop(),测试方法必须为public权限,一般以test开头,或者你也可以选择给其加注释@test来表
  4. 在测试方法内,类似于 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.00MBOK (1 test, 5 assertions)

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

2、类文件引入

Calculator.php

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

单元测试类:
CalculatorTest.php

<?phpnamespace 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.00MBThere 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.00MBThere was 1 failure:1) App\tests\CalculatorTest::testSum
Failed asserting that 0 matches expected 1./Applications/XAMPP/xamppfiles/htdocs/web/framework/tests/CalculatorTest.php:22FAILURES!
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)  

4、其他用法

其他用法请参考官网:PHPUnit中国官网


参考文章:
PHPUnit中国官网文档

PHP单元测试框架PHPUnit的使用相关推荐

  1. PHP单元测试框架PHPUnit的使用方法

    以前在学习IOS开发时有专门写过Objective-C的单元测试的文章,IOS开发学习之单元测试,今天再总结下怎么在PHP中使用单元测试. 一.前言 在这篇文章中,我们使用 composer 的依赖包 ...

  2. PHP单元测试框架 PHPUnit 提高

    在 入门 的基础上再来看这一篇. 1.使用注释 @test 来标注需要测试的方法 你的测试方法可以是 test 前缀的方法,也可以是包含 @test 注解的方法. public function te ...

  3. python 单元测试_聊聊 Python 的单元测试框架(一):unittest

    本文首发于 HelloGitHub 公众号,并发表于 Prodesire 博客. 前言 说到 Python 的单元测试框架,想必接触过 Python 的朋友脑袋里第一个想到的就是 unittest. ...

  4. python装饰器执行顺序_python unittest单元测试框架-3用例执行顺序、多级目录、装饰器、fixtures...

    1.用例执行顺序 unittest默认会按照ascii码的顺序,依次执行.类名--方法名排序,使用discover也是默认排序.如果不想使用默认排序,就使用testsuite测试集的方式. impor ...

  5. pytest测试框架_聊聊 Python 的单元测试框架(三):最火的 pytest

    本文首发于 HelloGitHub 公众号,并发表于 Prodesire 博客. 一.介绍 本篇文章是<聊聊 Python 的单元测试框架>的第三篇,前两篇分别介绍了标准库 unittes ...

  6. Selenium+Python ---- 免登录、等待、unittest单元测试框架、PO模型

    1.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...

  7. [测试]单元测试框架NUnit

    说到测试,相信大家都或多或少了解. 按照各自分类,就自己知道包括 A.单元测试.集成测试.系统测试 B.白盒测试.黑盒测试 C.压力测试.性能测试.安全测试 ...... 反正是太多太多.就做开发以来 ...

  8. Python单元测试框架Pyunit 的使用

    Python单元测试框架Pyunit 使用示例: 1 import unittest 2 3 class Person: 4 def age(self): 5 return 34 6 def name ...

  9. 单元测试框架之unittest(一)

    一.单元测试的含义 unittest单元测试框架的设计灵感来源于Junit(Java语言的单元测试框架),它与其他语言的单元测试框架风格相类似,支持自动化测试.为测试共享setUp和shutDown. ...

最新文章

  1. HDU 1853 Cyclic Tour
  2. [CF587F]Duff is Mad[AC自动机+根号分治+分块]
  3. 初识Entity Framework CodeFirst(3)
  4. react 拖拽连接插件_一款精美的 react 后台管理系统
  5. Android Service介绍
  6. 很好的PHP分页类(调试过)
  7. java reader类 实例_Java Reader ready()用法及代码示例
  8. Hive小文件问题:如何产生、造成影响、解放办法
  9. 第 二 十 八 天 :LB 负 载 均 衡 搭 建 之 LVS
  10. 遗传算法求解装箱问题c语言,装箱或背包问题? (或者遗传算法解决)
  11. AsteriskNow 实用总结
  12. we8iso8859p1 java_字符集WE8ISO8859P1 是不能改为ZHS16GBK的
  13. 《C陷阱与缺陷》读书笔记与总结
  14. 龙格库塔方法在实际生活中的应用(数值计算Java)
  15. ASO关键词覆盖怎么做?要做到多少?怎么提升aso关键词覆盖率
  16. 基于OXC的光电联动全光网组网方案研究与实践
  17. 高仿富途牛牛-组件化(六)-炒鸡牛逼的布局记忆功能(序列化和反序列化)
  18. 嵌入式linux locale,总结!嵌入式linux基础学习笔记
  19. Android 4.4 KitKat 支持 u 盘功能
  20. Elasticsearch-8.2.0安装问题

热门文章

  1. c51单片机led奇数偶数亮_LED奇数号灯和偶数号灯的交替显示程序详解
  2. Dell shareplex 与HVR数据复制软件
  3. 2021 FDUCTF解题报告
  4. 19万华为人都在用的智能工作平台,你也可以用了
  5. 基于51单片机的下载电路原理
  6. Active Directory概述
  7. 非锐化掩蔽和高提升滤波
  8. C# 将服务器文件批量压缩打包下载至本地两种方法(压缩包缓存到服务器下载、压缩包缓存到内存下载)
  9. 天龙八部服务器列表文件,天龙八部服务端server目录脚本说明.doc
  10. linux创建ftp本地用户名和密码,Vsftpd3.0--FTP服务器搭建之本地用户篇