編寫測試用例(詳細(xì))課件_第1頁
編寫測試用例(詳細(xì))課件_第2頁
編寫測試用例(詳細(xì))課件_第3頁
編寫測試用例(詳細(xì))課件_第4頁
編寫測試用例(詳細(xì))課件_第5頁
已閱讀5頁,還剩65頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

如何設(shè)計(jì)編寫測試用例(淺析)測試用例的概念測試用例設(shè)計(jì)原則測試用例的編寫方法實(shí)例:紙杯的測試用例設(shè)計(jì)如何設(shè)計(jì)編寫測試用例(淺析)測試用例的概念1如果沒有測試用例測試人員將會(huì)如何測試?如果沒有測試用例測試人員將會(huì)如何測試?2隨機(jī)測試存在的問題不知道是否較全面的測試了所有功能測試的覆蓋率無法衡量對新版本的重復(fù)測試很難實(shí)施無法對測試質(zhì)量進(jìn)行有效評估無法形成有效的知識積累......隨機(jī)測試存在的問題不知道是否較全面的測試了所有功能3測試用例的特征最有可能抓住錯(cuò)誤的不是重復(fù)的、多余的一組相似測試用例中最有效的既不是太簡單,也不是太復(fù)雜測試用例的特征最有可能抓住錯(cuò)誤的4測試用例的概念如何以最少的人力、資源投入,在最短的時(shí)間內(nèi)完成測試,發(fā)現(xiàn)軟件系統(tǒng)的缺陷,保證軟件的優(yōu)良品質(zhì),是軟件公司探索和追求的目標(biāo)測試用例是測試工作的指導(dǎo),是軟件測試的必須遵守的準(zhǔn)則,更是軟件測試質(zhì)量穩(wěn)定的根本保障測試用例的概念如何以最少的人力、資源投入,在最短的時(shí)間內(nèi)完成5測試用例的概念測試用例是指為實(shí)施測試而向被測試系統(tǒng)提供的輸入數(shù)據(jù),操作或者各種環(huán)境設(shè)置以及期望結(jié)果的一個(gè)特定集合。其實(shí)簡單來說,測試用例就是解決要測什么,怎么測和如何衡量的問題。測試用例的概念測試用例是指為實(shí)施測試而向被測試系統(tǒng)提供的輸入6舉例登錄功能,說出一些簡單的測試用例舉例登錄功能,說出一些簡單的測試用例7舉例簡單用例一般的用例舉例簡單用例8舉例比較詳細(xì)的用例舉例比較詳細(xì)的用例9測試用例設(shè)計(jì)原則測試用例對需求覆蓋的完整性;測試用例的有效性;測試用例的可理解性;測試用例的清晰性;測試用例的可維護(hù)性。測試用例設(shè)計(jì)原則測試用例對需求覆蓋的完整性;10需求的覆蓋完整性做到對需求的完全理解,從全局上把握需求對需求進(jìn)行歸類,包括正常流,異常流等,做到對需求的100%覆蓋。(其中有一個(gè)好的方法就是用mm圖把需求分解了)把基本路徑分解出來,將需求歸類。理順了需求,用例寫起來就順手多了。需求的覆蓋完整性做到對需求的完全理解,從全局上把握需求11需求的覆蓋完整性需求的覆蓋完整性12測試用例的有效性測試用例應(yīng)該包含清晰的輸入數(shù)據(jù)以及預(yù)期輸出如果環(huán)境或者業(yè)務(wù)發(fā)生變更后,測試數(shù)據(jù)必須進(jìn)行更新維護(hù)用例基于數(shù)據(jù)驅(qū)動(dòng)測試用例的有效性測試用例應(yīng)該包含清晰的輸入數(shù)據(jù)以及預(yù)期輸出13測試用例的可理解性測試用例步驟必須描述清晰,不能出現(xiàn)模棱兩可以及重復(fù)的話語測試用例應(yīng)該按照一定的順序進(jìn)行編寫,這樣執(zhí)行的時(shí)候效率比較高測試用例的可理解性測試用例步驟必須描述清晰,不能出現(xiàn)模棱兩可14測試用例的清晰性測試用例的驗(yàn)證點(diǎn)必須明確清晰重點(diǎn)突出一個(gè)用例進(jìn)行一個(gè)功能點(diǎn)的驗(yàn)證,一個(gè)蘿卜一個(gè)坑。對于流程性的用例建議按照流程順序進(jìn)行用例安排,從第一個(gè)驗(yàn)證點(diǎn)到最后一個(gè)驗(yàn)證點(diǎn),組成流程的開始到結(jié)束,方便測試執(zhí)行。測試用例包含前置條件的必須將前置條件描述清楚,包括入口等。測試用例的清晰性測試用例的驗(yàn)證點(diǎn)必須明確清晰重點(diǎn)突出15測試用例的可維護(hù)性測試用例因?yàn)闃I(yè)務(wù)需求發(fā)生變更的時(shí)候,需要及時(shí)更新維護(hù)測試用例,做到測試用例的實(shí)時(shí)性與有效性測試用例需要細(xì)化和不斷的完善,是個(gè)循序漸進(jìn)的過程通過測試實(shí)踐檢驗(yàn)測試用例并添加,刪除,修改測試用例。測試用例的可維護(hù)性測試用例因?yàn)闃I(yè)務(wù)需求發(fā)生變更的時(shí)候,需要及16小結(jié)RossCollard在"UseCaseTesting"一文中說:"測試用例的前10%到15%可以發(fā)現(xiàn)75%到90%的重要缺陷"。如果你在項(xiàng)目或日常結(jié)束后,仔細(xì)的分析過我們的bug列表,那么你會(huì)覺得這句話非常適用。合理的提高我們的測試效率就是在編寫測試用例的時(shí)候進(jìn)行測試用例優(yōu)先級的劃分。如何劃分1.用于冒煙測試的用例為最高優(yōu)先級2.把基本路徑以及各模塊主功能的測試標(biāo)注為高優(yōu)先級別3.把你所有錯(cuò)誤和邊界值或確認(rèn)測試標(biāo)注為中優(yōu)先級別4.把可用性測試,兼容性測試等標(biāo)注為低優(yōu)先級別5.將功能測試用例分為嚴(yán)重和不嚴(yán)重兩類,對于不嚴(yán)重的功能測試用例降級為低優(yōu)先級用例。小結(jié)RossCollard在"UseCaseTesti17測試用例編寫方法等價(jià)類劃分

