版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1第15講軟件測試2
軟件測試在軟件生命周期中橫跨兩個階段:單元測試和綜合測試。3
無論怎樣強調軟件測試的重要性和它對軟件可靠性的影響都不過分。軟件測試在軟件生存周期中橫跨兩個階段。 1、通常在編出每個模塊之后就對它做必要的測試(稱為單元測試),模塊的編寫者和測試者是同一個人,編碼和單元測試屬于軟件生存周期的同一個階段。 2、在這個階段結束之后,對軟件系統(tǒng)還要進行各種綜合測試,這是軟件生存周期中的另一個獨立的階段,通常由專門的測試人員承擔這項工作。第一節(jié)
基本概念4
軟件工程的其他階段都是“建設性”的,軟件工程師力圖從抽象的概念出發(fā),逐步設計出具體的軟件系統(tǒng),直到用一種適當的程序設計語言寫出可以執(zhí)行的程序代碼。軟件工程的測試階段,測試人員努力設計出一系列測試方案,目的卻是為了“破壞”已經建造好的軟件系統(tǒng)--竭力證明程序中有錯誤不能按照預定要求正確執(zhí)行。
測試階段的根本目的:盡可能多地發(fā)現并排除軟件中潛藏的錯誤,最終把一個高質量的軟件系統(tǒng)交給用戶使用。5
1、測試是為了發(fā)現程序中的錯誤而執(zhí)行程序的過程; 2、好的測試方案是極可能發(fā)現迄今為止尚未發(fā)現的錯誤的測試方案; 3、成功的測試是發(fā)現了至今為止尚未發(fā)現的錯誤的測試。測試的定義:
為了發(fā)現程序中的錯誤而執(zhí)行程序的過程。一、軟件測試的目的6
1、為了證明程序是正確的而進行測試,就會設計一些不易暴露錯誤的的測試方案。 2、為了發(fā)現程序中的錯誤,就會力求設計出最能暴露錯誤的測試方案。從心理學的角度看,由程序的編寫者自己進行測試是不恰當的。測試的目的決定了測試方案的設計
測試方案包括預定要測試的功能,應該輸入的測試數據和預期的結果。其中最困難的問題是設計測試用的輸入數據(測試用例)。
設計技術有:適用于黑盒測試的等價劃分,邊界值分析、以及錯誤推測法等;適用于白盒測試的邏輯覆蓋法;以及灰盒測試7二、測試的原則
1、測試用例包括應該輸入的測試數據和預期的輸出結果。
2、測試數據不僅要選擇合理的輸入數據,還要選擇不合理的輸入數據;
3、除了檢查程序應該做的事情,還應該檢查程序是否做了不應該做的事情;
4、應制定測試計劃并嚴格執(zhí)行,排除隨意性;
5、長期保留測試用例;
6、對發(fā)現錯誤較多的程序段,應進行更深入的測試;
7、程序員避免測試自己的程序。8可靠性分析三、軟件測試的對象及信息流1)軟件配置:包括需求說明書,設計說明書,源程序清單等;2)測試配置:包括測試計劃和測試方案。
3)測試工具:winrunner,robot;軟件配置測試配置測試測試結果結果分析錯誤調試正確預期結果錯誤率數據預測測試工具9第二節(jié)軟件測試方法(一)白盒測試技術(一)邏輯覆蓋是設計白盒測試方案的一種技術。是對一系列測試過程的總稱。從覆蓋源程序語句的詳盡程度分析:1、語句覆蓋2、判定覆蓋3、條件覆蓋4、判定/條件覆蓋5、條件組合覆蓋6、路徑覆蓋10開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A1234567測試舉例(被測模塊的流程圖)example(inta,intb,floatx){if(a>1&&b==0)x=x/a;if(a==2||x>1)x=x+1;}11A=2,B=0,X=41、語句覆蓋分析:1、只測試了條件為真的情況,當條件為假時處理有錯誤,語句測試不能發(fā)現。 2、只關心判定式的值,未測試每個條件取不同值情況。 3、如把AND錯寫成OR,把X>1錯寫成X<1,上述測試數據不能發(fā)現。開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A1234567預期結果:測試數據:X=3.0語句覆蓋就是設計若干個測試用例,運行被測程序,使得每一可執(zhí)行語句至少執(zhí)行一次。122、判定覆蓋分析: 1、判定覆蓋比語句覆蓋強,但邏輯覆蓋程度還不高。 2、上述測試數據只覆蓋了程序全部路徑的一半。開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A1234567I:A=3,B=0,X=3(覆蓋sacbd)II:A=2,B=1,X=1(覆蓋sabed)預期結果:測試數據:I:X=1.0II:X=2.0判定覆蓋就是設計若干個測試用例,運行被測程序,使得程序中每個判斷的取真分支和取假分支至少經歷一次。13
a點:A>1,A<=1,B=0,B!=0;b點:A=2,A!=2,X>1,X<=1;3、條件覆蓋I:A=2,B=0,X=4;(sacbed)(A>1,B=0,A=2,X>1;
)II:A=1,B=1,X=1;(sabd)(A<=1,B!=0,A!=2,X<=1;)分析:條件覆蓋比判定覆蓋強。開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A1234567預期結果:測試數據:I:X=3.0II:X=1.0條件覆蓋就是設計若干個測試用例,運行被測程序,使得程序中每個判斷的每個條件的可能取值至少執(zhí)行一次。14I:A=2,B=0,X=4;(sacbed)(A>1,B=0,A=2,X>1;
II:A=1,B=1,X=1;(sabd)(
A<=1,B!=0,A!=2,X<=1;分析:判定/條件覆蓋并不比條件覆蓋強。開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A12345674、判定/條件覆蓋預期結果:測試數據:I:X=3.0II:X=1.0判定-條件覆蓋就是設計足夠的測試用例,使得判斷中每個條件的所有可能取值至少執(zhí)行一次,每個判斷中的每個條件的可能取值至少執(zhí)行一次。158種可能的條件組合如下:(1)A>1,B=0;(5)A=2,X>1;(2)A>1,B!=0;(6)A=2,X<=1;(3)A<=1,B=0;(7)A!=2,X>1;(4)A<=1,B!=0;(8)A!=2,X<=1;5、條件組合覆蓋開始A>1ANDB=0X=X+1停止FTTFsedcbaA=2ORX>1X=X/A1234567I:A=2,B=0,X=4(sacbed)II:A=2,B=1,X=1(sabed)III:A=1,B=0,X=2(sabed)IV:A=1,B=1,X=1(sabd)
預期結果:測試數據:I:X=3.0II:X=2.0III:
X=3.0IV:
X=1.0條件組合覆蓋就是設計足夠的測試用例,運行被測程序,使得每個判斷的所有可能的條件取值組合至少執(zhí)行一次。164條可能的路徑:
1-2-3;1-2-6-7;1-4-5-3;1-4-5-6-7。6、路徑覆蓋分析:路徑覆蓋是相當強的邏輯覆蓋標準。和條件組合覆蓋結合起來,可以設計出檢錯能力更強的測試數據。sedcba1234567預期結果:測試數據:I:X=3.0II:X=2.0III:
X=3.0IV:
X=1.0I:A=1,B=1,X=1;(1-2-3
)II:A=1,B=1,X=2;(1-2-6-7
)III:A=3,B=0,X=1;(1-4-5-3
)IV:A=2,B=0,X=4;(1-4-5-6-7
)路徑測試就是設計足夠的測試用例,覆蓋程序中所有可能的路徑。17二黑盒測試這種方法是把測試對象看做一個黑盒子,測試人員完全不考慮程序內部的邏輯結構和內部特性,只依據程序的需求規(guī)格說明書,檢查程序的功能是否符合它的功能說明。黑盒測試又叫做功能測試或數據驅動測試。18等價類劃分是一種典型的黑盒測試方法,使用這一方法時,完全不考慮程序的內部結構,只依據程序的規(guī)格說明來設計測試用例。等價類劃分方法把所有可能的輸入數據,即程序的輸入域劃分成若干部分,然后從每一部分中選取少數有代表性的數據做為測試用例。
等價類:每類中的一個典型值在測試中的作用與這一類中的所有其他值的作用相同。1、等價類劃分黑盒測試技術19等價類的劃分有兩種不同的情況:
①有效等價類:是指對于程序的規(guī)格說明來說,是合理的,有意義的輸入數據構成的集合。
②無效等價類:是指對于程序的規(guī)格說明來說,是不合理的,無意義的輸入數據構成的集合。在設計測試用例時,要同時考慮有效等價類和無效等價類的設計。20劃分等價類等價類的原則。
(1)如果輸入條件規(guī)定了取值范圍,或值的個數,則可以確立一個有效等價類和兩個無效等價類。
21例如,在程序的規(guī)格說明中,對輸入條件有一句話:
“……項數可以從1到999……”
則有效等價類是“1≤項數≤999”兩個無效等價類是“項數<1”或“項數>999”。在數軸上表示成:22
(2)如果輸入條件規(guī)定了輸入值的集合,或者是規(guī)定了“必須如何”的條件,這時可確立一個有效等價類和一個無效等價類。例如,在Pascal語言中對變量標識符規(guī)定為“以字母打頭的……串”。那么所有以字母打頭的構成有效等價類,而不在此集合內(不以字母打頭)的歸于無效等價類。23
(3)如果輸入條件是一個布爾量,則可以確定一個有效等價類和一個無效等價類。
(4)如果規(guī)定了輸入數據的一組值,而且程序要對每個輸入值分別進行處理。這時可為每一個輸入值確立一個有效等價類,此外針對這組值確立一個無效等價類,它是所有不允許的輸入值的集合。24例如,在教師上崗方案中規(guī)定對教授、副教授、講師和助教分別計算分數,做相應的處理。因此可以確定4個有效等價類為教授、副教授、講師和助教,一個無效等價類,它是所有不符合以上身分的人員的輸入值的集合。
(5)如果規(guī)定了輸入數據必須遵守的規(guī)則,則可以確立一個有效等價類(符合規(guī)則)和若干個無效等價類(從不同角度違反規(guī)則)。25例如,Pascal語言規(guī)定“一個語句必須以分號‘;’結束”。這時,可以確定一個有效等價類“以‘;’結束”,若干個無效等價類“以‘:’結束”、“以‘,’結束”、“以‘’結束”、“以LF結束”等。確立測試用例
在確立了等價類之后,建立等價類表,列出所有劃分出的等價類。
26再從劃分出的等價類中按以下原則選擇測試用例:
(1)為每一個等價類規(guī)定一個唯一編號;
(2)設計一個新的測試用例,使其盡可能多地覆蓋尚未被覆蓋的有效等價類,重復這一步,直到所有的有效等價類都被覆蓋為止;
(3)設計一個新的測試用例,使其僅覆蓋一個尚未被覆蓋的無效等價類,重復這一步,直到所有的無效等價類都被覆蓋為止。27
用等價類劃分法設計測試用例的實例
在某一PASCAL語言版本中規(guī)定:“標識符是由字母開頭,后跟字母或數字的任意組合構成。有效字符數為8個,最大字符數為80個?!?并且規(guī)定:“標識符必須先說明,再使用?!薄霸谕徽f明語句中,標識符至少必須有一個。”
28用等價類劃分方法,建立輸入等價類表:29下面選取了9個測試用例,它們覆蓋了所有的等價類。
①VARx,T1234567:REAL;
BEGINx:=3.414;
T1234567:=2.732;
...…(1),(2),(4),(8),(9),(12),(14)
②VAR:REAL;
(3)
③VARx,:REAL;(5)
30④VART12345678:REAL;
(6)⑤VART12345......:REAL;
(7)
多于80個字符⑥VART$:CHAR;
(10)⑦VARGOTO:INTEGER;
(11)⑧VAR2T:REAL;
(13)⑨VARPAR:REAL;
(15)
BEGIN......
PAP:=SIN(3.14*0.8)/6;31
人們從長期的測試工作經驗得知,大量的錯誤是發(fā)生在輸入或輸出范圍的邊界上,而不是在輸入范圍的內部。因此針對各種邊界情況設計測試用例,可以查出更多的錯誤。通常,輸入等價類和輸出等價類的邊界,就是應該著重測試的程序邊界情況。選取測試數據應該:
“剛好等于;剛剛小于;剛剛大于?!?/p>
2、邊界值分析
某應用程序完成如下功能:
輸入某年某月某日,判斷這一天是這一年的第幾天。32例如:某應用程序完成如下功能:輸入某年某月某日,判斷這一天是這一年的第幾天。程序C源代碼如下:
main(){intday,month,year,sum,leap;printf("\npleaseinputyear,month,day\n");scanf("%d,%d,%d",&year,&month,&day);
switch(month){
case1:sum=0;break;case2:sum=31;break;case3:sum=59;break;case4:sum=90;break;
case5:sum=120;break;
case6:sum=151;break;
case7:sum=181;break;
case8:sum=212;break;
case9:sum=243;break;
case10:sum=273;break;
case11:sum=304;break;
case12:sum=334;break;
default:printf("dataerror");break;}sum=sum+day;
printf("Itisthe%dthday.",sum);}331、用下述表格形式設計邊界值測試用例序號輸入條件預期輸出實際輸出123456734序號輸入條件預期輸出實際輸出11900,1,1Itisthe1thdayItisthe1thday21899,0,0dataerrordataerror31901,2,2Itisthe33thdayItisthe33thday42050,12,31Itisthe365thdayItisthe365thday52049,11,30Itisthe334thdayItisthe334thday62051,13,32dataerrordataerror735
該程序是否有缺陷?這些缺陷可以用什么測試案例檢測出來?
有缺陷,沒有考慮閏年問題。可以用以下測試案例測試:
year=2000,month=3,day=1
預期輸出:61實際輸出:60修改缺陷部分,給出代碼。if(year%400==0||(year%4==0&&year%100!=0))/*判斷是不是閏年*/
leap=1;
else
leap=0;
if(leap==1&&month>2)/*如果是閏年且月份大于2,總天數應該加一天*/
sum++;36序號輸入數據預期輸出實際輸出說明11900,1,1Itisthefirstday剛好等于最小值22050,12,31Itisthe365thday剛好等于最大值31899,1,1輸入年份超范圍年份剛小于最小值42051,1,1輸入年份超范圍年份剛大于最大值52000,0,1輸入月份超范圍月份剛小于最小值62000,13,32輸入月份超范圍月份剛大于最大值72000,1,0輸入日超范圍日剛小于最小值82000,1,32輸入日超范圍日剛大于最大值92000,3,1Itisthe61thday閏年問題測試數據及預期結果37
基本思想:是列舉出程序中可能有的錯誤和容易發(fā)生錯誤的特殊情況,并且根據他們選擇測試方案。
經驗告訴我們:在一段程序中已經發(fā)現的錯誤數往往和未發(fā)現的錯誤數成正比。 錯誤推測法很大程度上靠直覺和經驗進行。3、錯誤推測3灰盒測試的定義1999年,美國洛克希德公司發(fā)表了灰盒測試法的論文,提出了灰盒測試法。單純從名稱上來看,灰盒測試是介于黑盒測試與白盒測試之間的一種測試方式?;液袦y試是基于程序運行時的外部表現同時又結合程序內部邏輯結構來設計用例,執(zhí)行程序并采集程序路徑執(zhí)行信息和外部用戶接口結果的測試技術。383.1灰盒測試的定義灰盒測試與黑盒測試的區(qū)別如果某軟件包含多個模塊,當你使用黑盒測試時,你只要關心整個軟件系統(tǒng)的邊界,無需關心軟件系統(tǒng)內部各個模塊之間如何協作。而如果使用灰盒測試,你就需要關心模塊與模塊之間的交互。這是灰盒測試與黑盒測試的區(qū)別。393.1灰盒測試的定義灰盒測試與白盒測試的區(qū)別
在灰盒測試中,無需關心模塊內部的實現細節(jié)。對于軟件系統(tǒng)的內部模塊,灰盒測試依然把它當成一個黑盒來看待。而白盒測試還需要再深入地了解內部模塊的實現細節(jié)。403.1灰盒測試的定義灰盒測試與單元測試的區(qū)別首先,在進行單元測試時,需要寫一些測試代碼(即“樁代碼”stub)。通常測試代碼和被測試代碼通常是同種語言(比如Java的單元測試通常也用Java來寫),且測試代碼和被測試代碼的耦合很緊密。因此,單元測試通常由開發(fā)人員來完成的,測試人員的能力未必能勝任。其次,單元測試的顆粒度會更細(會細到類一級、函數一級),而灰盒測試僅僅到模塊一級。413.1灰盒測試的優(yōu)缺點優(yōu)點:1、
能夠進行基于需求的覆蓋測試和基于程序路徑覆蓋的測試;2、
測試結果可以對應到程序內部路徑,便于bug的定位、分析和解決;3、
能夠保證設計的黑盒測試用例的完整性,防止遺漏軟件的一些不常用的功能或功能組合;4、
能夠需求或設計不詳細或不完整對測試造成的影響。423.1灰盒測試的優(yōu)缺點缺點:1、投入的時間比黑盒測試大概多20-40%的時間;2、對測試人員的要求比黑盒測試高;灰盒測試要求測試人員清楚系統(tǒng)內部由哪些模塊構成,模塊之間如何協作。3、不如白盒測試深入;4、不適用于簡單的系統(tǒng)。所謂的簡單系統(tǒng),就是簡單到總共只有一個模塊。由于灰盒測試關注于系統(tǒng)內部模塊之間的交互。如果某個系統(tǒng)簡單到只有一個模塊,那就沒必要進行灰盒測試了。433.2灰盒測試的準備1、在測試中,部署產品之外,還要安裝源代碼。從源代碼編譯生成的目錄中運行軟件。2、需要代碼覆蓋率工具的配置;部署可以針對本軟件開發(fā)語言的代碼覆蓋率工具;3、測試人員要具備閱讀代碼的能力,其對開發(fā)語言的熟悉程度和程序設計經驗多少決定了采用灰盒測試能夠取得多大的好處,所以配置這方面的測試人員或進行必要的培訓是必要的。443.4灰盒測試實例4546三、測試策略 在軟件系統(tǒng)進行實際測試時,應該聯合使用各種設計測試方案的方法,形成一種綜合策略。 通常的做法是:用黑盒測試法設計基本的測試方案,再用白盒測試法補充一些必要的測試方案。具體地說,可用下述策略:1)在任何情況下都應該使用邊界值分析的方法;2)必要時用等價劃分法補充測試方案3)必要時再用錯誤推測法補充測試方案4)對照程序邏輯,檢查已經設計出的測試方案。
47第四節(jié)軟件測試的步驟及過程48軟件開發(fā)與軟件測試的關系項目規(guī)劃項目需求分析項目概要分析項目詳細分析代碼編寫測試代碼編寫測試需求分析系統(tǒng)測試計劃集成測試計劃單元測試計劃產品發(fā)布系統(tǒng)測試集成測試單元測試完整的軟件開發(fā)流程49一、單元測試單元測試又稱模塊測試。每個程序模塊完成一個相對獨立的子功能,所以可以對該模塊進行單獨的測試。在單元測試期間主要評價模塊的下述5個特性:●模塊的接口●局部數據結構●重要的執(zhí)行通路●出錯處理通路●影響上述各方面特性的邊界條件50單元測試的步驟通常單元測試在編碼階段進行,并經過人工測試和計算機測試兩種類型的測試。(1)代碼審查人工測試源程序可以由編寫者本人非正式的進行,也可以由審查小組正式進行,后者稱為代碼審查,是一種非常有效的程序驗證技術,對于典型的程序來說,可以查處30-70%的邏輯設計錯誤和編碼錯誤。審查小組的組成:組長;程序的設計者;編寫者;測試者。代碼審查比計算機測試優(yōu)越的是:●一次審查會上可以發(fā)現許多錯誤;●可以減少系統(tǒng)驗證的總工作量(計算機測試的錯誤是一個一個地發(fā)現并改正的)。51(2)測試軟件在源程序代碼編制完成,經過評審和驗證,確認沒有語法錯誤之后,就開始進行單元測試的測試用例設計。程序單元并不一定是一個獨立的程序,在考慮測試單元時,同時要考慮它和外界的聯系,用一些輔助單元去模擬與被測單元相聯系的其它單元。這些輔助單元分為兩種:驅動模塊和樁模塊。樁模塊:樁模塊(Stub)是指模擬被測試的模塊所調用的模塊,而不是軟件產品的組成的部分。被測單元、相關的驅動模塊及樁模塊共同構成了一個“測試環(huán)境”。52二、集成測試集成測試過程中要考慮如下問題:●數據穿過模塊接口時是否會丟失;●模塊的功能是否會對其它模塊的功能產生不利的影響;●把子功能組合起來,能否達到預期的主功能要求;●單個模塊的誤差累積起來是否會放大到不能接受的程度;●全局數據結構是否有問題。53 集成是組裝軟件的系統(tǒng)技術;模塊組裝成程序時有兩種方法: 1、先分別測試每個模塊,在把所有模塊按設計要求放在一起結合成所要的程序,稱為非漸增式測試方法; 2、把下一個要測試的模塊同已經測試好的那些模塊結合起來進行測試,測試完以后在把下一個該測試的模塊結合進來測試,這種每次增加一個模塊的方法稱為漸增式測試(實際上同時完成了單元測試和集成測試)。
當使用漸增式的測試方法把模塊結合到軟件系統(tǒng)中去時,有自頂向下和自底向上兩種方法。
54
從主控模塊開始,沿著軟件的控制層次向下移動,從而逐漸把各個模塊結合起來。(深度優(yōu)先;寬度優(yōu)先)。用下述步驟實現自頂向下的結合策略: 第一步:對主控制模塊進行測試,測試時用存根程序代替所有直接附屬于主控制模塊的模塊; 第二步:根據選定的結合策略(深度、寬度優(yōu)先),每次用一個實際模塊代換一個存根程序(新結合進來的模塊往往需要新的存根程序); 第三步:再結合下一個模塊的同時進行測試;
第四步:為了保證新加入的模塊沒有引進新的錯誤,可能需要進行回歸測試(全部或部分地重復以前做過的測試)。
1)自頂向下結合存根程序代替被測試的模塊所調用的模塊。因此存根程序也可以稱為“虛擬子程序”。(樁模塊)55自頂向下增式集成測試進行單元測試,這時需配以樁模塊sub1、sub2和sub3(見圖(a)),以模擬被它調用的模塊B、C和D。其后,把模塊B、C和D與頂層模塊A連接起來,再對模塊B和D配以樁模塊sub4和sub5以模擬對模塊E和F的調用。這樣按圖(b)的形式完成測試。最后,去掉樁模塊sub4和sub5,把模塊E和F連上即對完整的結構圖(見圖(c))進行測試。56M1M4M3M2M7M6M5M8深度優(yōu)先策略先組裝在軟件結構的一條主控制通路上的所有模塊。(主控路徑的選擇決定于軟件的應用特性)如:先結合M1,M2和M5,接著是M8,如果M2需要,可結合M6,然后再構造中央和右側控制通路。寬度優(yōu)先策略 沿著軟件結構的水平移動,把處于同一個控制層次上的所有模塊組裝起來。如:先結合M2,M3和M4,接著是M5,M6,M7,直到所有模塊結合進來。57 從“原子”模塊開始,從底部向上結合模塊進行組裝和測試。用下述步驟實現自底向上的結合策略: 第一步:把低層模塊組合成實現某個特定的軟件子功能的族; 第二步:寫一個驅動程序(用于測試的控制程序),協調測試數據的輸入和輸出; 第三步:對由模塊組成的子功能族進行測試;
第四步:去掉驅動程序,沿軟件結構自底向上移動,把子功能族組合起來形成更大的子功能族。
2)自底向上結合58自底向上增式集成測試圖(a)、(b)和(c)表示:樹狀結構圖中處在最下層的葉結點模塊E、C和F,由于它們不再調用其他模塊,對它們進行單元測試時,只需配以驅動模塊drv1、drv2和drv3,用來模擬B、A和D對它們的調用。完成這三個單元測試以后,再按圖(d)和(e)的形式,分別將模塊B和E及模塊D和F連接起來,在配以驅動模塊drv4和drv5的條件下實施部分集成測試。最后再按圖(f)的形式完成整體的集成測試。59自頂向下測試方法的優(yōu)點:1)不需要測試驅動程序2)能夠在測試的早期實現并驗證系統(tǒng)的主要功能3)能在早期發(fā)現上層模塊的接口錯誤缺點:1)需要樁模塊2)低層關鍵模塊中的錯誤發(fā)現較晚3)測試早期不能充分展開人力。自底向上測試方法的優(yōu)缺點與上述剛好相反!!
不同集成測試策略的比較60 目的:向未來的用戶表明系統(tǒng)能夠象預定要求那樣工作。進一步驗證軟件的有效性。驗證:保證軟件正確地實現了某一特定要求的一系列活動;即:“我們是否正確地構造了產品?”確認:保證軟件的實現滿足了用戶需求的一系列活動。即:“我們是否構造了正確的產品?”軟件有效性:如果軟件的功能和性能如同用戶所合理的期待的那樣,則軟件是有效的。三確認(驗收)測試61 與系統(tǒng)測試類似,但還有一些差別:1)某些已經測試過的純粹技術性的特點可能不需要再次測試;2)對用戶特別感興趣的功能和性能,可能需要增加一些測試;3)通常主要使用生產中的實際數據進行測試;4)可能需要設計并執(zhí)行一些與用戶使用步驟有關的測試。
1、驗收測試的范圍621)驗收測試必須有用戶積極參與,或以用戶為主進行;2)驗收測試一般使用黑盒測試法3)驗收測試有兩種可能的結果:(1)功能和性能與用戶需求一致,軟件是可以接受的;(2)功能和性能與用戶的要求有差距;
驗收測試的特點63642、軟件配置復查復查的目的: 1)保證軟件配置的所有成分齊全 2)各方面的質量都符合要求 3)文檔與程序一致653.Alpha和Beta測試Alpha測試由用戶在開發(fā)者的場所進行,并且在開發(fā)者對用戶的“指導”下進行測試。開發(fā)者負責記錄錯誤和使用中遇到的問題。是在受控的環(huán)境中進行。Beta測試由軟件的最終用戶在一個或多個客戶場所進行。與Alpha測試不同的是,開發(fā)者通常不在測試現場。因此Beta測試是軟件在開發(fā)者不能控制的環(huán)境中的“真實”應用。用戶記錄下Beta測試中遇到的問題(真實的或想象的),并定期報告給開發(fā)者。軟件開發(fā)者對產品進行修改,并準備向全體客戶發(fā)布最終的軟件產品。66四、系統(tǒng)測試(SystemTesting)系統(tǒng)測試,是將通過確認測試的軟件,作為整個基于計算機系統(tǒng)的一個元素,與計算機硬件、外設、某些支持軟件、數據和人員等其它系統(tǒng)元素結合在一起,在實際運行環(huán)境下,對計算機系統(tǒng)進行一系列的組裝測試和確認測試。系統(tǒng)測試的目的在于通過與系統(tǒng)的需求定義作比較,發(fā)現軟件與系統(tǒng)的定義不符合或與之矛盾的地方。67系統(tǒng)測試
(1)恢復測試恢復測試是通過各種手段,強制性地使軟件出錯,而不能正常工作,進而檢查軟件系統(tǒng)的恢復能力。(2)安全測試安全測試的目的在于驗證安裝在系統(tǒng)內的保護機制能否在實際中保護系統(tǒng)且不受非法侵入,不受各種非法的干擾。(3)強度測試強度測試需要在反常的數量、頻率或資源的方式下運行系統(tǒng),以檢驗系統(tǒng)能力的最高實際限度。(4)性能測試性能測試用來測試軟件在集成系統(tǒng)中的運行性能,特別是針對實時系統(tǒng)、嵌入式系統(tǒng)。68恢復測試 恢復測試是要證實在克服硬件故障(包括掉電、硬件或網絡出錯等)后,系統(tǒng)能否正常地繼續(xù)進行工作,并不對系統(tǒng)造成任何損害。為此,可采用各種人工干預的手段,模擬硬件故障,故意造成軟件出錯。并由此檢查:
錯誤探測功能──系統(tǒng)能否發(fā)現硬件失效與故障;能否切換或啟動備用的硬件;在故障發(fā)生時能否保護正在運行的作業(yè)和系統(tǒng)狀態(tài);在系統(tǒng)恢復后能否從最后記錄下來的無錯誤狀態(tài)開始繼續(xù)執(zhí)行作業(yè),等等。掉電測試:69強度測試 強度測試是要檢查在系統(tǒng)運行環(huán)境不正常乃至發(fā)生故障的情況下,系統(tǒng)可以運行到何種程度的測試。例如:
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025至2031年中國電腦控制激光印章雕刻機行業(yè)投資前景及策略咨詢研究報告
- 二零二五年度房地產項目資金監(jiān)管與監(jiān)管機構合作合同
- 2025年度足浴店資產轉讓與品牌輸出協議
- 2025年度水電工程勘察設計一體化承包合同
- 2025年度足療技師崗位培訓與就業(yè)合同
- 2025年度5G通信技術合作投資協議書
- 2025年度法院拍賣合同范本:法院拍賣保證金合同
- 2025年度航空航天技術知識產權許可協議
- 銑床控制系統(tǒng)課程設計
- 飲品主題課程設計
- 中華人民共和國能源法
- 礦山智能化監(jiān)控系統(tǒng)
- 五年級口算題卡每天100題帶答案
- Unit 3 Family Matters Developing Ideas Writing about a Family Memory 教學設計-2024-2025學年高一上學期英語外研版(2019)必修第一冊
- 工程量清單及招標控制價編制工作方案
- 商業(yè)承兌匯票貼現協議
- 普工附有答案
- 《烏魯木齊市國土空間總體規(guī)劃(2021-2035年)》
- 2024年中國租賃業(yè)調查報告-畢馬威-202407
- 中俄東線天然氣管道工程(永清-上海)環(huán)境影響報告書
- 2024年長沙市中考數學真題試卷及答案
評論
0/150
提交評論