青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Error

C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
  217 Posts :: 61 Stories :: 32 Comments :: 0 Trackbacks

3.1調(diào)試測(cè)試

×我們必須創(chuàng)建測(cè)試以重現(xiàn)問題

×我們必須多次運(yùn)行測(cè)試以簡(jiǎn)化問題

×我們必須重新運(yùn)行測(cè)試以觀察運(yùn)行過程

×我們必須重新運(yùn)行測(cè)試以驗(yàn)證修改是否成功

×每個(gè)版本發(fā)布之前,我們必須重新運(yùn)行測(cè)試,以便發(fā)現(xiàn)將來不會(huì)再次出現(xiàn),這種稱為回歸測(cè)試

在調(diào)試過程中需要頻繁的進(jìn)行自動(dòng)測(cè)試,應(yīng)此最好盡可能的采用自動(dòng)化測(cè)試。通常通過使用自動(dòng)化測(cè)試技術(shù),可以更容易的進(jìn)行全面測(cè)試,自動(dòng)化測(cè)試的好處在于:

×可以重用已有測(cè)試

×可以進(jìn)行一些困難的、無法手工執(zhí)行的測(cè)試(如:大規(guī)模的隨機(jī)性測(cè)試)

×重復(fù)測(cè)試

×增強(qiáng)對(duì)軟件的信心

 

3.2控制程序

        通常,自動(dòng)化測(cè)試必須模擬程序所處的環(huán)境---也就是說,測(cè)試必須提供程序的輸入,并且評(píng)估程序的輸出。但是模擬環(huán)境需要很多技巧,如果環(huán)境中包括和程序進(jìn)行交互的用戶,自動(dòng)測(cè)試就必須模擬真實(shí)的用戶(包括他們的所有能力)。

        通過區(qū)分不同的接口,可以避開部分模擬難題,從而使得控制和評(píng)估都更易于自動(dòng)化。下圖是典型的三層接口劃分:

×表現(xiàn)層處理和用戶(或者構(gòu)建程序環(huán)境的任何事物)之間的交互

×功能層封裝程序的實(shí)際功能,功能獨(dú)立于表現(xiàn)層

×單元層把功能分解成多個(gè)單元,這些單元相互協(xié)作形成一個(gè)整體

image

 

 

3.3在表現(xiàn)層測(cè)試

3.3.1低級(jí)交互

        在最低級(jí)的抽象級(jí)別,用戶輸入被看做鼠標(biāo)和鍵盤的事件流,這種事件流可以是被捕獲和重放,即用時(shí)間記錄器的時(shí)間流替代實(shí)際輸入設(shè)備的事件流。

(PS:如果是在windows上測(cè)試需要UI交互的程序,貌似可以直接簡(jiǎn)單的試用key_event mouse_event等幾個(gè)api就能模擬時(shí)間送進(jìn)來了;當(dāng)然,還有socket類的測(cè)試,管道什么的,,,)

image

3.3.2系統(tǒng)級(jí)交互(高階主題,主要是將在系統(tǒng)(如虛擬機(jī))級(jí)別模擬外部操作)

 

3.3.3高級(jí)交互

        使用更高級(jí)抽象級(jí)別的事件流(或者腳本)來模擬外部操作。比如圖形程序的測(cè)試,以前是直接算坐標(biāo)控制,現(xiàn)在用更聰明的手段(標(biāo)識(shí)button的text,輸入指定的語句而不是裸的**_event)。簡(jiǎn)而言之就是輸入更加具有邏輯性,更加接近“人工智能”

image

 

3.3.4 評(píng)估測(cè)試結(jié)果

        不管是事件流還是通過用戶控件控制應(yīng)用程序,都存在一個(gè)重要的問題:模擬環(huán)境必須檢查程序的輸出。

×必須通過檢查輸出進(jìn)行同步,應(yīng)為模擬用戶可能會(huì)一直等待直到一個(gè)特定的動(dòng)作結(jié)束。

×必須通過檢查程序輸出來進(jìn)行結(jié)果評(píng)估,測(cè)試的最終目的是確定結(jié)果是否和我們的預(yù)期相符。

        表現(xiàn)層測(cè)試的優(yōu)點(diǎn)是:它總能實(shí)現(xiàn)。我們總是可以模擬和自動(dòng)執(zhí)行用戶的行為。但是,這是唯一的優(yōu)點(diǎn)。通常表現(xiàn)層測(cè)試只是用于:

×問題發(fā)生在表現(xiàn)層

×計(jì)算機(jī)程序可以很方便的調(diào)用表現(xiàn)層

×沒有其他的選擇(如:由于表現(xiàn)層和功能層沒有被清晰的分離,或者無法在較低層次上進(jìn)行測(cè)試)

