1.8 PhalApi 2.x 單元測試

2018-07-28 21:23 更新

PhalApi 2.x 單元測試

測試驅(qū)動開發(fā)與PHPUnit

PhalApi推薦使用測試驅(qū)動開發(fā)最佳實(shí)踐,并主要使用的是PHPUnit進(jìn)行單元測試。

PHPUnit官網(wǎng):https://phpunit.de,如需進(jìn)行單元測試,請先安裝PHPUnit。

以下是在PhalApi下簡化后TDD步驟。

定義接口服務(wù)的函數(shù)簽名

當(dāng)新增一個(gè)接口服務(wù)時(shí),可先定義好接口服務(wù)的函數(shù)簽名,通俗來說,即確定類名和方法名,以及輸入、輸出參數(shù)、接口服務(wù)的名稱與描述等。

例如,對于獲取評論的接口服務(wù),可以這樣定義。

  1. <?php
  2. namespace App\Api;
  3. use PhalApi\Api;
  4. /**
  5. * 評論服務(wù)
  6. */
  7. class Comment extends Api {
  8. public function getRules() {
  9. return array(
  10. 'get' => array(
  11. 'id' => array('name' => 'id', 'type' => 'int', 'require' => true, 'min' => 1, 'desc' => '評論ID'),
  12. ),
  13. );
  14. }
  15. /**
  16. * 獲取評論
  17. * @desc 根據(jù)評論ID獲取對應(yīng)的評論信息
  18. * @return int id 評論ID,不存在時(shí)不返回
  19. * @return string content 評論內(nèi)容,不存在時(shí)不返回
  20. */
  21. public function get() {
  22. }
  23. }

通過在線接口詳情文檔,可以看到對應(yīng)生成的接口文檔內(nèi)容。

這樣就完成了我們偉大的第一步,是不是很簡單,很有趣?

phalapi-buildtest自動生成測試代碼

接下來是為新增的接口類編寫對應(yīng)的單元測試。單元測試的代碼,可以手動編寫,也可以使用phalapi-buildtest腳本命令自動生成。

生成的命令是:

  1. phalapi$ ./bin/phalapi-buildtest ./src/app/Api/Comment.php App\\Api\\Comment > ./tests/app/Api/Comment_Test.php

保存的測試文件,統(tǒng)一放在tests目錄下,保持與產(chǎn)品代碼結(jié)構(gòu)平行,并以“_Test.php”為后綴。

查看生成的單元測試代碼文件./tests/app/Api/Comment_Test.php,可以看到類似以下代碼:

  1. class PhpUnderControl_AppApiComment_Test extends \PHPUnit_Framework_TestCase
  2. {
  3. public $appApiComment;
  4. protected function setUp()
  5. {
  6. parent::setUp();
  7. $this->appApiComment = new App\Api\Comment();
  8. }
  9. protected function tearDown()
  10. {
  11. // 輸出本次單元測試所執(zhí)行的SQL語句
  12. // var_dump(DI()->tracer->getSqls());
  13. // 輸出本次單元測試所涉及的追蹤埋點(diǎn)
  14. // var_dump(DI()->tracer->getSqls());
  15. }
  16. /**
  17. * @group testGet
  18. */
  19. public function testGet()
  20. {
  21. $rs = $this->appApiComment->get();
  22. $this->assertTrue(is_int($rs));
  23. }
  24. }

生成的骨架只是初步的代碼,還需要手動調(diào)整一下才能最終正常運(yùn)行。例如需要調(diào)整bootstrap.php的文件引入路徑。

  1. require_once dirname(__FILE__) . '/../../bootstrap.php';

完善單元測試用例

最為重要的是,應(yīng)該根據(jù)構(gòu)造-操作-檢驗(yàn)(BUILD-OPERATE-CHECK)模式編寫測試用例。對于Api接口層,還需要依賴[]()進(jìn)行模擬請求。例如這里的:

  1. class PhpUnderControl_AppApiComment_Test extends \PHPUnit_Framework_TestCase
  2. {
  3. public function testGet()
  4. {
  5. // Step 1. 構(gòu)造
  6. $url = 's=Comment.Get';
  7. $params = array('id' => 1);
  8. // Step 2. 操作
  9. $rs = PhalApi\Helper\TestRunner::go($url, $params);
  10. // Step 3. 檢驗(yàn)
  11. $this->assertEquals(1, $rs['id']);
  12. $this->assertArrayHasKey('content', $rs);
  13. }
  14. }

執(zhí)行單元測試

使用phpunit,可以執(zhí)行剛生成的測試文件。執(zhí)行:

  1. phalapi$ phpunit ./tests/app/Api/Comment_Test.php

會看到類似這樣的輸出:

  1. PHPUnit 4.3.4 by Sebastian Bergmann.
  2. .F
  3. Time: 39 ms, Memory: 8.00Mb
  4. There was 1 failure:
  5. 1) PhpUnderControl_AppApiComment_Test::testGet
  6. Failed asserting that false is true.
  7. /path/to/phalapi/tests/app/Api/Comment_Test.php:53
  8. FAILURES!
  9. Tests: 2, Assertions: 1, Failures: 1.

實(shí)現(xiàn)接口服務(wù)

在單元測試驅(qū)動的引導(dǎo)下,完成接口服務(wù)的具體功能,例如這里簡單地返回:

  1. <?php
  2. namespace App\Api;
  3. use PhalApi\Api;
  4. class Comment extends Api {
  5. public function get() {
  6. return array('id' => 1, 'content' => '這是一條模擬的評論');
  7. }
  8. }

再次執(zhí)行單元測試,便可通過了。

溫馨提示:以上示例代碼可從這里查看。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號