如何測試一個(gè)兩位數(shù)加法計(jì)算器的程序?測試需求:測試兩個(gè)參數(shù)的值相加后的結(jié)果是否正確。

其中:1.輸入的數(shù)值在-99到99之間。2.大于99或小于-99的輸入應(yīng)被拒絕,并顯示錯(cuò)誤信息。根據(jù)測試需求開始測試。分別給第1個(gè)參數(shù)和第2個(gè)參數(shù)輸入表中的值,然后得到測試結(jié)果。如圖:

測試用例編寫方法等價(jià)類劃分18測試用例編寫方法等價(jià)類劃分等價(jià)類劃分法作為一種最為典型的黑盒測試方法,它完全不考慮程序的內(nèi)部結(jié)構(gòu),而只是根據(jù)程序的要求和說明進(jìn)行測試用例的設(shè)計(jì)。如何去做?測試人員要對需求規(guī)格說明書中的各項(xiàng)需求,尤其是功能需求進(jìn)行細(xì)致分析,然后把程序的輸入域劃分程若干個(gè)部分,從每個(gè)部分中選取少數(shù)代表性數(shù)據(jù)作為測試用例。經(jīng)過這種劃分,每一類的代表性數(shù)據(jù)在測試中的作用都等價(jià)于這一類中的其他值。如何區(qū)分有效數(shù)據(jù)等價(jià)類與無效數(shù)據(jù)等價(jià)類有效數(shù)據(jù)等價(jià)類就是由那些對程序的規(guī)格說明有意義的,合理的輸入數(shù)據(jù)所構(gòu)成的集合。無效數(shù)據(jù)等價(jià)類就是那些對程序的規(guī)格說明不合理的或者無意義的輸入數(shù)據(jù)所構(gòu)成的集合。測試用例編寫方法等價(jià)類劃分19舉例等價(jià)類表

測試用例表

