功能測試、性能測試經驗談

  在當今的軟件測試領域,能夠說,誰掌握了功能測試和性能測試的精髓,誰就能在測試外包市場中佔據技術制高點。本文正是爲這類軟件服務型企業出謀劃策、提供測試技術決策參考。
  雖然功能測試是絕大多數軟件都沒法迴避的,但多數開發企業不諳其中滋味,因此,測試外包市場纔會如此繁榮並且規模日益壯大。目前,功能測試已跨越了單靠手工敲敲鍵盤、點點鼠標就能夠完成的階段,正朝着自動化和智能化方向發展。自動化是指各種測試工具已經獲得日益普遍的應用; 智能化是指測試人員從腳本編制、運行、調試到結果分析乃至測試方案改進,都須要有深刻的瞭解。
  而性能測試的重要性是隨着網絡應用的發展而發展的,因爲網絡環境、數據庫環境、應用服務器環境、系統平臺和技術等的複雜性和多樣性,軟件性能很是難於控制。雖然,改善系統性能不是單單依靠性能測試就能完成的,但性能測試至今還是控制性能的很是有效的手段,在軟件的能力驗證、能力規劃、性能調優、缺陷修復等方面都發揮着重要做用。
  功能測試工具的選擇
  那麼,如何高效地完成功能測試?選擇一款合適的功能測試工具並培訓一支高素質的工具使用隊伍無疑是相當重要的。儘管現階段存在少數不採用任何功能測試工具,從事功能測試外包項目的軟件服務企業。短時間來看,這類企業盈利情況尚可,但長久來看,它們極有可能被自動化程度較高的軟件服務企業取代。
  目前,用於功能測試的工具軟件有不少,針對不一樣架構軟件的工具也不斷推陳出新。這裏重點介紹的是其中一個較爲典型自動化測試工具,即Mercury公司的WinRunner。
  WinRunner是一種用於檢驗應用程序可否如期運行的企業級軟件功能測試工具。經過自動捕獲、檢測和模擬用戶交互操做,WinRunner能識別出絕大多數軟件功能缺陷,從而確保那些跨越了多個功能點和數據庫的應用程序在發佈時儘可能不出現功能性故障。
  WinRunner的特色在於: 與傳統的手工測試相比,它能快速、批量地完成功能點測試; 能針對相同測試腳本,執行相同的動做,從而消除人工測試所帶來的理解上的偏差; 此外,它還能重複執行相同動做,測試工做中最枯燥的部分可交由機器完成; 它支持程序風格的測試腳本,一個高素質的測試工程師能借助它完成流程極爲複雜的測試,經過使用通配符、宏、條件語句、循環語句等,還能較好地完成測試腳本的重用; 它針對於大多數編程語言和Windows技術,提供了較好的集成、支持環境,這對基於Windows平臺的應用程序實施功能測試而言帶來了極大的便利。
  WinRunner的工做流程大體能夠分爲如下六個步驟:( 中國軟件工程網
  1.識別應用程序的GUI
  在WinRunner中,咱們可使用GUI Spy來識別各類GUI對象,識別後,WinRunner會將其存儲到GUI Map File中。它提供兩種GUI Map File模式: Global GUI Map File和GUI Map File per Test。其最大區別是後者對每一個測試腳本產生一個GUI文件,它能自動創建、存儲、加載,推薦初學者選用這種模式。可是,這種模式不易於描述對象的改變,其效率比較低,所以對於一個有經驗的測試人員來講前者不失爲一種更好的選擇,它只產生一個共享的GUI文件,這使得測試腳本更容易維護,且效率更高。
  2.創建測試腳本( 中國軟件工程網
  在創建測試腳本時,通常先進行錄製,而後在錄製造成的腳本中手工加入須要的TSL(與C語言相似的測試腳本語言)。錄製腳本有兩種模式: Context Sensitive和Analog,選擇依據主要在因而否對鼠標軌跡進行模擬,在須要回放時通常選用Analog。在錄製過程當中這兩種模式能夠經過F2鍵相互切換。
  只要看看現代軟件的規模和功能點數就能夠明白,功能測試早已跨越了單靠手工敲敲鍵盤、點點鼠標就能夠完成的階段。而性能測試則是控制系統性能的有效手段,在軟件的能力驗證、能力規劃、性能調優、缺陷修復等方面都發揮着重要做用。
  3.對測試腳本除錯(debug)
  在WinRunner中有專門一個Debug Toolbar用於測試腳本除錯。可使用step、pause、breakpoint等來控制和跟蹤測試腳本和查看各類變量值。( 中國軟件工程網
相關文章
相關標籤/搜索