close

測試框架

昨天有寫出一些陽春的測試程式。固然夠用,但若是要做進階的測試方式或是闡明測試過程,明顯要實作出更多功能才能符合需求。但不用憂慮,開源的世界裡有極度多前輩,實作出專為測試利用的框架,讓我們寫測試可以輕鬆良多。
 
開源專案用起來開心的話,不妨去 GitHub 按個 Star 撐持一下吧!
PHP 的測試框架裡,我最常利用的是 Codeception ,它是以 PHPUnit 為根本打造出來的。會經常使用是因為它支援十分多框架與外掛,可以依個人喜愛去調劑。
 

建置情況

使用 PHP 要裝套件的話,首推固然是 Composer 。安裝方法的懶人包以下:
  1. $ curl -sS https://getcomposer.org/installer | php
  2. $ chmod +x composer.phar
複製代碼

 

這兩個指令會產生可執行的 composer.phar ,然後可以直接履行。想要用全域的體例履行需要再下這個指令:(以下會以全域的方式當範例)
  1. $ sudo mv composer.phar /usr/local/bin/composer
複製代碼

 

安裝好後,建個空目錄,進去下指令就可以安裝 Codeception 了:
  1. $ mkdir -p /path/to/project
  2. $ cd /path/to/project
  3. $ composer require --dev codeception/codeception
複製代碼

 

這個指令會產生 composer.json 、 composer.lock 兩個檔案與 vendor 目錄。目前的結構以下:
  1. ProjectRoot:
  2.   - vendor/
  3.   - composer.json
  4.   - composer.lock
複製代碼

 

個中 composer.json 是定義這個專案(也就是這個目錄)所需要安裝的套件為何,可使用 composer require <vendor>/<package> 的指令或手動點竄 JSON 新增。 --dev 參數則是標識表記標幟此套件是開辟階段才會利用。不可能上線了才在測試,一定是開發的時辰測,所以 Codeception 會加 --dev 參數。
當一切就绪時,可以下這個指令確認是不是有安裝成功:
  1. $ php vendor/bin/codecept --version
  2. Codeception version 2.2.7
複製代碼

 

有看到版號的話,恭喜你,情況建好了!
 

初始化目次構造

確定指令可以操作後,接著下這個指令,就會幫你把一起頭的目次都初始化好:
  1. $ php vendor/bin/codecept bootstrap
  2. Initializing Codeception in /Users/miles/GitHub/MilesChou/book-intro-of-ci
  3.  
  4. File codeception.yml created       <- global configuration
  5. tests/unit created                 <- unit tests
  6. tests/unit.suite.yml written       <- unit tests suite configuration
  7. tests/functional created           <- functional tests
  8. tests/functional.suite.yml written <- functional tests suite configuration
  9. tests/acceptance created           <- acceptance tests
  10. tests/acceptance.suite.yml written <- acceptance tests suite configuration
  11. tests/_output was added to .gitignore
  12. ---
  13. tests/_bootstrap.php written <- global bootstrap file
  14. Building initial Tester classes
  15. Building Actor classes for suites: acceptance, functional, unit
  16. -> AcceptanceTesterActions.php generated successfully. 0 methods added
  17. \AcceptanceTester includes modules: PhpBrowser, \Helper\Acceptance
  18. AcceptanceTester.php created.
  19. -> FunctionalTesterActions.php generated successfully. 0 methods added
  20. \FunctionalTester includes modules: \Helper\Functional
  21. FunctionalTester.php created.
  22. -> UnitTesterActions.php generated successfully. 0 methods added
  23. \UnitTester includes modules: Asserts, \Helper\Unit
  24. UnitTester.php created.
  25.  
  26. Bootstrap is done. Check out /Users/miles/GitHub/MilesChou/book-intro-of-ci/tests directory
複製代碼

 

它做了什麼上面都有寫,這部份就不贅述了。不過有兩個處所我個人習慣上會調整:
  • .gitignore 它會新增一行,那行我會刪除
  • 複製檔案 cp ./tests/_output/.gitignore ./tests/_support/_generated/
     
初始化完後,就可以入手下手履行了
  1. $ php vendor/bin/codecept run
複製代碼

 

第一次跑的了局以下:
1.png
固然,我們還沒開始寫測試呢!新增測試的方式如下:
  1. $ php vendor/bin/codecept generate:test unit Number
  2. Test was created in /Users/miles/GitHub/MilesChou/book-intro-of-ci/tests/unit/NumberTest.php
複製代碼

 