舉例等價(jià)類表20舉例在測試“-99<=數(shù)值<=99”的這個(gè)等價(jià)類區(qū)間的時(shí)候,會(huì)發(fā)現(xiàn)如10+40,-20+30,-30+(-30)這類的正數(shù)相加,正數(shù)負(fù)數(shù)相加,負(fù)數(shù)相加也是不同的等價(jià)區(qū)間。因此可以使用更多的等價(jià)類劃分。等價(jià)類表舉例在測試“-99<=數(shù)值<=99”的這個(gè)等價(jià)類區(qū)間的時(shí)候21舉例測試用例舉例測試用例22等價(jià)類方法小結(jié)等價(jià)類技術(shù)提供了一個(gè)選擇哪些數(shù)值,舍棄哪些數(shù)值的測試用例設(shè)計(jì)方法。運(yùn)用等價(jià)類技術(shù),可以把相似輸出,輸入,操作分成組,這些組就是等價(jià)區(qū)間。只要從等價(jià)區(qū)間選擇一到兩個(gè)有代表性的值作為測試用例來執(zhí)行就等同于測試了所有值。當(dāng)然,也可能存在編程人員編寫了異常處理的代碼(使用多個(gè)測試用例才能發(fā)現(xiàn)這個(gè)錯(cuò)誤),但是在發(fā)現(xiàn)這種類型的缺陷方面存在其他更為有效的技術(shù)(比如代碼審查)。由之前的案例可以看出,運(yùn)用等價(jià)類方法的步驟是:1.劃分等價(jià)類(依據(jù)是需求)2.建立等價(jià)類表(有效等價(jià)類和無效等價(jià)類)3.設(shè)計(jì)測試用例等價(jià)類方法小結(jié)等價(jià)類技術(shù)提供了一個(gè)選擇哪些數(shù)值,舍棄哪些數(shù)值23邊界值分析邊界值分析也是一種黑盒測試方法,是一種和等價(jià)類相關(guān)的技術(shù),它具有很強(qiáng)的發(fā)現(xiàn)程序錯(cuò)誤的能力。如果軟件的能力達(dá)到極限時(shí)能夠運(yùn)行,那么在正常情況下就不會(huì)有什么問題。長期的測試工作經(jīng)驗(yàn)說明“錯(cuò)誤隱藏在角落,問題聚焦在邊界上”,大量的錯(cuò)誤是發(fā)生在輸入或者輸出的邊界上,而不是發(fā)生在輸入輸出的范圍內(nèi)。因此,正對各種邊界值情況設(shè)計(jì)測試用例,可以查出更多的錯(cuò)誤。同樣以上個(gè)程序?yàn)榘咐?,簡單設(shè)計(jì)測試用例,如圖:邊界值分析邊界值分析也是一種黑盒測試方法,是一種和等價(jià)類相關(guān)24其他測試方法軟件測試有兩個(gè)基本方法:通過測試和失敗測試通過測試:主要用于驗(yàn)證系統(tǒng)和它的需求是否一致,確認(rèn)軟件至少能做什么,一般通過分析需求說明書設(shè)計(jì)測試用例。為了確定程序是否滿足目標(biāo),就必須執(zhí)行通過測試。失敗測試:確信軟件在普通情況下正確運(yùn)行之后,就可以采取各種手段找出缺陷。純粹為了破壞軟件而設(shè)計(jì)和執(zhí)行的測試用例稱為失敗測試或迫使出錯(cuò)測試。失敗測試主要用于證明“一個(gè)系統(tǒng)不做不需要它做的事情”。也就是說,要設(shè)計(jì)測試用例來考察程序超出需求規(guī)格說明的嚴(yán)格范圍時(shí)的行為。失敗測試雖然與通過測試看起來相似,但是它是蓄意攻擊軟件的薄弱環(huán)節(jié)。其他測試方法軟件測試有兩個(gè)基本方法:通過測試和失敗測試25其他測試方法錯(cuò)誤猜測:(錯(cuò)誤推測)本身不是一種測試技術(shù),而是一種可以運(yùn)用到所有測試技術(shù)中產(chǎn)生更加有效的一種測試的技能。錯(cuò)誤猜測是基于經(jīng)驗(yàn)和直覺推測程序中所有可能存在的各種錯(cuò)誤,從而有正對性的設(shè)計(jì)測試用例的方法。隨機(jī)測試:隨機(jī)測試指測試中的所有輸入數(shù)據(jù)都是隨機(jī)生成的,其目標(biāo)是模擬用戶的操作。其他測試方法錯(cuò)誤猜測:(錯(cuò)誤推測)本身不是一種測試技術(shù),而是26測試方法的選擇一個(gè)好的測試方法將給軟件測試帶來事半功倍的效果。在實(shí)際的測試工作中可以按照以下原則運(yùn)用以上所學(xué)習(xí)的測試技術(shù):1.在任何情況下都必須使用邊界值分析方法。經(jīng)驗(yàn)表明,用這種方法設(shè)計(jì)出的測試用例發(fā)現(xiàn)程序錯(cuò)誤的能力最強(qiáng)。2.用等價(jià)類劃分方法補(bǔ)充一些測試用例。3.用錯(cuò)誤推測法再增加一些測試用例。4.如果程序的功能說明中含有輸入條件的組合,應(yīng)在一開始就選擇用因果圖法。5.如果程序的某功能適合自動(dòng)測試,則可采用自動(dòng)測試方法以及隨機(jī)測試方法進(jìn)行測試。測試方法的選擇一個(gè)好的測試方法將給軟件測試帶來事半功倍的效果27幫助建議1.你是否感覺測試的時(shí)候思維很混亂,或者總覺得有些功能沒有測到,而一些功能已經(jīng)測過好幾遍?幫助建議:請明確你的需求,是否做到覆蓋100%。你的用例優(yōu)先級是否設(shè)置合理。2.在測試實(shí)踐緊迫的情況下,你不知道要測什么,或者要先測哪些功能?幫助建議:那么你需要調(diào)整自己的用例優(yōu)先級,順帶回去好好整理整理需求。3.在編寫測試用例的時(shí)候先去學(xué)習(xí)前輩們的優(yōu)秀做法。在學(xué)習(xí)別人優(yōu)秀成果的基礎(chǔ)上,編寫自己的用例。幫助建議1.你是否感覺測試的時(shí)候思維很混亂,或者總覺得有些28實(shí)例:紙杯的測試用例設(shè)計(jì)用戶需求:一個(gè)帶廣告圖案的花紙杯實(shí)例:紙杯的測試用例設(shè)計(jì)用戶需求:一個(gè)帶廣告圖案的花紙杯29杯子特性杯子的容量:能裝多少升水,空杯,半杯,滿杯杯子的型狀:圓型,上面口大,下面小。杯子的材料:紙杯杯子的抗摔能力:風(fēng)吹是否會(huì)倒,摔一次是否會(huì)摔壞,摔多次是否會(huì)摔壞杯子的耐溫性:裝冷水,冰水,熱水杯子特性杯子的容量:能裝多少升水,空杯,半杯,滿杯30廣告圖案廣告內(nèi)容與圖案碰水是否會(huì)掉色廣告內(nèi)容與圖案是否合法廣告內(nèi)容與圖案是否容易剝落廣告內(nèi)容與圖案是否符合某個(gè)名族的禁忌廣告圖案廣告內(nèi)容與圖案碰水是否會(huì)掉色31可用性及安全性可用性1.裝入液體多久后會(huì)漏水2.裝入熱水多久后可以變溫,裝入冰水多久后可以融化3.如果裝入的不是液體,像石頭,沙子,鐵塊等安全性1.裝入不同液體,是否會(huì)有化學(xué)反應(yīng)。比如:可樂,咖啡等飲料2.裝入熱水杯子是不是會(huì)變型和異味3.可以加入當(dāng)熱水小于多少度(是一個(gè)確定值)時(shí),手不能被燙傷??捎眯约鞍踩钥捎眯?2易用性和性能易用性1.不同人群是否能適合杯子的型狀,包括握杯的感覺和喝水的感覺2.不同人群是否能接受杯子的廣告內(nèi)容與圖案3.紙杯杯壁的薄厚,杯深是否可以讓消費(fèi)者接受性能1.杯子在50,80度的水溫下可以使用多少次2.倒?jié)M開水后,放入冰箱冷凍結(jié)冰,取出在融化后杯子是否可以繼續(xù)使用。