界面對(duì)人越友好,它對(duì)計(jì)算機(jī)程序就越不友好。。。所以表現(xiàn)層測(cè)試應(yīng)該不是最適合自動(dòng)化測(cè)試的接口(至少對(duì)非表示層coder來說)

 

3.4在功能層測(cè)試

        相比較于模擬用戶交互,更加可取的方法是為程序設(shè)計(jì)一個(gè)適合于進(jìn)行自動(dòng)化的接口---或者通俗的說,設(shè)計(jì)接口時(shí)要考慮和測(cè)試系統(tǒng)的交互。比如通過提供腳本語言接口,腳本語言允許最終用戶或者測(cè)試人員通過簡(jiǎn)單的方式自動(dòng)執(zhí)行某些任務(wù)。

        在功能層進(jìn)行測(cè)試的最大優(yōu)點(diǎn)是:很容易獲取和評(píng)估結(jié)果。但是,這種測(cè)試的前提條件是能清晰的分離表現(xiàn)層和功能層。而一些陳舊的程序都是獨(dú)立的整體,沒有進(jìn)行表現(xiàn)層和功能層的分離。這種情況下,有三種選擇:

×繼續(xù)在表現(xiàn)層惡心的測(cè)試,然后繼續(xù)糾結(jié)

×重新進(jìn)行大幅度的重新設(shè)計(jì),以分離表現(xiàn)層和功能層,或者至少減少他們之間的依賴關(guān)系

×分解程序,并且直接測(cè)試獨(dú)立的單元

 

3.5在單元層測(cè)試

        任何復(fù)雜的程度都可以分解成大量獨(dú)立的單元---子程序、函數(shù)、庫、模塊、抽象數(shù)據(jù)類型、對(duì)象、類、包、組建、beans或者設(shè)計(jì)方案和語言提供的任何分解機(jī)制。單元之間通過接口同學(xué)---就像程序之間通過他們所處的環(huán)境進(jìn)行通信一樣。

        現(xiàn)在的想法不是需要自動(dòng)運(yùn)行整個(gè)程序,而是自動(dòng)運(yùn)行某個(gè)特定的單元。其優(yōu)點(diǎn)是自動(dòng)運(yùn)行分離的單元一般都比自動(dòng)運(yùn)行整個(gè)程序容易的多。當(dāng)然,缺點(diǎn)是自能自動(dòng)化某個(gè)特定的單元行為,于是必須考慮在分離單元的過程中引入的問題。

        最終用戶通常是不能訪問單元的,因此不可能通過用戶腳本來執(zhí)行系統(tǒng)的功能。但是,程序員可以使用外圍程序訪問服務(wù)的方式訪問單元(PS: 這句有點(diǎn)繞口,感覺是讓程序員自己去寫code做單元測(cè)試)

        所有的單元測(cè)試工具都提供了一個(gè)能組織大量單獨(dú)測(cè)試用例的測(cè)試框架---每個(gè)測(cè)試覆蓋一個(gè)獨(dú)立的單元。單元測(cè)試應(yīng)該能在沒有任何用戶交互的情況下自動(dòng)運(yùn)行,測(cè)試框架會(huì)按照要求運(yùn)行部分或者所有的單元測(cè)試,然后概要顯示運(yùn)行單元測(cè)試以及各自的輸出結(jié)果。運(yùn)行某一個(gè)單元測(cè)試時(shí),測(cè)試框架會(huì)按照以下三個(gè)步驟進(jìn)行:

×建立單元測(cè)試以及運(yùn)行的周邊環(huán)境。通常一個(gè)單元可能需要其他單元或者操作環(huán)境的服務(wù)。該步驟建立起能使測(cè)試運(yùn)行的環(huán)境。

×執(zhí)行單元測(cè)試。每個(gè)測(cè)試用例覆蓋該單元的一個(gè)可能的行為,用例首先執(zhí)行所有操作,然后驗(yàn)證輸出是否與預(yù)期相符。

×重新清理測(cè)試環(huán)境。

 

3.6分離單元

        有一些程序的功能層依賴于表現(xiàn)層,根本不可能把他們分離。比如print_to_file,把當(dāng)前網(wǎng)頁打印到文件中。為了防止覆蓋已經(jīng)存在的文件,會(huì)請(qǐng)求用戶確認(rèn)是否已經(jīng)存在。(這個(gè)其實(shí)也可以使用的代碼搞定,麻煩點(diǎn),不過“確認(rèn)”這個(gè)功能的測(cè)試就是必須UI和用戶參與)

image

×表現(xiàn)層依賴功能層,應(yīng)為他需要調(diào)用print_to_file()

×功能層依賴表現(xiàn)層,應(yīng)為他需要調(diào)用confirm_loss()

