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

來源:互聯網
上載者:User

由於我們項目涉及到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,問題解決!

【責任編輯:wangxueyan TEL:(010)68476606】


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.