讓loadrunner走下神壇
無疑是一個強(qiáng)大有力的壓力測試工具。它的腳本可以錄制生成,自動關(guān)聯(lián);測試場景可以面向指標(biāo),多方監(jiān)控;測試結(jié)果圖表顯示,拆分組合。相信有人這樣想象過:拿著一張性能指標(biāo)標(biāo)準(zhǔn)列表和測試數(shù)據(jù)相比較,如同PH試紙一樣,遇堿則藍(lán),遇酸則紅,一目了然,之后就可以大聲地喊道:我找到了軟件系統(tǒng)的性能瓶頸!
然而,我們無論在loadrunner前面加多少個“強(qiáng)大”、“智能”的形容詞,別忘了其最終修飾的只是一個名詞-“工具”!洞笤捨饔巍分幸灿邢喈(dāng)精辟的論斷:官兵?最多也只是個長了痔瘡的官兵!把loadrunner比喻成長了痔瘡的官兵有點(diǎn)粗俗,但loadrunner它是個工具,那么是否能夠找到性能瓶頸就取決于使用工具的人,而不是工具本身。要做一個成功的性能測試,僅讀懂和精通了loadrunner的使用手冊是不夠的,還需要對被測軟件系統(tǒng)的方方面面都要有了解,比如軟件體系構(gòu)架,網(wǎng)絡(luò)拓?fù)涞戎R。這就如同一個技藝高超的木匠,并不是因?yàn)樗呈炝髓徸,錘子的說明書,而是他能結(jié)合木材的質(zhì)地和尺寸,用鑿子和錘子這些工具做出一把精巧的椅子來。那么在性能測試中,人的智慧活動體現(xiàn)在哪里呢?
一、首先性能測試也是測試的一種,這就意味著做性能測試也要寫測試案例。你所作的性能測試能不能足以支持找出性能測試瓶頸,和你在初期設(shè)計(jì)的測試案例關(guān)系甚為重要。我曾寫過對一個軟件系統(tǒng)的不下十個性能測試場景案例,等后來運(yùn)行時卻發(fā)現(xiàn)我必須增補(bǔ)幾個案例才能找到瓶頸,而原來十多個案例其實(shí)重復(fù)甚多。如果你要寫出好的不重復(fù)的性能測試案例來,你就得對被測軟件系統(tǒng)有一定的了解。
在這里,我順便插一句,在目前測試界總在爭論測試人員需不需要懂編程,需不需要有開發(fā)經(jīng)驗(yàn)這種問題,這完全是本末倒置,忘記了測試人員的目標(biāo)是什么,測試目標(biāo)就是寫出好的測試案例,好的測試案例就是發(fā)現(xiàn)了一個原來未曾發(fā)現(xiàn)的軟件bug。那么一個測試人員知識體系是否夠用的標(biāo)準(zhǔn)就是能不能寫出一個好的測試案例。而針對不同類型的測試,所需的知識深度是不一樣的,有的是不需編程知識,比如界面測試;有的是必須有開發(fā)經(jīng)驗(yàn)的,比如接口測試,不能一概而論。
對于性能測試來講,我個人認(rèn)為,測試人員倒不一定非要有開發(fā)經(jīng)驗(yàn),但是應(yīng)該有一個對軟件體系結(jié)構(gòu)了解全面的知識。為什么呢?做性能測試時,如果從客戶端施壓一次就符合性能指標(biāo),碰到這種情況您就偷著樂吧,因?yàn)樵谀愕闹笜?biāo)場景下,軟件系統(tǒng)中就不存在性能瓶頸,您也就不用費(fèi)心去找了。但是大多數(shù)情況下,我們在做性能測試時,都不能順利達(dá)到性能指標(biāo),可能server響應(yīng)超時了,也可能是用戶死掉了,在日志里拋出了一堆error,這種情形是非常常見,所以在我們在一開始設(shè)計(jì)性能測試方案時,就應(yīng)該考慮為尋找性能瓶頸而設(shè)計(jì)測試案例。這時我們就需要知道在整個軟件系統(tǒng)中,有哪些節(jié)點(diǎn),在哪些地方可能存在瓶頸,比如一個B/S系統(tǒng)就有IE client→物理網(wǎng)絡(luò)→web server→app server→DB這樣的一個壓力流串。每個節(jié)點(diǎn)的每個模塊都有可能成為瓶頸。瓶頸的產(chǎn)生可能由于模塊配置引起,也可能由于模塊本身引起。這都需要我們設(shè)計(jì)測試案例來發(fā)現(xiàn)的。一般地,我自己常用的感覺也比較方便的方法是,設(shè)計(jì)一組性能測試案例來驗(yàn)證一個節(jié)點(diǎn)是否存在瓶頸,這組case中盡量保持其他節(jié)點(diǎn)不變,來改變這個節(jié)點(diǎn)的配置,并監(jiān)控此節(jié)點(diǎn)的各種指標(biāo)。這里說起來就有很多話了,不是一言兩語能說得清的。以后有時間可以找個專題來慢慢跟大家討論。
二、使用loadrunner的VU生成腳本。腳本的生成方式就兩種,一種是自寫或嵌入源代碼,一種是錄制生成。常常聽見有人說,這兩種方式中首選錄制生成腳本,因?yàn)樗唵吻抑悄芑。但我個人總覺得手寫腳本要好一些,因?yàn)椋?/P>
1 .可讀性好,流程清晰,檢查點(diǎn)截取含義明確。業(yè)務(wù)級的代碼讀起來總比協(xié)議級的代碼更易讓人理解,也更容易維護(hù),必要時可建立一個腳本庫。而錄制生成的代碼大多沒有維護(hù)的價值,現(xiàn)炒現(xiàn)賣。
2 .手寫的程序相比錄制的腳本更能真實(shí)地模擬應(yīng)用運(yùn)行。因?yàn)殇浿频哪_本是截獲了網(wǎng)絡(luò)包,生成了協(xié)議級的代碼,而略掉了client端的處理邏輯。舉個例子,用VU錄制一個運(yùn)行script和applet的IE行為,它只會生成http協(xié)議的API,在IE中運(yùn)行的applet和script不會被模擬到,這就不是一個完整的系統(tǒng)。
3 .手寫程序相比錄制腳本更能增加測試人員的技術(shù)含量。開發(fā)和測試能力雙重提高,何樂而不為呢?loadrunner提供了java user,vb user,c user等語言類型的腳本,就是給我們開發(fā)腳本用的,而不是錄制用的。
腳本不管錄制也好,還是手寫也好,選擇的時候應(yīng)該以腳本模擬程序真實(shí)有效為準(zhǔn),結(jié)合項(xiàng)目進(jìn)度,開發(fā)難易程度等因素考慮。
在這里我想要說的是,開發(fā)一個好的腳本是成功性能測試的必要條件。一個好的腳本應(yīng)該能夠最大程度再現(xiàn)client程序行為。如上面那個例子,腳本只模擬了client端的部分行為,有一些沒有模擬到,那么client的瓶頸就有可能被忽略了。我曾吃過一個虧,自己寫了一個java socket腳本去聯(lián)server,但是忽略了client端的界面下的業(yè)務(wù)邏輯,用我的腳本做性能測試通過,全部OK,但是真實(shí)用戶一上線,client終端界面接受了大量的server信息,導(dǎo)致client進(jìn)程死掉了。痛哉,痛哉。
相關(guān)推薦:考試吧策劃:2010年軟件水平考試完全指南北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |