PHPUnit 在 Windows 下的配置及使用教程

开发 后端
由于我们项目涉及到php,因此需要对php代码进行单元测试。经过一番了解,决定用PHPUnit来测试php。PHPUnit花了不少时间摸索如何配置PHPUnit,看官网的文档也是一把泪。但知道怎么配置后,其实还是很简单的。

由于我们项目涉及到php,因此需要对php代码进行单元测试。经过一番了解,决定用PHPUnit来测试php。PHPUnit花了不少时间摸索如何配置PHPUnit,看官网的文档也是一把泪。但知道怎么配置后,其实还是很简单的。

  • 系统:Windows 10 专业版

  • PHP版本:PHP 5.5.12

  • 服务器工具:WAMPSERVER 2.5

  • PHPUnit版本:PHPUnit 4.8

一、配置PHPUnit

首先到PHPUnit官网(点此进入)下载相应的版本。我们使用的是php 5.5,于是选择PHPUnit 4.8。得到 .phar 文件,并把名字改为 phpunit.phar 。

把该文件放到任意位置。以我自己为例,我把它放到我们项目的目录下,即D:\repository\CourseManagement\mobile_api_test 。

右键 我的电脑 ,选择 属性 。点击左侧的 高级系统设置 。此时弹出 系统属性 ,选择 高级 选项卡,点击右下角的 环境变量 。 在用户变量里面,双击 PATH ,在 变量值 后面添加;D:\repository\CourseManagement\mobile_api_test (注意最前面的分号,路径填存放phpunit.phar的路径)。配置这个是为了在任意位置都能使用PHPUnit,不配置的话,需要在phpunit.phar的路径下才能使用PHPUnit。

官方文档里有一点没有提到,就是php的环境变量也要设置。比如我的 php.exe 在E:\software\wamp\bin\php\php5.5.12 里,那么也要在 PATH 后面添加;E:\software\wamp\bin\php\php5.5.12 。PS:可能是因为我没有安装PHP的IDE,所以一直没有配置它,偶然之间才想到可能要添加这个环境变量。

按快捷键 Win + R ,输入cmd并回车。进入存放phpunit.phar的路径。输入 echo @php "%~dp0phpunit.phar" %* > phpunit.cmd 并回车。接着输入 phpunit --version 并回车。如果得到输出 PHPUnit x.y.z by Sebastian Bergmann and contributors. 则表示配置好了(如果有误,输入exit 并回车,重新来一遍)。如下图:

二、使用PHPUnit进行测试

使用PHPUnit,必须使用  。以login.php为例(位置在D:\repository\CourseManagement\mobile_api ),我们的初始版本是这样的(欢迎吐槽本博客内的代码):

 

  1. <php 
  2.  
  3.     error_reporting(0); 
  4.  
  5.     $workNumber = $_POST["login-user"]; 
  6.     $password = $_POST["login-password"]; 
  7.     $tableName = $_POST["ident"]; 
  8.  
  9.     $con = mysqli_connect("localhost""root""""teacher_class_system"); 
  10.     if (!$con) { 
  11.         die('Could not connect: ' . mysql_error()); 
  12.     } else { 
  13.         mysqli_query($con"SET NAMES utf8"); 
  14.  
  15.         $result = mysqli_query($con"SELECT * FROM $tableName where workNumber = $workNumber and password = $password"); 
  16.         if (mysqli_num_rows($result) < 1) { 
  17.                 echo "false"
  18.         } else { 
  19.                 $result_arr = mysqli_fetch_assoc($result); 
  20.                 echo json_encode($result_arr, JSON_UNESCAPED_UNICODE); 
  21.         } 
  22.     } 
  23.  
  24.     > 

这样没法测试,于是进行一翻修改。首先在 login.php 所在文件夹里建立一个文件夹 classes,并在里面新建 class_login.php ,内容为 login.php 修改后的版本:

 

  1. <php 
  2.  
  3.    class Login { 
  4.        // 测试工具PHPUnit要求一定要在这里给变量默认值,于是默认为空。 
  5.        public function login($workNumber = "",$password = "",$tableName = "") {        
  6.            $con = mysqli_connect("localhost""root""""teacher_class_system"); 
  7.            if (!$con) { 
  8.                die('Could not connect: ' . mysqli_error()); 
  9.            } else { 
  10.                mysqli_query($con, "SET NAMES utf8"); 
  11.  
  12.                $result = mysqli_query($con, "SELECT * FROM $tableName where workNumber = $workNumber and password = $password"); 
  13.                if (!$result || mysqli_num_rows($result) == 0) { 
  14.                    return "false"
  15.                } else { 
  16.                    $result_arr = mysqli_fetch_assoc($result); 
  17.                    return json_encode($result_arr, JSON_UNESCAPED_UNICODE); 
  18.                } 
  19.            } 
  20.        } 
  21.    } 
  22.  
  23.    > 

