測試一直是軟件開(kāi)發(fā)過(guò)程中的一個(gè)重要過(guò)程,而三個(gè)因素使得它扮演了更重要的角色。首先,微軟.Net的環(huán)境已經(jīng)顯著(zhù)地提高了程序員編寫(xiě)自定義自動(dòng)化測試的能力,以前需要兩周時(shí)間創(chuàng )建的測試項目,現在在.Net Framework下只用幾個(gè)小時(shí)便可完成。第二,程序和系統越趨于復雜,所需的測試就越精密。最后,軟件安全性已不再是程序開(kāi)發(fā)最后才考慮的問(wèn)題,它是絕對必要的。在以前有可能存在一款軟件沒(méi)有經(jīng)過(guò)完整的測試就已向外發(fā)布的情況,但如今這已不再可行。為了幫助你滿(mǎn)足現今的測試挑戰,我將在這個(gè)欄目里每隔幾個(gè)月就向你展示軟件測試的最佳方法、原則和技術(shù)。
這個(gè)月我將從組合在軟件測試中的角色開(kāi)始說(shuō)起。編程產(chǎn)生組合的能力,能夠為你的測試用例輸出提供強有力的方法。首先我談?wù)勎宜f(shuō)的組合的意思:如果你現在正在寫(xiě)一個(gè)撲克牌的程序,需要你手動(dòng)輸入5張牌牌型的所有可能情況,你一定不會(huì )樂(lè )意。但如果你用這個(gè)欄目里的代碼來(lái)處理,你將能夠在幾分鐘內做好這件事:
string[] deck = new string[] { "Ac", "Ad", "Ah", "As", "Kc", (...) }; Combination c = new Combination(52,5); // 52 cards, 5 at a time string[] pokerHand = new string[5]; while (c != null) { pokerHand = c.ApplyTo(deck); PrintHand(pokerHand); c = c.Successor(); } |
在大量的自動(dòng)化測試方案中,你一旦學(xué)習并認識了組合,你會(huì )發(fā)現它驚人的有用。再舉一個(gè)例子,假如你正在測試某個(gè)系統,要用戶(hù)從文本框接收用戶(hù)傳入的10個(gè)字符。用戶(hù)可能會(huì )輸入"ABCDEFGHIJ",或者是")(*&^%$#@!",你想知道共有多少種測試的用例。假定你要求輸入字符的可選類(lèi)型等于20種(這可能根據系統要求的不同而不同,比如從大寫(xiě)的'A'到'Z',或者是從0到9等等)。
要特別強調的是,你必須從20個(gè)不同的字符中一次性選取10個(gè),即Choose(20,10)——這個(gè)函數我會(huì )在稍后解釋。請注意,這里我其實(shí)簡(jiǎn)化了問(wèn)題。實(shí)際上,你可能還需要考慮每個(gè)邊界條件和其他測試概念的排列組合。
現在,我將會(huì )創(chuàng )建一個(gè)C#語(yǔ)言寫(xiě)的的組合類(lèi),并向你展示怎樣用組合來(lái)提高測試的性能。我想你一定會(huì )認為理解并運用組合及其相關(guān)的理論是有價(jià)值的。
原文轉自:http://www.uml.org.cn/Test/201004214.asp