易用性和性能易用性33你有不明白的地方嗎?你有不明白的地方嗎?34謝謝

看!謝謝觀看!35如何設(shè)計(jì)編寫測試用例(淺析)測試用例的概念測試用例設(shè)計(jì)原則測試用例的編寫方法實(shí)例:紙杯的測試用例設(shè)計(jì)如何設(shè)計(jì)編寫測試用例(淺析)測試用例的概念36如果沒有測試用例測試人員將會(huì)如何測試?如果沒有測試用例測試人員將會(huì)如何測試?37隨機(jī)測試存在的問題不知道是否較全面的測試了所有功能測試的覆蓋率無法衡量對新版本的重復(fù)測試很難實(shí)施無法對測試質(zhì)量進(jìn)行有效評估無法形成有效的知識積累......隨機(jī)測試存在的問題不知道是否較全面的測試了所有功能38測試用例的特征最有可能抓住錯(cuò)誤的不是重復(fù)的、多余的一組相似測試用例中最有效的既不是太簡單,也不是太復(fù)雜測試用例的特征最有可能抓住錯(cuò)誤的39測試用例的概念如何以最少的人力、資源投入,在最短的時(shí)間內(nèi)完成測試,發(fā)現(xiàn)軟件系統(tǒng)的缺陷,保證軟件的優(yōu)良品質(zhì),是軟件公司探索和追求的目標(biāo)測試用例是測試工作的指導(dǎo),是軟件測試的必須遵守的準(zhǔn)則,更是軟件測試質(zhì)量穩(wěn)定的根本保障測試用例的概念如何以最少的人力、資源投入,在最短的時(shí)間內(nèi)完成40測試用例的概念測試用例是指為實(shí)施測試而向被測試系統(tǒng)提供的輸入數(shù)據(jù),操作或者各種環(huán)境設(shè)置以及期望結(jié)果的一個(gè)特定集合。其實(shí)簡單來說,測試用例就是解決要測什么,怎么測和如何衡量的問題。測試用例的概念測試用例是指為實(shí)施測試而向被測試系統(tǒng)提供的輸入41舉例登錄功能,說出一些簡單的測試用例舉例登錄功能,說出一些簡單的測試用例42舉例簡單用例一般的用例舉例簡單用例43舉例比較詳細(xì)的用例舉例比較詳細(xì)的用例44測試用例設(shè)計(jì)原則測試用例對需求覆蓋的完整性;測試用例的有效性;測試用例的可理解性;測試用例的清晰性;測試用例的可維護(hù)性。測試用例設(shè)計(jì)原則測試用例對需求覆蓋的完整性;45需求的覆蓋完整性做到對需求的完全理解,從全局上把握需求對需求進(jìn)行歸類,包括正常流,異常流等,做到對需求的100%覆蓋。(其中有一個(gè)好的方法就是用mm圖把需求分解了)把基本路徑分解出來,將需求歸類。理順了需求,用例寫起來就順手多了。需求的覆蓋完整性做到對需求的完全理解,從全局上把握需求46需求的覆蓋完整性需求的覆蓋完整性47測試用例的有效性測試用例應(yīng)該包含清晰的輸入數(shù)據(jù)以及預(yù)期輸出如果環(huán)境或者業(yè)務(wù)發(fā)生變更后,測試數(shù)據(jù)必須進(jìn)行更新維護(hù)用例基于數(shù)據(jù)驅(qū)動(dòng)測試用例的有效性測試用例應(yīng)該包含清晰的輸入數(shù)據(jù)以及預(yù)期輸出48測試用例的可理解性測試用例步驟必須描述清晰,不能出現(xiàn)模棱兩可以及重復(fù)的話語測試用例應(yīng)該按照一定的順序進(jìn)行編寫,這樣執(zhí)行的時(shí)候效率比較高測試用例的可理解性測試用例步驟必須描述清晰,不能出現(xiàn)模棱兩可49測試用例的清晰性測試用例的驗(yàn)證點(diǎn)必須明確清晰重點(diǎn)突出一個(gè)用例進(jìn)行一個(gè)功能點(diǎn)的驗(yàn)證,一個(gè)蘿卜一個(gè)坑。對于流程性的用例建議按照流程順序進(jìn)行用例安排,從第一個(gè)驗(yàn)證點(diǎn)到最后一個(gè)驗(yàn)證點(diǎn),組成流程的開始到結(jié)束,方便測試執(zhí)行。測試用例包含前置條件的必須將前置條件描述清楚,包括入口等。測試用例的清晰性測試用例的驗(yàn)證點(diǎn)必須明確清晰重點(diǎn)突出50測試用例的可維護(hù)性測試用例因?yàn)闃I(yè)務(wù)需求發(fā)生變更的時(shí)候,需要及時(shí)更新維護(hù)測試用例,做到測試用例的實(shí)時(shí)性與有效性測試用例需要細(xì)化和不斷的完善,是個(gè)循序漸進(jìn)的過程通過測試實(shí)踐檢驗(yàn)測試用例并添加,刪除,修改測試用例。測試用例的可維護(hù)性測試用例因?yàn)闃I(yè)務(wù)需求發(fā)生變更的時(shí)候,需要及51小結(jié)RossCollard在"UseCaseTesting"一文中說:"測試用例的前10%到15%可以發(fā)現(xiàn)75%到90%的重要缺陷"。如果你在項(xiàng)目或日常結(jié)束后,仔細(xì)的分析過我們的bug列表,那么你會(huì)覺得這句話非常適用。合理的提高我們的測試效率就是在編寫測試用例的時(shí)候進(jìn)行測試用例優(yōu)先級的劃分。如何劃分1.用于冒煙測試的用例為最高優(yōu)先級2.把基本路徑以及各模塊主功能的測試標(biāo)注為高優(yōu)先級別3.把你所有錯(cuò)誤和邊界值或確認(rèn)測試標(biāo)注為中優(yōu)先級別4.把可用性測試,兼容性測試等標(biāo)注為低優(yōu)先級別5.將功能測試用例分為嚴(yán)重和不嚴(yán)重兩類,對于不嚴(yán)重的功能測試用例降級為低優(yōu)先級用例。小結(jié)RossCollard在"UseCaseTesti52測試用例編寫方法等價(jià)類劃分

