測試用例設計——如何提升測試覆蓋率

前言數據庫

  說到測試用例的設計,我想每一個有過測試經歷的測試工程師都會認爲很簡單,不就是:按需求或概要設計,獲得軟件功能劃分圖,而後據此按每一個功能,採用等價類劃分、臨界值、因果圖等方法來設計用例就好了。安全

   但事實上撇開測試數據的設計不談,僅就測試項來講,咱們發現,對同一個項目,有經驗的測試人員,在寫用例或測試時總會有更多的測試考慮點,從而發現更多 的問題;而有些測試人員測試用例的撰寫卻只有那麼三板斧,表面看好象已經把頁面全部信息的測試都考慮到了,實際上卻仍是遺漏了大量測試覆蓋點,致使其測試 出來的程序老是比較脆弱。網絡

  究其緣由,我以爲仍是測試用例的撰寫水平不到位,更確切地說是測試用例的覆蓋度過低。說實話我認爲系統測試用 例真正作到100%覆蓋是很難的。難道說按設計中的功能劃分,每一個功能都寫到了這個用例就覆蓋完整了?錯,這還遠遠不夠。由於咱們知道還有大量的內部處 理、轉換、業務邏輯、相互影響的關係等都是需求或設計中所不會點明的。而這些一方面須要靠測試人員對項目自己的瞭解,另外一方面要靠測試人員的經驗,來一一 找到這些隱藏點並予以測試,才能真正地保證咱們的測試覆蓋度。併發

  因此本文拋開具體的測試數據設計方法,主要從測試覆蓋度的角度來介紹用例設計時,如何才能考慮地更周全,如何才能將隱藏的測試項一一找出,從而使咱們的測試更全面更完整。函數

   想法雖然美好,但是畢竟每一個測試的項目都是各不相同,針對不一樣項目咱們的經驗也會告訴給咱們不一樣的想法,這些想法一般很感性,很難用嚴密的邏輯理論來把 它昇華。所以本文的內容還是很簡陋且不**,只是但願能以本文爲磚,引發你們的思考,一塊兒來補充完善,以使咱們的測試用例設計水平不斷提升。學習

  正文測試

  1、測試用例的切面設計編碼

   所謂測試切面設計,其實就是測試用例大項的劃分。測試用例劃分的經典方法是瀑布模型,也就是從上到下,逐漸細分,大模塊包括小模塊,小模塊包括更小的模 塊。但僅僅如此是不夠的,咱們還要從更多的角度切入系統,從不一樣的角度把系統切分紅一塊一塊的,來進行測試,從而確保測試大項的完整性。加密

  一、功能點切面spa

  這是最多見的切面,一般咱們認爲頁面上的一個按鈕就是一個功能點。而後咱們能夠根據功能的複雜程度,按每一個功能;或一個功能點分多頁;或多個功能點合成一頁來進行用例的撰寫。

  二、特定切面

   除此之外,還有一種特定切面的劃分方法,也是用例撰寫時常常會用到的。所謂的特定切面,就是忽略掉表面上的功能點,而關注測試對象的某一個面。好比咱們 的內部管理系統提供了銷售錄入導入、註冊錄入導入等功能,從菜單劃分上對應了七八個功能點。但這些功能處理後臺有個共同的處理項就是受權記錄的生成,這時 咱們就能夠把「受權記錄生成」單獨拿出來作一個測試項,而在其它測 試項中涉及這一部分的用例就沒必要再一一撰寫。此外象一些界面共通的操做用例單獨寫成一頁,也是一種特定切面。因此若是說將用例按功能點劃分是一種縱向劃分 法,那麼特定切面就是從橫向的角度分析所獲得的切面。在普通功能點劃分上再根據實際狀況設計特定切面,可使咱們的用例閱讀性、理解性、操做性更強。

  三、隱含切面

  這類用例是最容易被忽略的。它每每不是明顯的某個功能項,多是功能項後臺的隱含處理,也多是多個功能項之間的關聯處理,甚至多是在某種特定情形下的處理。這都須要測試人員經過對軟件的學習瞭解,來進行挖掘。

  (1)、後臺功能

   常見的如一些定時自動啓動的服務;以及某種特定狀況下自動執行的操做等。它們在界面上每每是不體現的,但許多在需求設計中仍是會提到,也有一些比較細小 的功能可能會被忽略,就須要測試人員根據對項目的瞭解程度來進行挖掘。因此說一個熟悉項目的和一個不熟悉的測試人員,寫出來的用例就徹底是兩個層次的。

  (2)、完整業務流程的測試

  咱們都知道測試用例的設計是從點、線、面三個層次去考慮的。完整的一個功能項是線,其中的某個按鈕是點,多個相關功能結合成完整業務流就是面。從實際來看這類用例每每被咱們忽略。

   事實上目前公司的軟件原本都是業務型應用軟件,將各類功能從業務流中切割出來單獨寫用例,確定也會有涉及到總體流程的狀況。若不加以區分,將細節與全局 攪在一塊兒,不只思路混亂,也容易考慮不周。所以在系統測試階段,建議用例設計要有分有合,針對具體功能的就只圍着這個功能轉:而在業務流程測試項中,再完 全從總體的業務流角度出發去考慮用例,這樣不只不容易產生疏漏,用例閱讀與執行也更清楚。

  (3)、某種特定狀況下的系統運行

  這類用例的設計每每與系統實際業務狀況密不可分。好比**軟件,一般須要在月尾一天、月頭一天、年尾一天、年頭一天,對全部相關功能中的日期處理進行測試;又好比WIN 2000環境開發測試的系統,要測試在9八、XP、2003等操做系統下是否能運行自如;再有如存在大量動態圖片視頻等的網頁,在普通網速下的展示速度等等。總之就是要儘量從實際應用的角度出發考慮,來進行測試補充。

  (4)、其它相關係統

   即指在當前項目中直接使用的其它成果,包括公司自有的系統模塊、組件、函數;以及**或免費獲得的一些功能組件。對這些內容須要預先與開發組長等討論清 楚,是否須要測試。若時間緊張或其它緣由決定不測的,應在測試計劃中說明。若須要測試的,則具體可根據實際狀況來設計,能夠是經過系統某個功能的測試來涉 及,此時就不須要單獨劃分測試項;若相對比較獨立的,也能夠經過單獨的測試項來對其專門進行測試。

  (5)、除功能測試外的其它測試類型

  包括可靠性、安全性、恢復性、配置安裝測試等等,這些測試類型都是一個單獨的測試項。

  所謂好的開始是成功的一半,保證測試項劃分的完整、合理、正確,會直接影響到本次測試的成效。一般建議該階段工做要花1-2天的時間來考慮,並要在測試過程當中隨着對軟件的深刻了解,不斷進行調整補充。可千萬不要認爲把分析設計中的功能模型圖搬搬過來就能夠了。

 2、詳細用例的設計

  劃分好了測試項,接着就是針對各個測試項,考慮具體的測試用例了。根據測試項的特色,測試用例的設計角度也有所不一樣。下面咱們就來看看一般的功能點測試用例,該從哪些角度出發來進行設計:

  一、功能切面表面用例設計

  (1)、具體功能測試

  根據需求分析設計,按頁面提供的各個功能項,採用黑盒測試的各類方法,設計用例。好比頁面提供了增、刪、改、查功能,那麼這四個功能是否正確實現就是我要驗證的。這是最簡單、最基本,同時也是必須的測試用例,一般咱們的編碼人員自測也就是作到這個程度。^_^

  (2)、組合操做的測試

  這是從上一角度擴展出來的,相對而言也是編碼人員不會去測試的,因此須要測試人員多做考慮。

  所謂組合操做測試,也就是選擇某幾個操做項,按必定的順序進行操做,驗證系統不會出現意外錯誤。固然要將全部功能項排列組合一遍來測試不只沒必要 要,也是不可能的。因此具體要將哪些功能項進行結合,要按怎樣的步驟來操做,仍是須要測試人員根據實際狀況來做設計(因此說在IT業人才就是一切呀,呵 呵:)。

  通常來講咱們會考慮功能項之間的數據是否會存在關聯,如有就須要考慮這種組合了。常見的如查詢功能,須要將各條件逐一累加進行測試;增完的數據 可否改,改完可否刪,刪完可否再增,這之間可否查詢到正確結果;按鈕的連續屢次點擊會否出現異常;有嚴格先後順序要求的幾個操做,嘗試顛倒順序去操做,系 統可否控制等等。

  不只在某功能內部,擴展到有關聯的多個功能項之間,一樣有組合操做測試的存在。如申報完了能才反饋;如申報成功或失敗後再嘗試申報等。固然對於 這類用例既能夠寫到某個功能切面中,也能夠單獨寫到完整業務流程的切面中,這就取決於可能涉及用例的數量了,若關係比較複雜,固然是單獨寫比較好;若也就 是三五個用例數,那就直接在某個功能的用例中補充好了。

  (3)、GUI界面的測試

  這類測試是測試人員的強項,具體測試項目如限長、非法輸入等等,就沒必要贅述了。要提醒的是在測試時,必定要從實際使用者的操做習慣出發。要知道 界面原型所能肯定的也只是頁面的擺放顯示,而實際操做時的控制實現還是編碼人員自行實現的,即便有編碼指南,其所及範圍也是十分有限。而許多編碼人員在用 戶操做方便性上的考慮每每差強人意。因此測試人員就必需要把好這一關。

  (4)、數據初始化狀況測試

  不應爲空的數據是否有校驗;該有默認值的數據默認值是否正確;引用其它功能生成的數據,是否會實時刷新;頁面關閉或系統重啓後,數據的初始化設置等都是這類用例。

  (5)、業務需求實現是否正確

  這類問題每每是因爲咱們的需求說明欠詳細,而編碼人員的需求瞭解程度又較低形成。做爲測試人員天然要對需求進行深入研究,來對軟件實現進行把關。這裏常見的一些關注點有:

  ●數據的長度、類型控制是否合理(好比控制納稅人識別號只能爲數字,但實際業務中是會有字母出現的);

  ●業務邏輯控制是否合理(好比某數據項不提供修改,但實際業務中該數據項常常會須要改動);

  ●提供的實現方式是否合理(好比只在某一頁面提供某數據的獲取功能,但根據業務劃分有些人員不能操做此頁面,卻必需要能看到該數據);

  ●所作的數據控制是否合理(好比必須在A功能中新增數據,而後才能在B功能中操做,但實際業務中有可能會出現相反操做);

  ●所作的數據控制是否完整(如受權的方式有普通按月、有買斷、有按數量控制,那麼當同一企業嘗試同時存在以上幾種受權方式時,系統是否能有必要的控制);

  ●還有其它一些操做細節上的知足(如業務上須要批量操做的數據有否提供批量操做功能、導入失敗的結果文件是否能修改後直接再導入等)。

  對於不知足的需求,經開發組長、需求經理等確認不做修改的,就要做爲軟件的缺限或限制在測試報告中進行說明民。

 二、功能切面隱含測試項用例設計:

  (1)、數據完整性的測試

  當某數據被其它功能引用;或當前功能要引用其它來源的數據,就會涉及到數據完整性的測試。最多見的如被引用的數據刪除了,或關鍵字被修改了,引 用的數據會否出錯;兩個途徑進入的數據會否衝突或重複;此外還有由於相關的幾個功能由不一樣人員編碼,從而致使彼此的控制不一致,如A功能進入的數據在可允 許的**狀況下,到B功能中引用會否異常(最多見如用戶名錄入時容許長度10,但引用到某個單子填寫時容許長度是8,此時就會異常了)。

  (2)、後臺的特殊處理

  是指某功能除了表面所見之外的程序處理。好比訂單錄入,表面所見的就是訂單的保存,但後臺還會有重複數據的判斷、非法數據的處理、業務邏輯上衝 突狀況的處理以及其它種種根據需求設計所特有的處理。又好比備份功能,在備份前可能有數據的清空、備份目錄的清空、備份目標是否存在的校驗、備份文件重複 時的處理等等。相似這些在分析設計中就未必會寫全了,仍是要測試人員多花心思去思考挖掘。

  (3)、功能業務之間的關聯與轉換

  相關聯的幾個功能之間數據的傳遞,會否產生影響。好比新增錄入的某種特殊字符,要查詢時會引發查詢SQL語句異常;又如某下載文件名中存在中文 等字符,下載時因爲編碼問題致使亂碼的出現;再有報表填寫時到小數點後四位,生成報文時會不會被忽略成兩位了等等。象這種問題,一般只能是在每一個功能設計 用例時,儘可能保證用例中的數據能涉及到容許範圍的各類狀況,即充分運用等價類劃分+邊界值的方法設計出各類「稀奇古怪」的數據,並需驗證這些數據從頭流到 尾,都仍是能保持其正確性,而不只僅是在當前功能中正確。

  (4)、從設計實現發掘測試點

  這個就是咱們測試中最難捉的BUG了,它每每是由編碼人員本身在編碼時創造出來的,連設計人員都不會知道。

  好比內部管理系統中,正常的產品,其類別一般是2位數字;若是是模塊,其類別就以產品代碼來取代。這時如何來判斷該產品是模塊呢?最保險的固然 是校驗其產品類別字段的值可否在產品表中找到;也有比較簡單的方法就是直接判斷類別代碼大於2位仍是小於等於2位。此時若能確切知道採用的是哪一種實現方 法,就能夠直接找到其漏洞所在。好比採用後一種方法,當產品類別長度變化時,明顯系統會出錯。那麼即便確認該實現方式不改,測試人員也應將其做爲限制寫入 測試報告,。讓你們知道這個產品類別長度是不能隨意變化的。

  而讓人鬱悶的是,相似這樣的實現,有太多的編碼人員都是隨性處理的,它們細而隱蔽,在系統數據正常狀況下根本不會被發現;而在漫漫的軟件使用道 路中,因爲需求變動等緣由對原有一些設計作維護變化,這種問題就會忽然暴發出來讓人措不及防。因此要杜絕這類漏洞,除了測試人員要作土撥鼠,不停地對軟件 各功能的實現細節進行挖掘外,也要多給編碼人員灌輸完美實現的理念,多用複雜但抗壓性高的代碼,來替代簡單但依賴性強的代碼。

  (5)、併發操做時的測試

  即兩個或多個用戶同時操做同一功能時,會否引發數據的混亂。一般在C/S結構下,若是有同時操做的可能,是須要做此測試的;而在B/S結構下由 於其特殊性,此問題一般難以解決。除非就是某用戶一旦使用過某功能後,在必定時間內鎖定不容許再用,但這也會帶來實際應用中的不便,因此除非是特別核心的 數據,通常咱們也不會去作此控制,固然對於可能出現的併發衝突也就做爲系統的限制進行遺留了。

  三、特定切面用例設計

  所謂特定切面,其實就是從另外一個角度切割出來的用例面,因此具體的用例撰寫方式其實與功能切面是一致的。

  四、隱含切面用例設計

  隱含切面分如下幾種狀況:

  (1)、無界面的後臺功能

  對這類測試項,須要經過參數設置、代碼調用等方式來實現測試,但具體的測試設計其實與普通功能測試並沒有二致。這裏要注意,由於測試時每每前臺、 後臺是分開來分別進行的,而實際運行時二者極可能是交集的,因此測試時要多注意後臺功能的執行與前臺的一些功能執行會否產生衝突?好比後臺有個文件搬運的 服務,那有沒有可能在前臺文件生成過程當中,後臺執行文件搬運了?如有可能就要注意會否出現問題了。

  (2)、與業務流相關的測試

  這類測試用例的設計,就要從完整業務角度來設計數據了。從理論上來說,應該要將各個功能可能出現的各類數據排列組合到一塊兒,按業務流程逐一進行 測試。但實際上咱們不可能去作全覆蓋。因此設計這類用例時,最好有一張草稿,將全部相關功能按業務流程逐一列示,而後再將每一個功能可能出現的特定數據一一 標上,最後將圖中最可能出現的、最可能出錯的、最核心的數據取出來,分別組合成一個個完整的業務數據用例,來進行測試。這樣就能夠按清晰的思路,找出最實 用、最有效的測試數據。

  (3)、其它測試類型

  這一類的測試一般都有其特定的方法。如要測可靠性就準備大量數據不停地執行;要測安全性就考慮數據的加密、數據的傳輸、數據的破壞;恢復性通常 從網絡、電源方面着手;配置安裝則根據系統可支持的配置,搭建相應環境進行功能驗證,此處的驗證也要掌握技巧,即要多測試那些涉及到:數據庫讀寫、磁盤文 件讀寫、文件上傳下載、文件加解密、數據統計、圖表展示、打印等方面的功能。

 3、測試數據的設計

  每個測試思路最終都要轉化成具體的數據才能來執行。關於測試數據設計的方法也不外乎那幾種,就再也不贅述了。此處單就一些常常易犯的錯誤,提出一些注意點,做爲用例數據設計時的參考:

  一、儘可能避免可能出現歧義測試結果的數據:即你設計的數據必須能惟一正確地反映出你所但願測試的結果。好比一組測試數據,有可能獲得結果A或結果B,此時單用此數據來測試預期結果爲A的用例,那明顯就產生了歧義。

  二、對於不便具體列示的數據,則必須詳細描述其各項特性:有時咱們在設計用例時爲節約時間,不必定要到具體的一個數值,這也是容許的,但前提是 你必需要詳細描述清楚你要測試的數據特性。好比數據庫字段限長20,要測試超長數據時,能夠描述爲:嘗試輸入長度爲21位的半角英文字符;嘗試輸入長度爲 19位的半角英文字符,而後切換到中文全角再輸入一位全角字符等。千萬不能寫成:嘗試輸入超長字符,由於這隻能是測試方案,做爲方案是能夠這樣寫,但到用 例階段,必需要是具體的、明確的、可操做的。

  三、測試數據的設計必須有明確目的性:即測試數據是從測試方案衍生而來的。如上例測試方案是測超長字符輸入控制,因此測試數據就要根據具體字段 長度來錄入超長數據,若是一味錄入長15位、長16位的數據那就沒意義了。好的測試數據是能夠同時針對多個測試方案的,此時能夠在用例邊註明一下該數據的 測試目的,由於隨着時間推移,對着具體的數據你也許會忘了它究竟是測什麼的,而這對你最後總結測試,查驗測試覆蓋率是很是不利的,因此隨時記下你的思路想 法吧,好記性不如爛筆頭。

  四、測試數據可省略描述:測試數據描述以能讓人看懂爲準則。因此寫用例時當碰到連續幾個用例,僅某幾個關鍵數據值改動,其他均是同樣的狀況下, 沒必要每一個用例都要重複描述全部數據,能夠在第一個用例描述完整以後,其他用例中僅列示不一樣的數據,並標明其他數據同上第X個用例,便可。這樣測試時仍能復 原測試數據,且該用例的測試目的一眼就明,增長了用例的清晰性。

  至些,我根據測試用例設計的順序,從測試數據的切面設計(即測試項劃分),到詳細測試用例設計,再到測試數據設計三個層面,逐一介紹瞭如何來提 高測試用例的覆蓋度。由於具體項目中的具體狀況太多,以上敘述的內容也只能是管窺蠡測。至於其中的疏漏錯誤之處應也不免,只但願各位閱後能打開思路,從自 己多年的測試經驗中多總結、提煉出一些想法思路,進一步補充完善這個文檔,使你們的測試用例設計能力都能進一步提高。

相關文章
相關標籤/搜索