除此之外,也要修改原来那个 login.php 的内容,修改后如下:

 

  1. <php 
  2.   error_reporting(0); 
  3.  
  4.   require_once './classes/class_login.php'
  5.  
  6.   $workNumber = $_POST["login-user"]; 
  7.   $password = $_POST["login-password"]; 
  8.   $tableName = $_POST["ident"]; 
  9.  
  10.   $log = new Login; 
  11.   $response = $log->login($workNumber,$password,$tableName); 
  12.  
  13.   if($response != "false") { 
  14.       session_start(); 
  15.       $_SESSION['id']=$tableName; 
  16.   } 
  17.  
  18.   echo $response; 
  19.  
  20.   > 

开始写测试文件

我把测试文件放在 D:\repository\CourseManagement\mobile_api_test 这个文件夹内。新建一个文件 `login_test.php’ ,并写入以下代码:

 

  1. <php 
  2.   require_once dirname(__FILE__).'/../mobile_api/classes/class_login.php'
  3.  
  4.   class LoginTest extends PHPUnit_Framework_TestCase { 
  5.       public function testLoginSuccess() { 
  6.           $expected = '{"workNumber":"00001","password":"00001","name":"西瓜","sex":"男","birthday":"20151201","department":"计算机","telephone":"110","email":"git@github.com"}'
  7.  
  8.           $workNumber = '00001'
  9.           $password = '00001'
  10.           $tableName = 'user_teacher'
  11.           $lg = new Login; 
  12.           $actual = $lg->login($workNumber,$password,$tableName); 
  13.  
  14.           $this->assertEquals($expected,$actual); 
  15.       } 
  16.  
  17.       function testLoginFail() { 
  18.           $expected = 'false'
  19.  
  20.           $workNumber = '11111'
  21.           $password = '11111'
  22.           $tableName = 'user_teacher'
  23.  
  24.           $lg = new Login; 
  25.           $actual = $lg->login($workNumber,$password,$tableName); 
  26.           $this->assertEquals($expected,$actual); 
  27.       } 
  28.   } 
  29.  
  30.   > 

执行测试文件

快捷键 Win + R ,输入cmd并回车。进入该测试文件的目录,输入 phpunit login_test.php 执行测试。

简单的测试就完成了。

三、摸索过程

一开始下载PHPUnit,得到 .phar 文件,以为要解压,囧。找了半天才发现有一个能够解压这种文件的网站(点此进入)。然而并没有什么用……

照着官方文档来做,运行时出现错误:

‘php’ 不是内部或外部命令,也不是可运行的程序
或批处理文件。

Google搜索,必应搜索,StackOverFlow搜索,百度搜索,搜到的答案都没有用。

主要是因为他们都默认你已经配置好了PHP环境变量……

***想着是不是之前生成的 phpunit.cmd 有问题?于是查看一下这个文件的内容。突然想到是不是PHP环境变量没设置的原因?打开cmd,输入 php --version 。得到:

‘php’ 不是内部或外部命令,也不是可运行的程序
或批处理文件。

和上面的错误一样!果然是这里的问题。于是把 ;E:\software\wamp\bin\php\php5.5.12 添加到环境变量中。再运行 php --version 得到:

  1. PHP 5.5.12 (cli) (built: Apr 30 2014 11:20:58) 
  2. Copyright (c) 1997-2014 The PHP Group 
  3. Zend Engine v2.5.0, Copyright (c) 1998-2014 Zend Technologies 
  4. with Xdebug v2.2.5, Copyright (c) 2002-2014, by Derick Rethans 

再进入 phpunit.cmd 所在文件夹,运行 phpunit --version。得到:

PHPUnit 4.8.18 by Sebastian Bergmann and contributors.

问题解决!

经过这次的探索,以后碰到”找不到xxx”这种问题的时候,首先会想起环境变量的设置。

比如解决这个问题的同一天下午,我想使用Visual Studio Code的Git功能,但是却得到提示:

***个反应是:我明明安装了msysgit啊。

第二个反应是:会不会是环境变量没配置?打开环境变量配置,果然没有。于是将 git.exe 所在文件夹的路径添加进去。重启visual Studio Code,问题解决!

责任编辑:王雪燕 来源: schaepher
相关推荐

2011-08-25 15:10:49

LUAWindows环境配置

2012-08-17 09:48:55

MongoDB

2010-06-11 17:04:45

php sendmai

2009-07-07 11:17:14

JDK1.4环境配置

2010-07-21 13:11:34

Eclipse Per

2010-07-26 16:28:40

Perl开发环境

2010-05-25 16:03:18

sendmail配置

2010-06-02 16:10:04

php sendmai

2013-04-01 15:42:10

MySQL 5.6Windows

2009-08-24 09:37:03

Windows 7下配

2009-08-19 09:32:49

Windows 7IIS配置ASP配置

2010-06-04 14:12:57

Hadoop开发环境

2012-03-26 09:51:44

安卓开发平台搭建Mac

2010-04-08 15:37:33

2020-11-25 08:41:56

Windows

2010-12-15 13:48:01

Ubuntu 10.1JDKEclipse

2011-08-23 10:19:44

LuaEditplusSciTE

2010-08-03 09:05:55

Flex3SDK

2010-05-26 16:08:11

2011-04-02 14:21:45

MRTGWINDOWS安装
点赞
收藏

51CTO技术栈公众号