如何測試一個(gè)兩位數(shù)加法計(jì)算器的程序?測試需求:測試兩個(gè)參數(shù)的值相加后的結(jié)果是否正確。

其中:1.輸入的數(shù)值在-99到99之間。2.大于99或小于-99的輸入應(yīng)被拒絕,并顯示錯(cuò)誤信息。根據(jù)測試需求開始測試。分別給第1個(gè)參數(shù)和第2個(gè)參數(shù)輸入表中的值,然后得到測試結(jié)果。如圖:

測試用例編寫方法等價(jià)類劃分53測試用例編寫方法等價(jià)類劃分等價(jià)類劃分法作為一種最為典型的黑盒測試方法,它完全不考慮程序的內(nèi)部結(jié)構(gòu),而只是根據(jù)程序的要求和說明進(jìn)行測試用例的設(shè)計(jì)。如何去做?測試人員要對需求規(guī)格說明書中的各項(xiàng)需求,尤其是功能需求進(jìn)行細(xì)致分析,然后把程序的輸入域劃分程若干個(gè)部分,從每個(gè)部分中選取少數(shù)代表性數(shù)據(jù)作為測試用例。經(jīng)過這種劃分,每一類的代表性數(shù)據(jù)在測試中的作用都等價(jià)于這一類中的其他值。如何區(qū)分有效數(shù)據(jù)等價(jià)類與無效數(shù)據(jù)等價(jià)類有效數(shù)據(jù)等價(jià)類就是由那些對程序的規(guī)格說明有意義的,合理的輸入數(shù)據(jù)所構(gòu)成的集合。無效數(shù)據(jù)等價(jià)類就是那些對程序的規(guī)格說明不合理的或者無意義的輸入數(shù)據(jù)所構(gòu)成的集合。測試用例編寫方法等價(jià)類劃分54舉例等價(jià)類表

