• <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>
            隨筆 - 60  文章 - 5  trackbacks - 0
            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            常用鏈接

            留言簿(2)

            隨筆分類(42)

            隨筆檔案(60)

            文章檔案(2)

            我收藏的博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            要減少軟件中的錯誤數(shù)目,方法之一就是擁有一個專業(yè)的測試組,其工作就是盡一切可能使軟件崩潰。不幸的是,如果擁有測試組,那么即使是經(jīng)驗(yàn)豐富的開發(fā)人員,也會傾向于花費(fèi)較少的時間來保證代碼的可靠性。

                軟件界有一句俗語:“開發(fā)人員不應(yīng)該測試他們自己的代碼”。這是因?yàn)殚_發(fā)人員對自己的代碼了如指掌,他們很清楚如何采用適當(dāng)?shù)姆椒▽Υa進(jìn)行測試。盡管這 句俗語很有道理,但卻忽略了非常重要的一點(diǎn) - 如果開發(fā)人員不對自己的代碼進(jìn)行測試,又如何知道代碼能否按照預(yù)期的方式運(yùn)行?

                簡單說來,他們根本無從得知。開發(fā)人員編寫那種運(yùn)行不正常或只在某些情況下運(yùn)行正常的代碼是一個嚴(yán)重的問題。他們通常只測試代碼能否在很少的情況下正常運(yùn)行,而不是驗(yàn)證代碼能夠在所有情況下均正常運(yùn)行。

                發(fā)現(xiàn)軟件錯誤的情況有很多:

                1.由首次編寫代碼的開發(fā)人員發(fā)現(xiàn)。
                2.由嘗試運(yùn)行代碼的開發(fā)人員發(fā)現(xiàn)。
                3.由組中的其他開發(fā)人員或測試人員發(fā)現(xiàn)。
                4.作為產(chǎn)品大規(guī)模測試的一部分。
                5.由最終用戶發(fā)現(xiàn)。

                如果在第一種情況下發(fā)現(xiàn)軟件錯誤,則修復(fù)錯誤比較容易,成本也很低。情況越靠后,修復(fù)軟件錯誤的成本就越高;修復(fù)一個由最終用戶發(fā)現(xiàn)的軟件錯誤可能要耗費(fèi) 100 或 1000 倍的成本。更不用說用戶通常因?yàn)檐浖e誤導(dǎo)致工作無法繼續(xù),而一直等到下一個版本才能解決問題。
                如果開發(fā)人員能夠在編寫代碼期間發(fā)現(xiàn)所有的軟件錯誤,那就再好不過了。為此,您必須編寫能在編寫代碼時運(yùn)行的測試。

                測試是軟件開發(fā)的重要環(huán)節(jié)之一。按照軟件開發(fā)的過程測試可分為:單元測試、功能測試、性能測試、性能測試、集成測試、系統(tǒng)測試、域測試(Field test)等。我們這里將主要研究的是面向程序員的單元測試。

                什么是單元測試 

                單元測試是開發(fā)者編寫的一小段代碼,用于檢驗(yàn)被測代碼中的一個很明確的功能是否正確。通常而言,一個單元測試是用于判斷某個特定條件(或者場景)下某個特 定函數(shù)的行為。例如,你可能把一個很大的值放入一個有序list 中去,然后確認(rèn)該值出現(xiàn)在list 的尾部。或者,你可能會從字符串中刪除匹配某種模式的字符,然后確認(rèn)字符串確實(shí)不再包含這些字符了。

                單元測試是由程序員自己來完成,最終受益的也是程序員自己。可以這么說,程序員有責(zé)任編寫功能代碼,同時也就有責(zé)任為自己的代碼編寫單元測試。執(zhí)行單元測試,就是為了證明這段代碼的行為和我們期望的一致。

                為什么要使用單元測試

                我們編寫代碼時,一定會反復(fù)調(diào)試保證它能夠編譯通過。如果是編譯沒有通過的代碼,沒有任何人會愿意交付給自己的客戶。但代碼通過編譯,只是說明了它的語法正確;我們卻無法保證它的語義也一定正確,沒有任何人可以輕易承諾這段代碼的行為一定是正確的。

                幸運(yùn),單元測試會為我們的承諾做保證。編寫單元測試就是用來驗(yàn)證這段代碼的行為是否與我們期望的一致。有了單元測試,我們可以自信的交付自己的代碼,而沒有任何的后顧之憂。

                單元測試有下面的這些優(yōu)點(diǎn):

                1、它是一種驗(yàn)證行為。

                程序中的每一項(xiàng)功能都是測試來驗(yàn)證它的正確性。它為以后的開發(fā)提供支緩。就算是開發(fā)后期,我們也可以輕松的增加功能或更改程序結(jié)構(gòu),而不用擔(dān)心這個過程中會破壞重要的東西。而且它為代碼的重構(gòu)提供了保障。這樣,我們就可以更自由的對程序進(jìn)行改進(jìn)。

                2、它是一種設(shè)計行為。

                編寫單元測試將使我們從調(diào)用者觀察、思考。特別是先寫測試(test-first),迫使我們把程序設(shè)計成易于調(diào)用和可測試的,即迫使我們解除軟件中的耦合。

                3、它是一種編寫文檔的行為。

                單元測試是一種無價的文檔,它是展示函數(shù)或類如何使用的最佳文檔。這份文檔是可編譯、可運(yùn)行的,并且它保持最新,永遠(yuǎn)與代碼同步。

                4、它具有回歸性。

                自動化的單元測試避免了代碼出現(xiàn)回歸,編寫完成之后,可以隨時隨地的快速運(yùn)行測試。

                單元測試的范疇 

                如果要給單元測試定義一個明確的范疇,指出哪些功能是屬于單元測試,這似乎很難。但下面討論的四個問題,基本上可以說明單元測試的范疇,單元測試所要做的工作。

                1、 它的行為和我期望的一致嗎?

                這是單元測試最根本的目的,我們就是用單元測試的代碼來證明它所做的就是我們所期望的。
             
                2、 它的行為一直和我期望的一致嗎?

                編寫單元測試,如果只測試代碼的一條正確路徑,讓它正確走一遍,并不算是真正的完成。軟件開發(fā)是一個項(xiàng)復(fù)雜的工程,在測試某段代碼的行為是否和你的期望一 致時,你需要確認(rèn):在任何情況下,這段代碼是否都和你的期望一致;譬如參數(shù)很可疑、硬盤沒有剩余空間、緩沖區(qū)溢出、網(wǎng)絡(luò)掉線的時候。

                3、 我可以依賴單元測試嗎?

                不能依賴的代碼是沒有多大用處的。既然單元測試是用來保證代碼的正確性,那么單元測試也一定要值得依賴。

                4、 單元測試說明我的意圖了嗎?

                單元測試能夠幫我們充分了解代碼的用法,從效果上而言,單元測試就像是能執(zhí)行的文檔,說明了在你用各種條件調(diào)用代碼時,你所能期望這段代碼完成的功能。

                不寫測試的借口

                到這里,我們已經(jīng)知道了使用單元測試的種種理由。但目前的實(shí)際情況是大多數(shù)程序員不進(jìn)行單元測試,或只進(jìn)行簡單的單元測試。下面是一些他們常用的接口:

                1、 編寫單元測試太花時間了。

                我們知道,在開發(fā)時越早發(fā)現(xiàn)BUG,就能節(jié)省更多的時間,降低更多的風(fēng)險。如果你仍然認(rèn)為在編寫產(chǎn)品代碼的時候,還是沒有時間編寫測試代碼,那么請先考慮下面這些問題:

                1)、對于所編寫的代碼,你在調(diào)試上面花了多少時間。
                2)、對于以前你自認(rèn)為正確的代碼,而實(shí)際上這些代碼卻存在重大的bug,你花了多少時間在重新確認(rèn)這些代碼上面。
                3)、對于一個別人報告的bug,你花了多少時間才找出導(dǎo)致這個bug 的源碼位置。
                回答完這些問題,你一定不再以“太花時間”作為拒絕單元測試的借口。

                2、 運(yùn)行測試的時間太長了。

                合適的測試是不會讓這種情況發(fā)生的。實(shí)際上,大多數(shù)測試的執(zhí)行都是非常快的,因此你在幾秒之內(nèi)就可以運(yùn)行成千上萬個測試。但是有時某些測試會花費(fèi)很長的時間。這時,需要把這些耗時的測試和其他測試分開。通常可以每天運(yùn)行這種測試一次,或者幾天一次。

                3、 測試代碼并不是我的工作。

                你的工作就是保證代碼能夠正確的完成你的行為,恰恰相反,測試代碼正是你不可缺少的工作。

                4、 我并不清楚代碼的行為,所以也就無從測試。

                如果你實(shí)在不清楚代碼的行為,那么估計現(xiàn)在并不是編碼的時候。如果你并不知道代碼的行為,那么你又如何知道你編寫的代碼是正確的呢?

                5、 但是這些代碼都能夠編譯通過。

                我們前面已經(jīng)說過,代碼通過編譯只是驗(yàn)證它的語法通過。但并不能保證它的行為就一定正確。

                6、 公司請我來是為了寫代碼,而不是寫測試。

                公司付給你薪水是為了讓你編寫產(chǎn)品代碼,而單元測試大體上是一個工具,是一個和編輯器、開發(fā)環(huán)境、編譯器等處于同一位置的工具。

                7、 如果我讓測試員或者QA(Quality Assurance)人員沒有工作,那么我會覺得很內(nèi)疚。

                你并不需要擔(dān)心這些。請記住,我們在此只是談?wù)搯卧獪y試,而它只是一種針對源碼的、低層次的,為程序員而設(shè)計的測試。在整個項(xiàng)目中,還有其他的很多測試需要這些人來完成,如:功能測試、驗(yàn)收測試、性能測試、環(huán)境測試、有效性測試、正確性測試、正規(guī)分析等等。

                8、 我的公司并不會讓我在真實(shí)系統(tǒng)中運(yùn)行單元測試。

                我們所討論的只是針對開發(fā)者的單元測試。也就是說,如果你可以在其他的環(huán)境下(例如在正式的產(chǎn)品系統(tǒng)中)運(yùn)行這些測試的話,那么它們就不再是單元測試,而是其他類型的測試了。實(shí)際上,你可以在你的本機(jī)運(yùn)行單元測試,使用你自己的數(shù)據(jù)庫。

                總而言之,單元測試會讓我們的開發(fā)工作變得更加輕松,讓我們對自己的代碼更加自信。無論是大型項(xiàng)目還是小型項(xiàng)目,無論是時間緊迫的項(xiàng)目還是時間寬裕的項(xiàng)目,只要代碼不是一次寫完永不改動,編寫單元測試就一定超值,它已成為我們編碼不可缺少的一部分。




            posted on 2009-07-15 21:19 黃劍父 閱讀(178) 評論(0)  編輯 收藏 引用 所屬分類: Debug
            品成人欧美大片久久国产欧美| 久久99国产精品成人欧美| 欧美成人免费观看久久| 久久精品国产亚洲av麻豆图片 | 大香网伊人久久综合网2020| 久久精品国产福利国产琪琪| 无夜精品久久久久久| 精品久久久久久国产潘金莲| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久最新精品国产| 国产精品久久久久久久久久影院 | 成人资源影音先锋久久资源网| 品成人欧美大片久久国产欧美| 思思久久好好热精品国产| 久久亚洲综合色一区二区三区| 久久天天躁夜夜躁狠狠躁2022 | 国产亚洲精午夜久久久久久 | 99久久精品影院老鸭窝| 欧美色综合久久久久久| 久久国产精品久久精品国产| 亚洲精品第一综合99久久| 久久国产精品-国产精品| 久久久久亚洲av无码专区导航| 久久综合精品国产一区二区三区 | 97视频久久久| 久久久久亚洲AV无码专区网站| 九九99精品久久久久久| 嫩草伊人久久精品少妇AV| 久久99久久99精品免视看动漫| 久久强奷乱码老熟女网站| 狠狠人妻久久久久久综合| 国产精品18久久久久久vr| 国产精品岛国久久久久| 久久国产乱子伦免费精品| 久久久久亚洲av无码专区| 欧美大香线蕉线伊人久久| 精品久久久久久成人AV| 国内精品久久久久伊人av| 久久精品无码专区免费青青| 亚洲国产另类久久久精品小说| 久久亚洲精品无码aⅴ大香|