作者tkdmaf (皮皮快跑)
看板PHP
標題[分享] 測試導向之於敏捷軟體的實際作為。
時間Thu Dec 9 21:12:53 2010
講理論既然太過文字化,所以我就用程式碼來說明比較快。
就以驗證帳號密碼來做說明好了。
1.功能需求:驗證帳號密碼是否正確。
需求回傳值:false(不正確)、true(正確)
驗證法則:
require('unit_test.php');
require('member.php');
class test_my_function extends unit_test{
function test_run(){
$this->test_member_login();
}
function test_member_login(){
$member = new member;
$account = 'account';
$password = 'password';
$this->unit->run($member->chk_login($account,$password),'is_true',
'function:test_member_login');
}
}
2.開始實作功能:
此時,$member->chk_login()功能並未實作。我們是要求這個測試必須回傳正確的
結果。但之前先讓他傳回false;
class member{
function chk_login($account,$password){
return false;
}
}
3.將實作功能進行功能驗證:
接下來實作功能獲得驗證。
class member{
function chk_login($account,$password){
if($account == 'account' && $password == 'passwor')
return true;
return false;
}
}
4.測試功能無誤,功能本身也開發完成:
然後,執行單元測試,若測試結果為false就表示判斷不符預期,有可能是測試端
給錯值或是被測試物件方法有錯誤,如此即知bug存在而進行修正。
上例的$password =='passwor'少一個字,所以要把d加回去,這樣原本顯示的false
就會變成true。同樣的,可以在測試中修改測試假碼來驗證應當傳回false的情形。
5.將功能實際應用在主要功能:
當測試功能確認無誤時,即可將該功能提供予其他需要登入功能的系統。
而這個測試會被保留,在未來客戶需要進行程式改變時,都可以透過測試來驗證
功能本身是否異常,他會像是一個bug清單一般的列示一個測試list。
如此,保全了軟體開發優異的速度,而測試本身則保障了程式的品質。
再專案即將交付期,也可以透過不斷列示的測試結果來驗證程式功能的正確或是異常。
而經過一段時間(可能數個月,也可能一、兩年甚至更長。),即便客戶要修正功能。
他的維護成本也不會呈現倍數成長,敏捷開發當中的理想值應當逐年只以1.1倍的速
度緩慢成長。
對工程師而言,放假碼→測試→刪除→假功能→假顯示→刪除,這樣的步調可能很
多人都習慣了。對於假功能假資料都是用過即丟。
然而整合這些東西,做為一個測試驗證的功能或資料卻是確保程式開發速度和品質
的優良保證。在未來的異常狀況,也可以透過測試的結果快速的找出bug的問題點。
甚至於,這些測試碼本身,他可以替代需要測試的文件說明。
快速的展示一個高效率的測試驗證。
而當其他的工程師接手專案時,他們儘需要了解每一項測試的結果及如何找出異常。
透過測試驗證程式功能叫做「單元測試」。
而透過測試結果來產生code的方法我們稱之為:測試導向。
他很快、有效率、保障品質......而在XP的書中也有故事講述過這個方法。
僅將此開發方法提供予各位參考。希望能幫大家提昇工作效率和交付良好品質的專案。
△編輯追加延伸閱讀:
功能:提供一個交換二個變數的方法。
測試要求:
function test_swap(){
$a = 5;
$b = 3;
$this->unit->run(($a == 3 && $b == 5),'is_true',
'function:test_variable_swap'
}
功能實作(假設此為member所提供):
function swap(&$a,&$b){
list($a,$b) = array($b,$a);
}
功能測試:
function test_swap(){
$member = new member;
$a = 5;
$b = 3;
$member->swap($a,$b);
$this->unit->run(($a == 3 && $b == 5),'is_true',
'function:test_variable_swap'
}
當此驗證無誤,將測試值換掉做false測試。
測試驗證符合要求,swap()功能實做完成,經測試確保程式執行無誤。
程式品質保證無異常。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 59.104.131.10
※ 編輯: tkdmaf 來自: 59.104.131.10 (12/09 21:13)
※ 編輯: tkdmaf 來自: 59.104.131.10 (12/09 22:11)