測試用例表

舉例等價(jià)類表55舉例在測試“-99<=數(shù)值<=99”的這個(gè)等價(jià)類區(qū)間的時(shí)候,會(huì)發(fā)現(xiàn)如10+40,-20+30,-30+(-30)這類的正數(shù)相加,正數(shù)負(fù)數(shù)相加,負(fù)數(shù)相加也是不同的等價(jià)區(qū)間。因此可以使用更多的等價(jià)類劃分。等價(jià)類表舉例在測試“-99<=數(shù)值<=99”的這個(gè)等價(jià)類區(qū)間的時(shí)候56舉例測試用例舉例測試用例57等價(jià)類方法小結(jié)等價(jià)類技術(shù)提供了一個(gè)選擇哪些數(shù)值,舍棄哪些數(shù)值的測試用例設(shè)計(jì)方法。運(yùn)用等價(jià)類技術(shù),可以把相似輸出,輸入,操作分成組,這些組就是等價(jià)區(qū)間。只要從等價(jià)區(qū)間選擇一到兩個(gè)有代表性的值作為測試用例來執(zhí)行就等同于測試了所有值。當(dāng)然,也可能存在編程人員編寫了異常處理的代碼(使用多個(gè)測試用例才能發(fā)現(xiàn)這個(gè)錯(cuò)誤),但是在發(fā)現(xiàn)這種類型的缺陷方面存在其他更為有效的技術(shù)(比如代碼審查)。由之前的案例可以看出,運(yùn)用等價(jià)類方法的步驟是:1.劃分等價(jià)類(依據(jù)是需求)2.建立等價(jià)類表(有效等價(jià)類和無效等價(jià)類)3.設(shè)計(jì)測試用例等價(jià)類方法小結(jié)等價(jià)類技術(shù)提供了一個(gè)選擇哪些數(shù)值,舍棄哪些數(shù)值58邊界值分析邊界值分析也是一種黑盒測試方法,是一種和等價(jià)類相關(guān)的技術(shù),它具有很強(qiáng)的發(fā)現(xiàn)程序錯(cuò)誤的能力。如果軟件的能力達(dá)到極限時(shí)能夠運(yùn)行,那么在正常情況下就不會(huì)有什么問題。長期的測試工作經(jīng)驗(yàn)說明“錯(cuò)誤隱藏在角落,問題聚焦在邊界上”,大量的錯(cuò)誤是發(fā)生在輸入或者輸出的邊界上,而不是發(fā)生在輸入輸出的范圍內(nèi)。因此,正對各種邊界值情況設(shè)計(jì)測試用例,可以查出更多的錯(cuò)誤。同樣以上個(gè)程序?yàn)榘咐?,簡單設(shè)計(jì)測試用例,如圖:邊界值分析邊界值分析也是一種黑盒測試方法,是一種和等價(jià)類相關(guān)59其他測試方法軟件測試有兩個(gè)基本方法:通過測試和失敗測試通過測試:主要用于驗(yàn)證系統(tǒng)和它的需求是否一致,確認(rèn)軟件至少能做什么,一般通過分析需求說明書設(shè)計(jì)測試用例。為了確定程序是否滿足目標(biāo),就必須執(zhí)行通過測試。失敗測試:確信軟件在普通情況下正確運(yùn)行之后,就可以采取各種手段找出缺陷。純粹為了破壞軟件而設(shè)計(jì)和執(zhí)行的測試用例稱為失敗測試或迫使出錯(cuò)測試。失敗測試主要用于證明“一個(gè)系統(tǒng)不做不需要它做的事情”。也就是說,要設(shè)計(jì)測試用例來考察程序超出需求規(guī)格說明的嚴(yán)格范圍時(shí)的行為。失敗測試雖然與通過測試看起來相似,但是它是蓄意攻擊軟件的薄弱環(huán)節(jié)。其他測試方法軟件測試有兩個(gè)基本方法:通過測試和失敗測試60其他測試方法錯(cuò)誤猜測:(錯(cuò)誤推測)本身不是一種測試技術(shù),而是一種可以運(yùn)用到所有測試技術(shù)中產(chǎn)生更加有效的一種測試的技能。錯(cuò)誤猜測是基于經(jīng)驗(yàn)和直覺推測程序中所有可能存在的各種錯(cuò)誤,從而有正對性的設(shè)計(jì)測試用例的方法。隨機(jī)測試:隨機(jī)測試指測試中的所有輸入數(shù)據(jù)都是隨機(jī)生成的,其目標(biāo)是模擬用戶的操作。其他測試方法錯(cuò)誤猜測:(錯(cuò)誤推測)本身不是一種測試技術(shù),而是61測試方法的選擇一個(gè)好的測試方法將給軟件測試帶來事半功倍的效果。在實(shí)際的測試工作中可以按照以下原則運(yùn)用以上所學(xué)習(xí)的測試技術(shù):1.在任何情況下都必須使用邊界值分析方法。經(jīng)驗(yàn)表明,用這種方法設(shè)計(jì)出的測試用例發(fā)現(xiàn)程序錯(cuò)誤的能力最強(qiáng)。2.用等價(jià)類劃分方法補(bǔ)充一些測試用例。3.用錯(cuò)誤推測法再增加一些測試用例。4.如果程序的功能說明中含有輸入條件的組合,應(yīng)在一開始就選擇用因果圖法。5.如果程序的某功能適合自動(dòng)測試,則可采用自動(dòng)測試方法以及隨機(jī)測試方法進(jìn)行測試。測試方法的選擇一個(gè)好的測試方法將給軟件測試帶

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論