它會提醒說,有新增一個測試檔在 tests/unit/NumberTest.php 這裡。裡面預設有一個叫 testMe() 的方法,我們在裡面加一個一定會過的測試看看:
  1. <?php
  2.  
  3. class NumberTest extends \Codeception\Test\Unit
  4. {
  5.     public function testMe()
  6.     {
  7.         $actual = true;
  8.         $this->assertTrue($actual);
  9.     }
  10. }
複製代碼

 

$this->assertTrue($actual) 講白話一點指的是:假設 $actual 這個變數的內容是 true ,若是 false 的話,假設就錯了。以這個例子,這個假設是永久准確的。我們來看履行後果:
2.png
如果看到跟上面一樣成效的話,恭喜你,第一個測試寫好了!

正式寫測試程式

起首要設定 Namespace , PHP 的 namespace 可使用 composer.json 設定,設定檔典範榜樣如下:
  1. {
  2.     "require-dev": {
  3.         "codeception/codeception": "^2.2"
  4.     },
  5.     "autoload": {
  6.         "psr-4": {
  7.             "HelloWorld\\": "src"
  8.         }
  9.     }
  10. }
複製代碼

 

再來先把昨天的 Number 類別加到專案裡,程式以下: (注意要加 namespace)
  1. <?php // src/Number.php
  2.  
  3. namespace HelloWorld;
  4.  
  5. class Number
  6. {
  7.     private $number;
  8.  
  9.     public function __construct($number)
  10.     {
  11.         $this->number = $number;
  12.     }
  13.    
  14.     public function add($addend)
  15.     {
  16.         return $this->number + $addend;
  17.     }
  18.    
  19.     public function sub($subtrahend)
  20.     {
  21.         return $this->number - $subtrahend;
  22.     }
  23.    
  24.     public function get()
  25.     {
  26.         return $this->number;
  27.     }
  28. }
複製代碼

 

目次佈局:(注意 Number.php 檔案位置)
  1. ProjectRoot:
  2.   - src/
  3.     - Number.php
  4.   - tests/
  5.   - vendor/
  6.   - codeception.yml
  7.   - composer.json
  8.   - composer.lock
複製代碼

 

需要注意的是,上面三個都是互有關聯,聯系關系以下:
  • composer.json 檔裡,利用 PSR4 ,設定為 "HelloWorld\\": "src" ,代表 HelloWorld 的 Namespace 會進來 src 找
  • Number.php 自然就是放在 src 下面了
     
設定好以後,下 composer dump-autoload 會從新產生 autoload 規則檔。網頁設計只要程式一最先有載入 vendor/autoload.php ,以後就可以在任何處所 new \HelloWorld\Number() 了。
Codeception 在開始執行前,會先載入 _bootstrap.php 做初始化,如載入 autoload.php 就是一個可以做的事,它的樣板檔也是這麼說的:
  1. <?php // tests/_bootstrap.php
  2. // This is global bootstrap for autoloading
  3.  
  4. require __DIR__ . '/../vendor/autoload.php';
複製代碼

 

再來回到方才的測什麼都能過的測試檔 NumberTest.php ,我們來加第一個真實的測試:
  1. <?php // tests/unit/NumberTest.php
  2.  
  3. class NumberTest extends \Codeception\Test\Unit
  4. {
  5.     public function testShouldGet1WhenConstructArgIs1()
  6.     {
  7.         // Arrange
  8.         $target = new \HelloWorld\Number(1);
  9.         $excepted = 1;
  10.  
  11.         // Act
  12.         $actual = $target->get();
  13.  
  14.         // Assert
  15.         $this->assertEquals($excepted, $actual);
  16.     }
  17. }
  18.  
複製代碼

 

這邊註釋一下:
  • Function 名稱習慣上會寫的很白話,猶如上面所看到的,因為測試結果看到的都是 function 名稱占多數。
  • 測試套件平日會供給很多 assert 供選擇,上例是最經常使用的 assertEquals() ,判斷兩個值是否相等。
     
執行一下,如果看到下面這張圖,代表你第一個測試寫成功了。

 

網頁設計 

3.png

網頁設計
 
Codeception 可以整合的功能許多,不外今天就先把單位測試寫好就好。未來測試會一向加上去,但對開辟者而言,只要下履行指令,它就會把所有測試都掃數跑過,並產生報表說測試有無經由過程,特別很是地方便。
今天的典範榜樣程式可以到這裡下載哦!將來還會延續更新,記得可以用 Git 還原版本。
 


文章來自:
arrow
arrow
    文章標籤
    網頁設計
    全站熱搜
    創作者介紹
    創作者 codym31ccng1 的頭像
    codym31ccng1

    桃園網頁設計

    codym31ccng1 發表在 痞客邦 留言(0) 人氣()