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

Error

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

3.1調(diào)試測試

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

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

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

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

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

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

×可以重用已有測試

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

×重復(fù)測試

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

 

3.2控制程序

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

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

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

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

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

image

 

 

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

3.3.1低級交互

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

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

image

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

 

3.3.3高級交互

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

image

 

3.3.4 評估測試結(jié)果

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

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

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

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

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

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

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

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

 

3.4在功能層測試

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

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

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

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

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

 

3.5在單元層測試

        任何復(fù)雜的程度都可以分解成大量獨(dú)立的單元---子程序、函數(shù)、庫、模塊、抽象數(shù)據(jù)類型、對象、類、包、組建、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做單元測試)

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

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

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

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

 

3.6分離單元

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

image

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

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

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

對于這個(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ì)

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

image

 

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

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

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

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

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

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

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

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

image

 

 

3.8預(yù)防未知問題


只有注冊用戶登錄后才能發(fā)表評論。
網(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>
            嫩草成人www欧美| 亚洲欧洲综合另类在线| 欧美激情一区二区在线 | 国内精品久久久久影院优| 亚洲国产精品尤物yw在线观看| 国产精品国产三级国产aⅴ浪潮| 欧美sm重口味系列视频在线观看| 国产欧美精品| 99在线|亚洲一区二区| 亚洲精品视频免费观看| 久久九九免费视频| 欧美在线中文字幕| 久久久精品国产免大香伊 | 亚洲在线网站| 欧美激情亚洲精品| 欧美电影电视剧在线观看| 好男人免费精品视频| 午夜一区在线| 久久精品卡一| 国产一区二区三区最好精华液| 亚洲欧美日韩国产一区二区| 欧美一级播放| 国产美女高潮久久白浆| 午夜久久美女| 久久激情五月激情| 韩国av一区二区三区四区| 久久精品视频播放| 久久中文欧美| 91久久精品国产91性色| 免费日韩av电影| 亚洲人被黑人高潮完整版| 日韩网站免费观看| 国产精品mv在线观看| 亚洲伊人久久综合| 久久狠狠亚洲综合| 影音先锋欧美精品| 欧美精品97| 国产精品99久久99久久久二8| 亚洲欧美日韩精品久久奇米色影视 | 欧美激情片在线观看| 亚洲清纯自拍| 亚洲欧美久久久| 国产亚洲第一区| 久久久综合免费视频| 亚洲国产精品一区二区久| 一本到12不卡视频在线dvd| 欧美性猛交视频| 欧美在线免费一级片| 欧美**人妖| 亚洲性av在线| 黄色精品一区| 欧美极品在线观看| 午夜免费日韩视频| 亚洲高清视频的网址| 亚洲一区二区三区中文字幕在线| 国产欧美一区视频| 欧美成在线视频| 亚洲一级黄色av| 美女亚洲精品| 亚洲综合丁香| 亚洲国产乱码最新视频| 国产精品欧美久久| 久久中文字幕一区二区三区| 99re热这里只有精品视频| 久久久久成人精品| 亚洲午夜电影| 亚洲国产精品黑人久久久| 欧美视频在线播放| 免费成人网www| 午夜精品久久久久影视| 91久久久久久国产精品| 久久精品伊人| 亚洲欧美另类综合偷拍| 最新亚洲激情| 韩日视频一区| 国产精品日韩一区| 欧美另类视频| 鲁大师成人一区二区三区| 亚洲男女自偷自拍| 午夜在线一区| 一区二区三区视频在线| 在线播放不卡| 国产亚洲欧美一区| 国产精品爱久久久久久久| 欧美不卡激情三级在线观看| 久久国产毛片| 亚洲欧美日本另类| 99re热这里只有精品视频| 亚洲国产精品久久久久婷婷老年| 久久全国免费视频| 欧美中文字幕久久| 亚洲欧美在线磁力| 亚洲午夜一二三区视频| 亚洲精品久久视频| 亚洲激情成人在线| 亚洲国产欧美久久| 伊人成人在线视频| 激情欧美日韩| 国产一区日韩欧美| 国产综合久久久久久| 国产麻豆日韩| 国产欧美在线视频| 国产亚洲精品aa午夜观看| 国产日韩精品视频一区| 国产欧美精品| 国产一区二区三区四区hd| 国产精品一香蕉国产线看观看| 国产精品theporn88| 国产精品国产三级国产aⅴ浪潮 | 亚洲欧美日本日韩| 亚洲男女自偷自拍图片另类| 亚洲欧美www| 午夜在线a亚洲v天堂网2018| 午夜宅男久久久| 久久国产精品久久久久久久久久| 久久av红桃一区二区小说| 欧美一区综合| 老巨人导航500精品| 欧美成人一区二区在线| 欧美大片国产精品| 欧美日韩在线播放| 国产精品天天摸av网| 国产一区二区三区久久 | 午夜精品一区二区三区四区| 午夜精品久久久久久久久| 欧美综合国产精品久久丁香| 另类尿喷潮videofree| 欧美经典一区二区| 国产精品国产a| 黄色日韩精品| 亚洲最新在线视频| 午夜精品免费在线| 麻豆av一区二区三区久久| 亚洲欧洲综合| 亚洲欧美国产高清| 猛男gaygay欧美视频| 欧美日韩一区二区三| 国产日韩欧美| 亚洲精品小视频| 欧美一区二区私人影院日本| 你懂的亚洲视频| 夜夜嗨av一区二区三区四季av| 欧美一级日韩一级| 欧美电影资源| 国产日韩欧美精品综合| 亚洲三级影院| 久久黄色小说| 日韩系列在线| 看片网站欧美日韩| 国产精品一区二区视频| 最新国产拍偷乱拍精品| 亚洲欧美一区二区三区在线| 欧美jizzhd精品欧美巨大免费| 一区二区三区福利| 久久免费一区| 国产欧美欧美| 亚洲视频自拍偷拍| 蜜臀久久99精品久久久久久9| 一区二区三区色| 免费视频一区| 国产一区在线视频| 亚洲综合日韩| 亚洲精品美女91| 麻豆av福利av久久av| 国产视频欧美视频| 亚洲一区二区免费在线| 欧美国产日韩精品免费观看| 亚洲欧美三级伦理| 欧美日韩在线免费观看| 亚洲三级免费观看| 免费久久精品视频| 午夜欧美大尺度福利影院在线看 | 在线观看欧美视频| 小黄鸭精品aⅴ导航网站入口| 91久久精品国产91久久| 久久精品在线| 国产一区观看| 欧美亚洲一区二区在线观看| av不卡在线| 欧美日韩一区二区在线视频| 亚洲精品自在久久| 亚洲高清视频中文字幕| 久久综合网hezyo| 亚洲成色精品| 免费久久99精品国产| 久久久综合网站| 在线观看国产日韩| 麻豆精品在线播放| 久久久久国产一区二区| 黄色成人免费观看| 久久亚洲精品伦理| 久久久久久一区二区三区| 黄色成人片子| 女同性一区二区三区人了人一 | 国产精品日韩高清| 亚洲已满18点击进入久久| 亚洲午夜精品一区二区| 国产精品网站视频| 久久久999成人| 久久久噜噜噜久久中文字免|