![軟件工程-軟件測試ppt課件_第1頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/5/eb5c430e-3616-4c6c-8237-aecf6bd9a905/eb5c430e-3616-4c6c-8237-aecf6bd9a9051.gif)
![軟件工程-軟件測試ppt課件_第2頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/5/eb5c430e-3616-4c6c-8237-aecf6bd9a905/eb5c430e-3616-4c6c-8237-aecf6bd9a9052.gif)
![軟件工程-軟件測試ppt課件_第3頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/5/eb5c430e-3616-4c6c-8237-aecf6bd9a905/eb5c430e-3616-4c6c-8237-aecf6bd9a9053.gif)
![軟件工程-軟件測試ppt課件_第4頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/5/eb5c430e-3616-4c6c-8237-aecf6bd9a905/eb5c430e-3616-4c6c-8237-aecf6bd9a9054.gif)
![軟件工程-軟件測試ppt課件_第5頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/5/eb5c430e-3616-4c6c-8237-aecf6bd9a905/eb5c430e-3616-4c6c-8237-aecf6bd9a9055.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、軟件生存周期軟件生存周期可行性研究可行性研究需求分析需求分析概要設(shè)計概要設(shè)計詳細設(shè)計詳細設(shè)計編編 碼碼集成測試集成測試確認測試確認測試使用與維護使用與維護退役退役軟件定義軟件定義軟件開發(fā)軟件開發(fā)軟件使用軟件使用與維護與維護軟件生命周期軟件生命周期防不勝防的軟件錯誤防不勝防的軟件錯誤 例:例:1963年年, 美國美國, 飛往火星的火箭爆炸飛往火星的火箭爆炸, 損失損失$ 10 million. 緣由緣由: FORTRAN循循環(huán)環(huán) DO 5 I = 1, 3 誤寫為誤寫為 DO 5 I = 1.3軟軟 件件 測測 試試 (Testing)軟件測試是保證軟件質(zhì)量的關(guān)鍵步驟,是對軟件規(guī)軟件測試是保證軟
2、件質(zhì)量的關(guān)鍵步驟,是對軟件規(guī)格說明、設(shè)計和編碼的最后復審,其工件量約占總格說明、設(shè)計和編碼的最后復審,其工件量約占總工作量工作量40%以上對于人命關(guān)天的情況,測試相當以上對于人命關(guān)天的情況,測試相當于其它部分總成本的于其它部分總成本的3 5倍)。倍)。1. 基本概念基本概念1、定義:測試是為了發(fā)現(xiàn)程序中的錯誤而執(zhí)行程序、定義:測試是為了發(fā)現(xiàn)程序中的錯誤而執(zhí)行程序的過程。的過程。留意:留意: 只能盡可能查錯,不能證明程序中只能盡可能查錯,不能證明程序中 沒有錯;沒有錯; 測試員與程序員不應是同一個人。測試員與程序員不應是同一個人。2、黑盒和白盒測試、黑盒和白盒測試 黑盒測試黑盒測試(black-
3、box , or closed-box testing): 不考慮程序內(nèi)部的結(jié)構(gòu),只觀察程序的入不考慮程序內(nèi)部的結(jié)構(gòu),只觀察程序的入口和出口,是否能完成規(guī)格要求的輸入輸出口和出口,是否能完成規(guī)格要求的輸入輸出. 功能測試功能測試 白盒測試白盒測試(white-box , or open-box, clear-box testing): 程序的結(jié)構(gòu)和處理過程象白盒子一樣透明程序的結(jié)構(gòu)和處理過程象白盒子一樣透明. 結(jié)構(gòu)測試結(jié)構(gòu)測試1. 基本概念基本概念141416161616161610103 32 22 22 2若程序執(zhí)行需若程序執(zhí)行需10-3秒,則對于所有合法輸入秒,則對于所有合法輸入的測試大
4、約需用一萬年,而且還應測試輸入非法的測試大約需用一萬年,而且還應測試輸入非法數(shù)據(jù)的情況。數(shù)據(jù)的情況。主要問題:窮盡測試主要問題:窮盡測試(complete test)通常是不可能的。通常是不可能的。例:例:(Black-box) 程序要求輸入程序要求輸入3個整形數(shù)據(jù)。若字長個整形數(shù)據(jù)。若字長16位,則各種可能輸入的排列組合共有位,則各種可能輸入的排列組合共有 (種)(種)例:例:(White-box) 下圖所示的程序中共有下圖所示的程序中共有 5201014條可能的執(zhí)行通路,顯然,每條條可能的執(zhí)行通路,顯然,每條通路都執(zhí)行一遍是不現(xiàn)實的。通路都執(zhí)行一遍是不現(xiàn)實的。1. 基本概念基本概念循環(huán)循環(huán)
5、2020次次3、測試步驟:、測試步驟:(1) 單元測試單元測試 程序設(shè)計程序設(shè)計 & 編碼編碼 bugs(2) 集成測試集成測試 模塊之間的連接模塊之間的連接(3) 系統(tǒng)測試系統(tǒng)測試 需求需求 & 系統(tǒng)設(shè)計系統(tǒng)設(shè)計(4) 驗收測試驗收測試 用戶參與用戶參與(5) 平行測試平行測試 新老系統(tǒng)進行比較新老系統(tǒng)進行比較.綜合綜合測試測試1. 基本概念基本概念測試階段的信息流:測試階段的信息流:測試測試評價評價調(diào)試調(diào)試可靠性可靠性模型模型軟件配置軟件配置測試配置測試配置測試結(jié)果測試結(jié)果可靠性預測可靠性預測錯錯 誤誤正正 確確錯誤率數(shù)據(jù)錯誤率數(shù)據(jù)預期結(jié)果預期結(jié)果2. 單元測試白盒)單元測
6、試白盒)主要測試以下五個方面:主要測試以下五個方面:1、模塊接口:、模塊接口: 內(nèi)部檢查:傳輸參數(shù)的數(shù)目、屬性、單位、內(nèi)部檢查:傳輸參數(shù)的數(shù)目、屬性、單位、次序是否匹配;全程變量的定義是否一致;只次序是否匹配;全程變量的定義是否一致;只做輸入的變元有無被修改,等等。做輸入的變元有無被修改,等等。 外部檢查:翻開、終了、關(guān)閉文件的操作;外部檢查:翻開、終了、關(guān)閉文件的操作;文件和屬性;文件和屬性;IO錯誤處理;輸出拼寫,等等。錯誤處理;輸出拼寫,等等。2、局部數(shù)據(jù)結(jié)構(gòu):、局部數(shù)據(jù)結(jié)構(gòu): 數(shù)據(jù)說明數(shù)據(jù)說明(declaration);初始化與缺省值的設(shè);初始化與缺省值的設(shè)置;變量名拼寫;數(shù)據(jù)類型的相
7、容性;上置;變量名拼寫;數(shù)據(jù)類型的相容性;上下溢下溢出及地址異常,等等。出及地址異常,等等。2.單元測試單元測試3、重要的執(zhí)行通路:、重要的執(zhí)行通路: 由于窮盡測試不可能,故通常針對最常見的由于窮盡測試不可能,故通常針對最常見的錯誤設(shè)計測試方案。錯誤設(shè)計測試方案。4、出錯處理通路:、出錯處理通路: 預見出現(xiàn)錯誤的條件,設(shè)置處理。預見出現(xiàn)錯誤的條件,設(shè)置處理。5、邊界條件、邊界條件 單元測試中最后,也可能是最重單元測試中最后,也可能是最重要的任務,因為軟件常在其邊界失效。要的任務,因為軟件常在其邊界失效。1、代碼審查、代碼審查(code inspection) 徹底檢查徹底檢查: 例如例如 Lu
8、cent Technologies 的測試策略,的測試策略,是由三人一組是由三人一組(包括包括 author, reader, 和和recorder),逐行檢查源代碼。逐行檢查源代碼。 演習:由人扮演演習:由人扮演computer,模擬執(zhí)行情況。,模擬執(zhí)行情況。2.單元測試單元測試優(yōu)點優(yōu)點: 一次審查可發(fā)現(xiàn)多個錯誤,不必改一個測一個。一次審查可發(fā)現(xiàn)多個錯誤,不必改一個測一個。單元測試的主要手段單元測試的主要手段 :2、制作測試軟件:、制作測試軟件:Stub (存根和(存根和 Driver驅(qū)動驅(qū)動軟件的編寫,屬額外開支。模塊高內(nèi)聚可簡化這一軟件的編寫,屬額外開支。模塊高內(nèi)聚可簡化這一過程。過程。
9、3. 集成測試集成測試 (Integration Testing)1、非漸增式測試、非漸增式測試 (Big-bang testing)Test A,B, C, DTestATestBTestCTestD3.集成測試集成測試兩種方式的比較:兩種方式的比較: Incremental testing 可以較早發(fā)現(xiàn)模塊間的接口錯可以較早發(fā)現(xiàn)模塊間的接口錯誤;誤;Big-bang testing 最后才組裝,因此錯誤發(fā)現(xiàn)得最后才組裝,因此錯誤發(fā)現(xiàn)得晚。晚。 Big-bang testing 中發(fā)現(xiàn)錯誤后難以診斷定位;中發(fā)現(xiàn)錯誤后難以診斷定位; Incremental testing 中,出現(xiàn)的錯誤往往跟
10、最新加中,出現(xiàn)的錯誤往往跟最新加入的模塊有關(guān)。入的模塊有關(guān)。 Incremental testing 在不斷集成的過程中使模塊不在不斷集成的過程中使模塊不斷在新的條件下受到新的檢測,測試更徹底。斷在新的條件下受到新的檢測,測試更徹底。 Incremental testing 較較 Big-bang testing 費時。費時。 Big-bang testing 可以同時并行測試所有模塊,能充可以同時并行測試所有模塊,能充分利用人力。分利用人力。2、漸增式測試、漸增式測試 (Incremental testing) 自頂向下測試自頂向下測試第第1步:測試頂端模塊,用存根程序步:測試頂端模塊,用存
11、根程序(stub)代替直接附屬的下層模塊代替直接附屬的下層模塊 Stub: 模擬未測試模塊的活動模擬未測試模塊的活動.3.集成測試集成測試3、Incremental testing 的幾種策略的幾種策略MS1S2第第2步:根據(jù)深度優(yōu)先或?qū)挾葍?yōu)先的策略,每次步:根據(jù)深度優(yōu)先或?qū)挾葍?yōu)先的策略,每次用一個實際模塊代換一個用一個實際模塊代換一個stub。3.集成測試集成測試第第3步:在結(jié)合進一個模塊的同時進行測試。步:在結(jié)合進一個模塊的同時進行測試。MS1S2M1S3S4M2S2第第4步:回歸測試步:回歸測試(regression testing)全部或全部或部分地重復以前做過的測試。部分地重復以前做
12、過的測試。 自底向上測試自底向上測試第第1步:把低層模塊組合成族,每族實現(xiàn)一個子功能。步:把低層模塊組合成族,每族實現(xiàn)一個子功能。第第2步:用驅(qū)動程序步:用驅(qū)動程序(Driver)協(xié)調(diào)測試數(shù)據(jù)的協(xié)調(diào)測試數(shù)據(jù)的IO,測,測試子功能族。試子功能族。3.集成測試集成測試優(yōu)點:在早期即對主要控制及關(guān)鍵的抉擇進行檢驗。優(yōu)點:在早期即對主要控制及關(guān)鍵的抉擇進行檢驗。問題:問題:Stub只是對低層模塊的模擬,測試時沒有重只是對低層模塊的模擬,測試時沒有重要的數(shù)據(jù)自下往上流,許多重要的測試須推要的數(shù)據(jù)自下往上流,許多重要的測試須推遲進行,而且在早期不能充分展開人力。遲進行,而且在早期不能充分展開人力。Driv
13、er: 調(diào)用模塊細節(jié)逐個進行測試調(diào)用模塊細節(jié)逐個進行測試.DM1M2第第3 3步:去掉步:去掉DriverDriver,自下而上把子功能族合成,自下而上把子功能族合成更大的子功能族。更大的子功能族。MMMMMMMMMMMMDDDDDD3.集成測試集成測試留意:兩種策略留意:兩種策略的優(yōu)、缺點剛好的優(yōu)、缺點剛好互補,但單用其互補,但單用其中任一種都不實中任一種都不實際,通常根據(jù)軟際,通常根據(jù)軟件的特點將二者件的特點將二者混用。混用。 Sandwich testing (三文治測試)(三文治測試)3.集成測試集成測試Target layerTop-downBottom-up4. 驗收測試驗收測試(
14、Acceptance testing)義務:驗收軟件的有效性功能和性能達標)。義務:驗收軟件的有效性功能和性能達標)。手段:黑盒測試;用戶參與;主要用實際數(shù)據(jù)進手段:黑盒測試;用戶參與;主要用實際數(shù)據(jù)進行測試。行測試。內(nèi)容:按合同規(guī)定審查軟件配置;內(nèi)容:按合同規(guī)定審查軟件配置; 設(shè)計測試計劃,使通過測試保證軟件能滿設(shè)計測試計劃,使通過測試保證軟件能滿足所有功能、性能要求;足所有功能、性能要求; 文檔與程序一致,具有維護階段所必須的文檔與程序一致,具有維護階段所必須的細節(jié);細節(jié); 嚴格按用戶手冊操作,以檢查手冊的完整嚴格按用戶手冊操作,以檢查手冊的完整性和正確性。性和正確性。5. 設(shè)計測試方案設(shè)
15、計測試方案(Plan of testing)主要技術(shù):主要技術(shù):1、邏輯覆蓋、邏輯覆蓋(Logical coverage) 適用于白盒測試適用于白盒測試 覆蓋程度由弱到強順次為:覆蓋程度由弱到強順次為: 語句覆蓋語句覆蓋(Statement coverage):每個語句至少執(zhí)行每個語句至少執(zhí)行一次。一次。義務:義務:預定要測試的功能預定要測試的功能 設(shè)計輸入的測試數(shù)據(jù)設(shè)計輸入的測試數(shù)據(jù)(test cases) 列出預期結(jié)果列出預期結(jié)果(expected output)5. 設(shè)計測試方案設(shè)計測試方案例:例:問題:若問題:若AND錯錯寫 為寫 為 O R , 或, 或X1錯寫為錯寫為X 1AND
16、B=0TA=2OR X 1TX = X / AX = X + 1前往前往FFTest case : A=2 , B=0 , X=4. 判定覆蓋判定覆蓋(Branch coverage):在:在的基礎(chǔ)上,的基礎(chǔ)上,每個判定的每個分支至少執(zhí)行一次。每個判定的每個分支至少執(zhí)行一次。5. 設(shè)計測試方案設(shè)計測試方案Test cases:A=3 , B=0 , X=3A=2 , B=1 , X=1問題:若問題:若X1錯錯寫為寫為X 1AND B=0TA=2OR X 1TX = X / AX = X + 1前往前往FF 條件覆蓋條件覆蓋(Condition coverage):在:在的基礎(chǔ)上,使的基礎(chǔ)上,使
17、每個判定表達式的每個條件都取到各種可能的結(jié)果。每個判定表達式的每個條件都取到各種可能的結(jié)果。5. 設(shè)計測試方案設(shè)計測試方案Test cases:A=2 , B=0 , X=4(滿足(滿足A1, B=0; A=2, X1)A=1, B=1, X=1(滿足滿足A1, B0; A 2, X1)問:條件覆蓋問:條件覆蓋 ? 判定覆蓋判定覆蓋 答答: 不一定。不一定。 反例反例: A=2, B=0, X=1 A=1, B=1, X=2 斷定斷定/條件覆蓋:即判定覆蓋條件覆蓋:即判定覆蓋條件覆蓋條件覆蓋 入口入口A 1AND B=0TA=2OR X 1TX = X / AX = X + 1前往前往FF 條
18、件組合覆蓋:每個判定表達式條件組合覆蓋:每個判定表達式中條件的各種可能組合都至少出中條件的各種可能組合都至少出現(xiàn)一次。現(xiàn)一次。5. 設(shè)計測試方案設(shè)計測試方案入口入口A 1AND B=0TA=2OR X 1TX = X / AX = X + 1前往前往FF全部可能的條件組合為:全部可能的條件組合為: A1, B=0 A1, B 0 A1, B=0 A1, B 0 A=2, X1 A=2, X 1 A 2, X1 A 2,X 1 Test cases: A=2, B=0, X=4 (T T) A=2. B=1, X=1 (F T) A=1, B=0, X=2 (F T) A=1, B=1, X=1
19、 (F F)問題:沒有測試到問題:沒有測試到T F的情形的情形考察考察control flow graph 的角度,還可考慮下述覆蓋:的角度,還可考慮下述覆蓋: 點覆蓋點覆蓋5. 設(shè)計測試方案設(shè)計測試方案 邊覆蓋邊覆蓋= 語句覆蓋語句覆蓋 路徑覆蓋路徑覆蓋(Path coverage): 每條可能的路徑都至少執(zhí)每條可能的路徑都至少執(zhí)行一次,若圖中有環(huán),則每行一次,若圖中有環(huán),則每個環(huán)至少經(jīng)過一次。個環(huán)至少經(jīng)過一次。=判定覆蓋判定覆蓋Test cases: A=1 , B=1 , X=1 A=1 , B=1 , X=2 A=3 , B=0 , X=1 A=2 , B=0 , X=4 路徑覆蓋路徑
20、覆蓋 條件組合覆蓋條件組合覆蓋 劃分經(jīng)驗劃分經(jīng)驗 當規(guī)定了輸入范圍時:當規(guī)定了輸入范圍時:5. 設(shè)計測試方案設(shè)計測試方案2、等價劃分、等價劃分(Equivalence Partitioning) 適用于黑盒測試適用于黑盒測試 劃分一組劃分一組 等價類等價類 描繪一組輸入條件的有效或無效描繪一組輸入條件的有效或無效條件條件, 測試程序是否有設(shè)計方案中該有的輸出結(jié)果測試程序是否有設(shè)計方案中該有的輸出結(jié)果.無效類無效類 有效類有效類 無效類無效類 當規(guī)定了輸入的一組值,且對不同值做不同處理時:例:教工分房方當規(guī)定了輸入的一組值,且對不同值做不同處理時:例:教工分房方案中,按教授、副教授、講師、助教分
21、別計分案中,按教授、副教授、講師、助教分別計分 有效類有效類4個;無效類個;無效類1個個 當規(guī)定了輸入的規(guī)則時:當規(guī)定了輸入的規(guī)則時: 例:例:(PASCAL) 語言規(guī)定,每個語句以語言規(guī)定,每個語句以“ ;” 結(jié)結(jié) 束束 有效類有效類1個;無效類若干以個;無效類若干以“ ,”終了、以終了、以“ :”終了、以空格結(jié)束等等)終了、以空格結(jié)束等等) 當輸入為整型時:有效類可分為當輸入為整型時:有效類可分為Z+、0、Z 三三種種 當處理表格時:有效類可分為空表、含一項的表、當處理表格時:有效類可分為空表、含一項的表、含多項的表等含多項的表等注:注: 以上經(jīng)驗亦適用于輸出數(shù)據(jù);以上經(jīng)驗亦適用于輸出數(shù)據(jù)
22、; 不需要測試編譯程序肯定能發(fā)現(xiàn)的錯誤。不需要測試編譯程序肯定能發(fā)現(xiàn)的錯誤。5. 設(shè)計測試方案設(shè)計測試方案 設(shè)計步驟設(shè)計步驟 設(shè)計一個新方案以盡可能多地覆蓋尚未被覆蓋設(shè)計一個新方案以盡可能多地覆蓋尚未被覆蓋的有效等價類;重復這一步驟直到所有有效類都的有效等價類;重復這一步驟直到所有有效類都被覆蓋為止。被覆蓋為止。 設(shè)計一個新方案以覆蓋一個且僅一個尚未被覆設(shè)計一個新方案以覆蓋一個且僅一個尚未被覆蓋的無效等價類;重復這一步驟直到所有無效類蓋的無效等價類;重復這一步驟直到所有無效類都被覆蓋為止。(通常程序執(zhí)行一個錯誤后即不都被覆蓋為止。(通常程序執(zhí)行一個錯誤后即不繼續(xù)檢測其它錯誤,故每次只測一個無效
23、類)繼續(xù)檢測其它錯誤,故每次只測一個無效類)5. 設(shè)計測試方案設(shè)計測試方案3、邊界值分析、邊界值分析(Boundary Value Analysis)留意:留意: 程序最容易在邊界發(fā)生錯誤;程序最容易在邊界發(fā)生錯誤; 通常與等價劃分結(jié)合進行。通常與等價劃分結(jié)合進行。4、錯誤推測、錯誤推測(Failure Prediction)思緒:思緒: 列出可能有的錯誤;列出可能有的錯誤; 列出容易發(fā)生錯誤的特殊情況。列出容易發(fā)生錯誤的特殊情況。 以此為基礎(chǔ)設(shè)計測試方案。以此為基礎(chǔ)設(shè)計測試方案。根據(jù):直覺、閱歷根據(jù):直覺、閱歷工具:常見錯誤清單、判定表等。工具:常見錯誤清單、判定表等。5. 設(shè)計測試方案設(shè)計
24、測試方案5、實用策略、實用策略(Practical Strategies) 黑盒設(shè)計黑盒設(shè)計 白盒補充白盒補充 在任何情況下都應該使用邊界值分析的方法;在任何情況下都應該使用邊界值分析的方法; 必要時用等價劃分法補充;必要時用等價劃分法補充; 必要時再用錯誤推測法補充;必要時再用錯誤推測法補充; 對照程序邏輯,檢查測試方案??筛鶕?jù)對程對照程序邏輯,檢查測試方案??筛鶕?jù)對程序可靠性的要求采用不同的邏輯覆蓋標準,序可靠性的要求采用不同的邏輯覆蓋標準,必要時補充一些測試方案。必要時補充一些測試方案。注注: 即使用上述綜合策略設(shè)計測試方案,仍不能即使用上述綜合策略設(shè)計測試方案,仍不能保證發(fā)現(xiàn)一切錯誤。
25、例如保證發(fā)現(xiàn)一切錯誤。例如Lucent公司經(jīng)過包公司經(jīng)過包括逐行檢查源代碼在內(nèi)的多方面測試之后,括逐行檢查源代碼在內(nèi)的多方面測試之后,其軟件能達標運行的成功率為其軟件能達標運行的成功率為 5. 設(shè)計測試方案設(shè)計測試方案80%。6.調(diào)調(diào) 試試(Debugging)測試測試 發(fā)現(xiàn)錯誤發(fā)現(xiàn)錯誤調(diào)試調(diào)試 改正錯誤改正錯誤第第1步:確定錯誤的位置步:確定錯誤的位置(95%工作量工作量); 第第2步:改正錯誤。步:改正錯誤。Failure外錯誤通常是由系統(tǒng)設(shè)計產(chǎn)生的外錯誤通常是由系統(tǒng)設(shè)計產(chǎn)生的.Fault缺點、內(nèi)錯誤、缺點、內(nèi)錯誤、error、bug起因于軟件生產(chǎn)中的人為起因于軟件生產(chǎn)中的人為錯誤錯誤.程
26、序的程序的 failure 通常有一個清晰的表現(xiàn)特征,但是通常有一個清晰的表現(xiàn)特征,但是 fault 往往很難往往很難被發(fā)現(xiàn)。被發(fā)現(xiàn)。Execution of casesTestcasesResultsDebuggingAdditional testsSuspected causesIdentified causesCorrectionsRegression testsDebugging6.調(diào)調(diào) 試試1、調(diào)試技術(shù)、調(diào)試技術(shù) 輸出存儲器內(nèi)容輸出存儲器內(nèi)容(memory dump): 以八進制或十六進制的形式印出存儲器的內(nèi)容。以八進制或十六進制的形式印出存儲器的內(nèi)容。缺陷:缺陷: 輸出信息量極大,
27、輸出信息量極大, 不易解讀且大多無用;不易解讀且大多無用; 輸出的是程序在某一輸出的是程序在某一 時刻的靜態(tài)情況,且時刻的靜態(tài)情況,且 往往不是出錯時的狀態(tài)。往往不是出錯時的狀態(tài)。6.調(diào)調(diào) 試試 插入插入“watch points”(或稱或稱“spy points”) 人工插入打印人工插入打印 缺陷:缺陷: 改動源代碼,增加了出錯機會;改動源代碼,增加了出錯機會; 打印信息可能太多。打印信息可能太多。 自動調(diào)試工具自動調(diào)試工具 無須打印額外信息,且不無須打印額外信息,且不改動源代碼改動源代碼6.調(diào)調(diào) 試試2、調(diào)試策略、調(diào)試策略 調(diào)試過程的關(guān)鍵不是調(diào)試技術(shù),而是用來推調(diào)試過程的關(guān)鍵不是調(diào)試技術(shù),
28、而是用來推斷錯誤原因的基本策略。主要有:斷錯誤原因的基本策略。主要有: 試探法,憑經(jīng)驗猜測。試探法,憑經(jīng)驗猜測。 回溯法:由癥狀回溯法:由癥狀(symptom)最先出現(xiàn)的地方,最先出現(xiàn)的地方,沿沿control flow向回檢查。適用于小型程序。向回檢查。適用于小型程序。 對分法:在關(guān)鍵點插入變量的正確值,那么:對分法:在關(guān)鍵點插入變量的正確值,那么:6.調(diào)調(diào) 試試輸出正確輸出正確錯誤在前半段錯誤在前半段錯誤在后半段錯誤在后半段NY收集數(shù)據(jù)收集數(shù)據(jù)組織數(shù)據(jù)組織數(shù)據(jù)研究數(shù)據(jù)研究數(shù)據(jù)間的關(guān)系間的關(guān)系提出假設(shè)提出假設(shè)證明假設(shè)證明假設(shè)糾正錯誤糾正錯誤能能能能不不能能不能不能YesNo What Whe
29、re When How3W1H Table6.調(diào)調(diào) 試試 歸納法:從錯誤癥狀中找出規(guī)律,推斷根源。歸納法:從錯誤癥狀中找出規(guī)律,推斷根源。列舉可能列舉可能的原因的原因排除不正確排除不正確的假設(shè)的假設(shè)精化余下精化余下的假設(shè)的假設(shè)證明證明假設(shè)假設(shè)收集更多數(shù)據(jù)收集更多數(shù)據(jù)糾正糾正錯誤錯誤有剩余有剩余能能不能不能無剩余無剩余 演繹法:普通演繹法:普通 特殊特殊 從假設(shè)中逐步排除、精化,從而導出錯誤根源。從假設(shè)中逐步排除、精化,從而導出錯誤根源。6.調(diào)調(diào) 試試7. 軟件可靠性軟件可靠性(Reliability)1、基本概念、基本概念 可靠性可靠性(Reliability):程序在給定的時間間隔:程序在給
30、定的時間間隔內(nèi),按照說明書的規(guī)定,成功地運行的概率。內(nèi),按照說明書的規(guī)定,成功地運行的概率。 可用性可用性(Usability):程序在給定的時間點,按:程序在給定的時間點,按照說明書的規(guī)定,成功地運行的概率。照說明書的規(guī)定,成功地運行的概率。 正確性正確性(Correctness):程序的功能正確。:程序的功能正確。ReliabilityCorrectnessUsability7. 軟件可靠性軟件可靠性設(shè)系統(tǒng)故障停機時間為設(shè)系統(tǒng)故障停機時間為td1, td2, ; 正常運行時間正常運行時間為為tu1, tu2, ; 則系統(tǒng)的則系統(tǒng)的“穩(wěn)態(tài)可用性穩(wěn)態(tài)可用性為為Availability = (S
31、hooman, 1983)其中其中 MTTF = Mean Time To Failure = MTTR = Mean Time To Repair = MTTR MTTFMTTFn1iuitn10ttu1td1tu2td2n1iditn12、估算、估算 MTTF: MTTF = 7. 軟件可靠性軟件可靠性)/I(E/IK(E1TCTT其中:其中:K為經(jīng)驗常數(shù)典型值約在為經(jīng)驗常數(shù)典型值約在200左右);左右); ET為測試前故障總數(shù);為測試前故障總數(shù); IT為程序長度機器指令總數(shù));為程序長度機器指令總數(shù)); 為測試包括調(diào)試時間;為測試包括調(diào)試時間; EC( )為時間從為時間從0至至 期間改正
32、的錯誤數(shù)。期間改正的錯誤數(shù)。前提假設(shè):前提假設(shè): ET / IT Constant (通常為(通常為0.5 2%) 調(diào)試中沒有引入新故障即調(diào)試中沒有引入新故障即ET與時間與時間無關(guān))無關(guān)) MTTF與剩余故障成反比與剩余故障成反比換個角度看問題換個角度看問題7. 軟件可靠性軟件可靠性MTTFKIE)(ETTC意義:可根據(jù)對軟件平穩(wěn)運行時間的要求,估算需改意義:可根據(jù)對軟件平穩(wěn)運行時間的要求,估算需改正多少個錯誤后才能結(jié)束測試。正多少個錯誤后才能結(jié)束測試。還有一個問題還有一個問題 ET = ?估算方法:估算方法: 植入故障法:植入故障法: 人為植入人為植入NS個故障,測后發(fā)現(xiàn)個故障,測后發(fā)現(xiàn)ns
33、個植入故障和個植入故障和n個個原有故障,則設(shè)原有故障,則設(shè)TSSSEnnNNnNn Hyman 分別測試法:分別測試法: 二人組分別獨立測試同一程序,甲測得故二人組分別獨立測試同一程序,甲測得故障總數(shù)為障總數(shù)為B1,乙測得為,乙測得為B2,其中有,其中有bc是相同的,是相同的,設(shè)以甲的測試結(jié)果為基準即相當于設(shè)以甲的測試結(jié)果為基準即相當于中的植中的植入故障),則設(shè)入故障),則設(shè)7. 軟件可靠性軟件可靠性T1c221cEBbBBBBBb一般多測幾個一般多測幾個 取平均。取平均。B3、正確性說明、正確性說明 目的:研究能證明程序正確性的自動系統(tǒng)。目的:研究能證明程序正確性的自動系統(tǒng)。7. 軟件可靠性
34、軟件可靠性p1p2p3pn-1pna(1) = inputa(2)a(3)a(n-1)a(n) = outputa(i):斷言斷言(assertion)證明:對任一個證明:對任一個i,執(zhí)行了,執(zhí)行了pi到到pi+1之間的語句后,可之間的語句后,可將將a(i)變?yōu)樽優(yōu)閍(i+1),則證明由,則證明由a(1)可導出可導出a(n)。若。若a(1)和和a(n)正確,且程序確定可終正確,且程序確定可終止,則證明程序正確。止,則證明程序正確。但是:即使有了正確性證明程序,軟件測試也仍然但是:即使有了正確性證明程序,軟件測試也仍然是需要的。是需要的。由于:由于:正確性證明只證明程序功能正確,但不能正確性證明
35、只證明程序功能正確,但不能驗證動態(tài)特性;驗證動態(tài)特性; 證明過程本身也可能發(fā)生錯誤。證明過程本身也可能發(fā)生錯誤。原理:原理:100%50%100%測試用例完成率測試用例完成率 = = 已完成用例已完成用例 / / 全部用例全部用例測試時間使用率測試時間使用率 = = 所用時間所用時間 / / 總時間總時間第一第一階段階段第二第二階段階段第三第三階段階段8.日立預測法日立預測法日立預測法日立預測法 測試期間繪制并檢查兩種曲線測試期間繪制并檢查兩種曲線1、測試完成率曲線:、測試完成率曲線:閱歷:閱歷:工程的成敗取工程的成敗取決于第一階段決于第一階段向第二階段轉(zhuǎn)向第二階段轉(zhuǎn)移斷點的位置,移斷點的位置,一般成功的工一般成功的工程其轉(zhuǎn)折點位程其轉(zhuǎn)折點位于于15%;若超;若超過過55%則破產(chǎn)則破產(chǎn)不可避免。不可避免。錯誤發(fā)現(xiàn)率錯誤發(fā)現(xiàn)率 = 單位時間內(nèi)發(fā)現(xiàn)的錯誤數(shù)單位時間內(nèi)發(fā)現(xiàn)的錯誤數(shù)時間時間峰值時間峰值時間成成功功的的工工程程失敗的失敗的工程工程極壞的工程極壞的工程8.日立預測法日立預測法2、錯誤發(fā)現(xiàn)率曲線:、錯誤發(fā)現(xiàn)率曲線:閱歷:閱歷:剛過峰值點后剛過峰值點后曲線的導數(shù)關(guān)曲線的導數(shù)關(guān)系到工程的成系到工程的成敗。若導數(shù)值敗。若導數(shù)值大于大于- 0.3,則,則失敗不可避免。失敗不可避免。其它可靠性預測模型其它可靠性預測模型(reliability predictio
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 用數(shù)據(jù)說話在匯報中展現(xiàn)你的精準教育成果
- 腳蹬帶行業(yè)市場發(fā)展及發(fā)展趨勢與投資戰(zhàn)略研究報告
- 2020-2025年中國削片機行業(yè)市場深度分析及發(fā)展前景預測報告
- 中國動態(tài)腕矯形器行業(yè)發(fā)展趨勢預測及投資戰(zhàn)略咨詢報告
- 拼接板項目可行性研究報告模板及范文
- 2025年中國多西他賽行業(yè)市場深度分析及發(fā)展前景預測報告
- 匯報藝術(shù)提升企業(yè)管理溝通效果的秘訣
- 2020-2025年中國汽車共享行業(yè)發(fā)展?jié)摿Ψ治黾巴顿Y方向研究報告
- 2025年國家戰(zhàn)略合作協(xié)議
- 加入學生會申請書800字
- 2024年初級養(yǎng)老護理員職業(yè)鑒定考試題庫(含答案)
- 人教八年級上冊英語第一單元《Section A (1a-2d)》教學課件
- 2023年版《安寧療護實踐指南(試行)》解讀課件
- 2024年銀行考試-興業(yè)銀行筆試考試歷年高頻考點試題摘選含答案
- 油氣勘探開發(fā)的勘探風險管理
- 10kV環(huán)網(wǎng)柜改造工程施工方案設(shè)計
- 電工班三級安全教育內(nèi)容范本
- 新生兒疾病篩查可疑陽性、陽性兒復查隨訪登記表
- 開學前幼兒園安全培訓
- 2024年春學期人教版pep版小學英語五年級下冊教學進度表
- 2023年湛江市麻章區(qū)教育局招聘事業(yè)編制教師考試真題
評論
0/150
提交評論