問題就來了:如何切斷依賴關(guān)系,使單元可以更好分離?

對(duì)于這個(gè)例子處理起來比較容易。可以讓函數(shù)按照兩種方式運(yùn)行:自動(dòng)模式禁止用戶確認(rèn)功能,總是返回true;交互模式,打開用戶確認(rèn)功能,等待用戶回答。更加通用的方式是:參數(shù)化print_to_file函數(shù),使他能與不同的表現(xiàn)層工作。

image

(PS:其實(shí)還可以通過引入一個(gè)中間層來解決,假設(shè)給print_to_file()加上參數(shù),然后core不再依賴pressntation,而是依賴一個(gè)消息模塊、或者控制模塊,那么只要寫一個(gè)模擬發(fā)送消息、模擬控制的模塊即可。解決循環(huán)依賴直接的辦法是引入中間層)

 

3.7為調(diào)試而設(shè)計(jì)

        依賴抽象而不是具象這一原則對(duì)于減少依賴關(guān)系有很大幫助。實(shí)際上可以利用這種方法創(chuàng)建整個(gè)應(yīng)用程序框架,其中最流行的一個(gè)例子就是模型-視圖-控制器架構(gòu)模式,該模式能從應(yīng)用程序級(jí)上解除功能層和表現(xiàn)層之間的耦合。

image

 

        如何創(chuàng)建一個(gè)這樣的系統(tǒng)?最關(guān)鍵的還是分離功能層和表現(xiàn)層。我們決不希望核心功能依賴某個(gè)特定視圖。MVC模式就是解決這類問題的一個(gè)通用方案。他把職責(zé)分解為兩個(gè)部分:

×模型管理核心數(shù)據(jù),并且提供處理這些核心數(shù)據(jù)的服務(wù)。

×個(gè)總觀察者注冊(cè)或者粘附(attach)在模型上,核心數(shù)據(jù)一旦發(fā)生變化,他們就會(huì)得到通知。

觀察者又可以分成兩種類型:

×視圖負(fù)責(zé)以特定的方式顯示核心數(shù)據(jù)

×控制器負(fù)責(zé)處理輸入時(shí)間并調(diào)用模型服務(wù)

用戶和控制器交互是,他最終可能會(huì)調(diào)用一個(gè)改變核心數(shù)據(jù)的服務(wù)。這是注冊(cè)在模型上的所有視圖都會(huì)得到通知。也就是說,他們能從模型那里獲得數(shù)據(jù)以及更新顯示。從而用戶也就得到反饋。

MVC給測(cè)試和調(diào)試帶來的好處:對(duì)于測(cè)試來說可以創(chuàng)建和添加新的控制器來調(diào)用模型提供的服務(wù)---例如,能自動(dòng)記錄執(zhí)行這些服務(wù)的控制器。對(duì)于調(diào)試來說,可以支持特殊的視圖來記錄模型的所有變化。最后,可以單獨(dú)的檢查每一個(gè)觀察者和模型,減少復(fù)雜性。

image

 

 

