PhalApi推薦使用測試驅(qū)動開發(fā)最佳實(shí)踐,并主要使用的是PHPUnit進(jìn)行單元測試。
PHPUnit官網(wǎng):https://phpunit.de,如需進(jìn)行單元測試,請先安裝PHPUnit。
以下是在PhalApi下簡化后TDD步驟。
當(dāng)新增一個接口服務(wù)時,可先定義好接口服務(wù)的函數(shù)簽名,通俗來說,即確定類名和方法名,以及輸入、輸出參數(shù)、接口服務(wù)的名稱與描述等。
例如,對于獲取評論的接口服務(wù),可以這樣定義。
<?php
namespace App\Api;
use PhalApi\Api;
/**
* 評論服務(wù)
*/
class Comment extends Api {
public function getRules() {
return array(
'get' => array(
'id' => array('name' => 'id', 'type' => 'int', 'require' => true, 'min' => 1, 'desc' => '評論ID'),
),
);
}
/**
* 獲取評論
* @desc 根據(jù)評論ID獲取對應(yīng)的評論信息
* @return int id 評論ID,不存在時不返回
* @return string content 評論內(nèi)容,不存在時不返回
*/
public function get() {
}
}
通過在線接口詳情文檔,可以看到對應(yīng)生成的接口文檔內(nèi)容。
這樣就完成了我們偉大的第一步,是不是很簡單,很有趣?
接下來是為新增的接口類編寫對應(yīng)的單元測試。單元測試的代碼,可以手動編寫,也可以使用phalapi-buildtest腳本命令自動生成。
生成的命令是:
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,可以看到類似以下代碼:
class PhpUnderControl_AppApiComment_Test extends \PHPUnit_Framework_TestCase
{
public $appApiComment;
protected function setUp()
{
parent::setUp();
$this->appApiComment = new App\Api\Comment();
}
protected function tearDown()
{
// 輸出本次單元測試所執(zhí)行的SQL語句
// var_dump(DI()->tracer->getSqls());
// 輸出本次單元測試所涉及的追蹤埋點(diǎn)
// var_dump(DI()->tracer->getSqls());
}
/**
* @group testGet
*/
public function testGet()
{
$rs = $this->appApiComment->get();
$this->assertTrue(is_int($rs));
}
}
生成的骨架只是初步的代碼,還需要手動調(diào)整一下才能最終正常運(yùn)行。例如需要調(diào)整bootstrap.php的文件引入路徑。
require_once dirname(__FILE__) . '/../../bootstrap.php';
最為重要的是,應(yīng)該根據(jù)構(gòu)造-操作-檢驗(yàn)(BUILD-OPERATE-CHECK)模式編寫測試用例。對于Api接口層,還需要依賴[]()進(jìn)行模擬請求。例如這里的:
class PhpUnderControl_AppApiComment_Test extends \PHPUnit_Framework_TestCase
{
public function testGet()
{
// Step 1. 構(gòu)造
$url = 's=Comment.Get';
$params = array('id' => 1);
// Step 2. 操作
$rs = PhalApi\Helper\TestRunner::go($url, $params);
// Step 3. 檢驗(yàn)
$this->assertEquals(1, $rs['id']);
$this->assertArrayHasKey('content', $rs);
}
}
使用phpunit,可以執(zhí)行剛生成的測試文件。執(zhí)行:
phalapi$ phpunit ./tests/app/Api/Comment_Test.php
會看到類似這樣的輸出:
PHPUnit 4.3.4 by Sebastian Bergmann.
.F
Time: 39 ms, Memory: 8.00Mb
There was 1 failure:
1) PhpUnderControl_AppApiComment_Test::testGet
Failed asserting that false is true.
/path/to/phalapi/tests/app/Api/Comment_Test.php:53
FAILURES!
Tests: 2, Assertions: 1, Failures: 1.
在單元測試驅(qū)動的引導(dǎo)下,完成接口服務(wù)的具體功能,例如這里簡單地返回:
<?php
namespace App\Api;
use PhalApi\Api;
class Comment extends Api {
public function get() {
return array('id' => 1, 'content' => '這是一條模擬的評論');
}
}
再次執(zhí)行單元測試,便可通過了。
更多建議: