以前在学习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,编辑如下:

/**

* 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

class Calculator

{

public function sum($a, $b)

{

return $a + $b;

}

}

?>

单元测试类:

CalculatorTest.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

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.

是不是很简单,因为没有测试数据,所以这里加测试数据,然后重新执行上边的命令

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、其他用法

php自动生成phpunit,PHP单元测试框架PHPUnit的使用相关推荐

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

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

  2. PHP单元测试框架PHPUnit的使用

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

  3. c 自动生成html报告,Pytest框架之 - Allure生成漂亮的HTML图形测试报告

    官网介绍 1. Allure Framework是一种灵活的轻量级多语言测试报告工具,不仅可以以简洁的Web报告形式非常简洁地显示已测试的内容,也允许参与开发过程的每个人从日常测试中提取最大程度的有用 ...

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

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

  5. 接口自动化测试框架开发 | Pytest+Allure+AIOHTTP+用例自动生成

    测试开发实战技能进阶学习,文末加群! 近期准备优先做接口测试的覆盖,为此需要开发一个测试框架,经过思考,这次依然想做点儿不一样的东西. 接口测试是比较讲究效率的,测试人员会希望很快能得到结果反馈,然而 ...

  6. pytest单元测试框架基本操作

    pytest 什么是单元测试框架? 单元测试是指在软件开发当中,针对软件的最小单元(函数.方法)进行正确性的检查测试. 单元测试框架主要做什么? 测试发现:从多个文件里面去找到我们测试用例. 测试执行 ...

  7. python color属性_使用Python制作一个带GUI界面的词云自动生成工具(连载七)

    前几篇向大家介绍了词云自动生成工具(GUI)的详解GUI词云自动生成工具中词云属性设置界面的实现(连载六).通过前面内容我们基本构建出了词云自动生成工具的主要框架.本篇结合tkinter中的filed ...

  8. Spring Boot(九)Swagger2自动生成接口文档和Mock模拟数据

    一.简介 在当下这个前后端分离的技术趋势下,前端工程师过度依赖后端工程师的接口和数据,给开发带来了两大问题: 问题一.后端接口查看难:要怎么调用?参数怎么传递?有几个参数?参数都代表什么含义? 问题二 ...

  9. idea swagger生成接口文档_Spring Boot(九)Swagger2自动生成接口文档和Mock模拟数据...

    一.简介 在当下这个前后端分离的技术趋势下,前端工程师过度依赖后端工程师的接口和数据,给开发带来了两大问题: 问题一.后端接口查看难:要怎么调用?参数怎么传递?有几个参数?参数都代表什么含义? 问题二 ...

  10. 如何自动生成『状态机』代码?

    关注.星标公众号,直达精彩内容 来源:网络素材 有限自动机(Finite Automata Machine)是计算机科学的重要基石,它在软件开发领域内通常被称作有限状态机(Finite State M ...

最新文章

  1. 史上最通俗易懂的IPFS入门介绍:01
  2. 【Clion+Pycharm 网络编程】C++实现服务端,Python实现客户端
  3. 系统部署文档_惊喜!Alibaba架构师终于发布“微服务架构与实践”文档
  4. CF535C Tavas and Karafs 二分 + 结论
  5. python下路径问题及模型存储
  6. ipad服务器未响应怎么办,ipad平板连接Win7系统电脑半天没反应如何解决
  7. [翻译]Log Everything All the Time
  8. ubuntu16.04.3 ntp服务
  9. 《MYSQL必知必会》—3~9.使用MySQL、检索数据列、排序检索数据列、过滤数据(WHERE子句、组合WHERE子句、通配符、正则表达式)
  10. 数据预处理中的缺失值问题
  11. 83. 验证码(1)
  12. LinkedList源码解析
  13. 省份城市 mysql_省份城市数据库 mysql
  14. 线性子空间的交、并、和、维数与直和等各种关系总结
  15. iapp卸载指定软件代码,iapp删除文件夹代码
  16. android 直播sdk 抖音,从零开始仿写一个抖音App——跨平台视频编辑SDK项目搭建
  17. 3点钟无眠区块链:96小时聊天内容精华全记录
  18. VMware 打开虚拟机屏幕太小问题解决
  19. 简单的电商分销管理系统介绍
  20. 2-6_Cleaning_Data

热门文章

  1. 6 猜数字游戏 (15分)——数学分析能力
  2. poj - 2586 - Y2K Accounting Bug
  3. 什么是霍尔推进器?只能推动一张纸,却成为多国追捧的黑科技
  4. python怎么算一元二次方程_Python实现求解一元二次方程的方法示例
  5. [经典之作]vml经典之作
  6. 两数之和——python
  7. VMware SDS之11: VMware SPBM之DELL SC(也即Compellent)篇
  8. 判断一个数是否为4的倍数
  9. systemverilog : constraint slove... before 详解
  10. conda安装环境报错:Solving environment: failed with initial frozen solve.