3.8預(yù)防未知問題


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美中文日韩在线| 国产精品久久久久久久久久ktv| 亚洲视频碰碰| 亚洲一区欧美二区| 欧美一级久久久久久久大片| 久久本道综合色狠狠五月| 久久精品成人一区二区三区蜜臀 | 欧美日韩国产精品专区| 欧美精品激情| 国产精品久久久久免费a∨| 国产精品热久久久久夜色精品三区| 国产精品久久久久久模特| 国产一区日韩二区欧美三区| 亚洲第一天堂av| 一本色道久久88亚洲综合88| 亚洲欧美日韩区| 久久青青草综合| 亚洲国产精品精华液2区45| 亚洲人线精品午夜| 欧美亚洲在线| 欧美日韩国产影院| 国产自产v一区二区三区c| 亚洲日本成人女熟在线观看| 亚洲自拍偷拍麻豆| 麻豆乱码国产一区二区三区| 亚洲欧洲在线播放| 夜夜嗨一区二区三区| 久久国产精品99国产精| 亚洲国产日韩一级| 欧美一级视频精品观看| 欧美精品少妇一区二区三区| 国产日产欧美a一级在线| 99re6这里只有精品视频在线观看| 久久av在线| 99国内精品久久久久久久软件| 久久精品二区亚洲w码| 国产精品美腿一区在线看| 亚洲国产高清一区| 久久精品国产99国产精品澳门 | 久久久久成人精品| 99精品免费网| 欧美精品一区在线播放| 亚洲国产毛片完整版| 小辣椒精品导航| 一区二区日本视频| 欧美精品国产精品日韩精品| 亚洲大片av| 久久偷看各类wc女厕嘘嘘偷窃| 一本色道久久加勒比精品| 欧美国产1区2区| 尤物99国产成人精品视频| 欧美在线免费观看视频| 亚洲视频第一页| 久久精品人人| 国产日韩欧美成人| 午夜精品在线| 亚洲午夜精品国产| 国产精品99一区| 亚洲一区久久久| av成人动漫| 欧美午夜无遮挡| 一区在线视频| 久久欧美肥婆一二区| 欧美专区中文字幕| 国产一区二区精品| 久久精品中文字幕免费mv| 欧美国产大片| 欧美成人激情在线| 日韩视频免费在线| 亚洲开发第一视频在线播放| 欧美精品久久久久久久久久| 中文精品视频一区二区在线观看| 亚洲乱码国产乱码精品精天堂| 欧美日韩精品综合在线| 午夜久久久久久| 久久精品官网| 亚洲精品免费网站| 亚洲一二三区精品| 黄色成人在线免费| 亚洲精品国产精品国产自| 国产精品久久久久77777| 久久久久www| 欧美高清视频在线| 午夜精品视频在线| 欧美h视频在线| 欧美高清在线观看| 欧美亚洲在线观看| 久久综合婷婷| 亚洲在线播放电影| 久久久久国产精品一区| 亚洲日本免费| 午夜国产精品影院在线观看| 亚洲第一天堂av| 国产精品99久久久久久久久久久久 | 9色精品在线| 国内成+人亚洲| 亚洲激情电影中文字幕| 国产精品日韩久久久| 男女激情久久| 国产精品久久久久久久久免费| 蜜臀av性久久久久蜜臀aⅴ| 欧美日韩综合在线免费观看| 久久午夜精品| 国产精品成人播放| 欧美成人午夜免费视在线看片| 欧美午夜电影一区| 欧美国产日韩二区| 国产日韩精品一区二区三区| 亚洲片国产一区一级在线观看| 国产偷久久久精品专区| 99成人在线| 亚洲久色影视| 久久精品人人爽| 欧美在线日韩精品| 欧美午夜不卡| 亚洲精品日本| 亚洲全黄一级网站| 久久精品国产亚洲5555| 午夜精品福利电影| 欧美日韩中文字幕| 亚洲人成绝费网站色www| 在线观看福利一区| 久久精品国产亚洲一区二区| 亚洲免费伊人电影在线观看av| 欧美激情一级片一区二区| 免费中文日韩| 激情久久久久久久| 久久gogo国模裸体人体| 欧美综合二区| 国产亚洲综合精品| 亚洲在线播放| 亚洲欧美日韩中文播放| 欧美视频精品在线| 亚洲伦理在线免费看| 在线一区二区三区做爰视频网站 | 欧美日韩精品国产| 最近中文字幕日韩精品| 亚洲精品午夜精品| 欧美国产日韩a欧美在线观看| 亚洲高清三级视频| 一区二区日本视频| 国产精品xxx在线观看www| 一区二区欧美在线| 欧美中文在线观看国产| 国产亚洲欧美一级| 欧美伊久线香蕉线新在线| 精品不卡一区| 美女诱惑黄网站一区| 亚洲激情在线观看| 亚洲午夜久久久| 国产欧美日韩综合一区在线播放| 欧美一级黄色网| 美女黄毛**国产精品啪啪| 亚洲国产精品久久久| 欧美猛交免费看| 亚洲视频自拍偷拍| 久久色在线观看| 亚洲精品少妇网址| 国产精品视频免费一区| 久久爱另类一区二区小说| 亚洲国产精品va| 亚洲欧美日本在线| 亚洲电影在线看| 欧美日韩精品免费观看视一区二区| 亚洲天堂激情| 美女久久一区| 亚洲午夜在线| 激情久久一区| 欧美日韩免费精品| 久久精品二区| 一区二区高清视频| 蜜臀a∨国产成人精品| 亚洲天堂成人在线观看| 精品二区视频| 国产精品久久久久秋霞鲁丝| 欧美中文字幕在线观看| 亚洲激情在线观看| 久久另类ts人妖一区二区| 日韩午夜在线观看视频| 国产欧美三级| 欧美日韩精品三区| 久久久精品tv| 亚洲免费一级电影| 亚洲精品免费一二三区| 国产主播在线一区| 国产精品美女久久久浪潮软件| 久久男人资源视频| 亚洲欧美日韩一区在线观看| 亚洲人屁股眼子交8| 久久一区二区精品| 亚洲欧美制服另类日韩| 99视频+国产日韩欧美| 欧美成人一区二区在线| 亚洲欧美日韩在线高清直播| 欧美新色视频| 久久久久久一区| 久久视频一区| 99国产精品99久久久久久粉嫩| 麻豆久久精品| 欧美视频日韩视频|