黑盒測試和白盒測試_第1頁
黑盒測試和白盒測試_第2頁
黑盒測試和白盒測試_第3頁
黑盒測試和白盒測試_第4頁
黑盒測試和白盒測試_第5頁
已閱讀5頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、軟件測試報告 黑盒測試與白盒測試軟件測試程序一從鍵盤輸入三個數(shù),判斷由這三個數(shù)能否夠成一個三角形,如能并判定是等邊三角形還是等腰三角形、直角三角形,還是其它三角形,當輸入的三個數(shù)中有一個小于等于0時,程序結(jié)束。#include <iostream>using namespace std;void sort(int &a,int &b,int &c) if( a<b ) int temp=a; a=b; b=temp; if( b<c ) int temp=b; b=c; c=temp; if( a<b ) int temp=a; a=b;

2、b=temp; int main() int a,b,c; while(1) cout<<endl<<"輸入三角形的三條邊(整數(shù)):n" cin>>a>>b>>c; sort(a,b,c); if(c<=0) cout<<"無效數(shù)字.n" break; if( a>=(b+c) ) cout<<"不能構(gòu)成三角形.n" continue; if( (a=b) | (b=c) ) cout<<"等腰三角形.n"

3、if( (a=b)&&(b=c) ) cout<<"等邊三角形.n" int x=a*a-b*b-c*c; if ( x=0 ) cout<<"直角三角形.n" else if ( x<0 ) cout<<"鈍角三角形.n" else cout<<"銳角三角形.n" return 0;黑盒測試一、等價類劃分某程序規(guī)定:"輸入三個整數(shù) a 、 b 、 c 分別作為三邊的邊長構(gòu)成三角形。通過程序判定所構(gòu)成的三角形的類型,當此三角形為一般三角

4、形、等腰三角形及等邊三角形時,分別作計算 "。用等價類劃分方法為該程序進行測試用例設(shè)計。(三角形問題的復雜之處在于輸入與輸出之間的關(guān)系比較復雜。) 解:分析題目中給出和隱含的對輸入條件的要求: (1)整數(shù)  (2)三個數(shù) (3)非零數(shù) (4)正數(shù)  (5)兩邊之和大于第三邊     (6)等腰 (7)等邊 如果 a 、 b 、 c 滿足條件( 1 ) ( 4 ),則輸出下列四種情況之一:如果不滿足條件(5),則程序輸出為 " 非三角形 " 。 2

5、)如果三條邊相等即滿足條件(7),則程序輸出為 " 等邊三角形 " 。3)如果只有兩條邊相等、即滿足條件(6),則程序輸出為 " 等腰三角形 " 。4)如果三條邊都不相等,則程序輸出為 " 一般三角形 " 。 列出等價類表并編號 覆蓋有效等價類的測試用例:    a      b      c         

6、0;    覆蓋等價類號碼3      4      5             (1)-(7)    4      4      5       &

7、#160;     (1)-(7),(8)    4      5      5             (1)-(7),(9)        5      4   &#

8、160;  5             (1)-(7),(10)    4      4      4             (1)-(7),(11)  覆蓋無效等價類的測試用例:白盒測試業(yè)務(wù)處理流

9、程的思路用流程圖表示如下:1)跟前面三組分析一樣,把相同的邏輯提取到一個函數(shù)中,然后三次調(diào)用。2)根據(jù)直角三角形的特點:斜邊是最長的,所以我們可以事先寫一個函數(shù)來找到最長的邊,然后把它賦值給c,這樣處理之后,只需要一次調(diào)用判定(a2+b2=c2)的函數(shù)了。程序設(shè)計對于軟件的質(zhì)量和軟件實施過程的難易程度起著至關(guān)重要的作用。好的設(shè)計,即使聘用沒什么經(jīng)驗的開發(fā)人員都很容易產(chǎn)生出高質(zhì)量的代碼出來;而差的設(shè)計,即使是經(jīng)驗很豐富的開發(fā)人員也很容易產(chǎn)生缺陷,特別是可重用性、可測試性、可維護性、可擴展性等方面的缺陷。經(jīng)過以上的分析,下面來看一下如何設(shè)計。在下圖中,每個方框都使用一個函數(shù)來實現(xiàn),為了跟用戶界面分

10、開,最頂上的函數(shù)不要寫在main函數(shù)中。把思路用流程圖的方式表達出來,不用停留在腦袋里:具體的函數(shù)的調(diào)用關(guān)系圖:復雜模塊triangleType的流程圖:測試環(huán)境 WindowsXP系統(tǒng)環(huán)境下運行Microsoft Visual C+ 6.0l 軟件測試程序二通過輸入年份和天數(shù),用來判定是否是閏年和所查詢的是具體的幾月幾日。例如:輸入2000年第60天會顯示2000年2月29日 輸入2000年第61天會顯示2000年3月1日 輸入2001年第60天會顯示2001年3月1日 輸入2001年第59天會顯示2001年2月28日一、黑盒測試測試環(huán)境:Windows XP, JAVA-PRO劃分等價類:

11、根據(jù)計算閏年公式,得出以下幾個輸出情況,由輸入數(shù)據(jù)計算正確的為有效等價類,不正確的為無效等價類。輸入條件有效等價類無效等價類是閏年X%4=0&&X%100!=0)|(X%400=0)X%4!=0&&X%100=0)|(X%400!=0)不是閏年X%4!=0&&X%100=0)|(X%400!=0)X%4=0&&X%100!=0)|(X%400=0)確定測試用例在軟件程序中輸入兩個數(shù)字分別為年和天數(shù)。按照劃分等價類分成閏年和不是閏年將其列表如下:序號年和天數(shù)覆蓋等價類結(jié)果1200060(1)(2)閏年2000年2月29日220006

12、1(1)(2)閏年2000年3月1日3200159(3)(4)不是閏年2001年2月28日4200160(3)(4)不是閏年2001年3月1日結(jié)果:測試分析:為了全面覆蓋所有的分支中的條件,在程序中輸入了各種可能的數(shù)據(jù)組合,從測試中可以看出來,該程序的所有分支中的各個條件的所有可能的情況都至少執(zhí)行了一次,沒有發(fā)現(xiàn)錯誤。二、白盒測試測試環(huán)境:Windows XP, JAVA-PROimport java.io.*;public class LeapYear public static void main(String arg)throws IOException String n,m; int

13、s,y,b=0,c,d,e; BufferedReader keyin=new BufferedReader(new InputStreamReader(System.in);從鍵盤輸入數(shù)字 System.out.println("請輸入你想測的年份和小于365的數(shù)字"); n=keyin.readLine(); m=keyin.readLine(); s=Integer.parseInt(n); 將輸入數(shù)據(jù)轉(zhuǎn)換成整形數(shù)據(jù) y=Integer.parseInt(m); 將輸入數(shù)據(jù)轉(zhuǎn)換成整形數(shù)據(jù) if(s%4=0&&s%100!=0)|(s%400=0)&am

14、p;&y>31) 判斷閏年的公式 int a=31,29,31,30,31,30,31,31,30,31,30,31; 設(shè)置天數(shù)的數(shù)組 d=y/30; c=d+1; e=y; while(e>0) e=e-ab; 對天數(shù)進行計算 b+; e=e+ab-1; System.out.println(s+"年"+c+"月"+e+"日" ); else int a=31,28,31,30,31,30,31,31,30,31,30,31;設(shè)置天數(shù)的數(shù)組 d=y/30; c=d+1; e=y; while(e>0) e=

15、e-ab; 對天數(shù)進行計算 b+; e=e+ab-1; System.out.println(s+"年"+c+"月"+e+"日" ); 輸出結(jié)果XX年XX月XX日輸入年份和天數(shù)判斷是否是閏年閏年不是閏年TRUE 1FALSE 2語句覆蓋本程序有兩個不同的路徑測試用例對應(yīng)輸出2000602000年2月29日2000612000年3月1日2001592001年2月28日2001602001年3月1日圖(1-1)條件覆蓋測試用例取值條件具體取值通過路徑200060輸出:2000年2月29日TRUEX%4=0&&X%100!=

16、0)|(X%400=0)P(1)200061輸出:2000年3月1日TRUEX%4=0&&X%100!=0)|(X%400=0)P(1)200159輸出:2001年2月28日FALSEX%4!=0&&X%100=0)|(X%400!=0)P(2)200160輸出:2001年3月1日FALSEX%4!=0&&X%100=0)|(X%400!=0)P(2)圖(1-2)白盒測試檢查了軟件內(nèi)部的活動是否都符合設(shè)計要求,在這里,我們利用邏輯覆蓋中的語句覆蓋以及條件覆蓋,設(shè)計相應(yīng)的測試用例,是分支中的各個條件的所有可能的情況都至少執(zhí)行了一次,并將數(shù)據(jù)繪制成表

17、,以便研究發(fā)現(xiàn)錯誤或Bug(見圖1-1,表1-2)經(jīng)過白盒測試,程序運行正常,沒有發(fā)現(xiàn)錯誤。程序清單:import java.io.*;public class LeapYear public static void main(String arg)throws IOException String n,m; int s,y,b=0,c,d,e; BufferedReaderkeyin=newBufferedReader(newInputStreamReader(System.in); System.out.println("請輸入你想測的年份和小于365的數(shù)字"); n=keyin.readLine(); m=keyin.readLine(); s=Integer.parseInt(n); y=Integer.parseInt(m); if(s%4=0&&s%100!=0)|(s%400=0)&&y>31) int a=31,29,31,30,31,30,31,31,30,31,30,31; d=y/30; c=d+1; e=y; whi

溫馨提示

  • 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論