• <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>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            你真正需要的代碼測(cè)試覆蓋率是多少?

            本文是從 How much code coverage do you really need? 這篇文章翻譯而來(lái)。

            我寫(xiě)這篇文章的起因是由于看了@unclebobmartin在微博上的一些看起來(lái)言之鑿鑿的話語(yǔ)。給那些不認(rèn)識(shí)Uncle Bob的人介紹一下——他是我們軟件產(chǎn)業(yè)里最著名的一個(gè)專(zhuān)家,是《 Clean Code(代碼整潔之道)》這本著作的作者,是敏捷宣言(Agile Manifesto)的簽署人之一。在上世紀(jì)九十年代,他對(duì)文獻(xiàn)最佳面向?qū)ο髮?shí)踐方法貢獻(xiàn)了很大的力量。所以,當(dāng)他說(shuō)話時(shí),我們一定要關(guān)注一下。

            他給我們?nèi)粘5腡DD和單元測(cè)試制訂了一個(gè)最高綱領(lǐng)。我們可以從他的微博里清楚的看到這點(diǎn):

            “兩件事。可重復(fù)性和成本。跟自動(dòng)化測(cè)試比起來(lái),手工測(cè)試的成本高的可怕。”

            “手工測(cè)試不是測(cè)試;那是在做實(shí)驗(yàn)。只要有人的因素牽涉其中,那結(jié)果就必然可疑。”

            “你們告訴我的實(shí)際意思就是讓我大開(kāi)方便之門(mén)、不去測(cè)試某些程序。哼 …”

            “代碼覆蓋率100%并不是成績(jī),那是最低要求。即使只寫(xiě)了一行代碼,你也要測(cè)試它。”

            他接著把軟件測(cè)試跟在其它領(lǐng)域里常見(jiàn)的但被認(rèn)為很關(guān)鍵的活動(dòng)進(jìn)行了比較:

            “戰(zhàn)地外科醫(yī)生也許沒(méi)有最夠的時(shí)間做嚴(yán)格的消毒,但這帶來(lái)的風(fēng)險(xiǎn)可能是死亡或高昂的治療代價(jià)。”

            “會(huì)計(jì)難道只會(huì)把80%的數(shù)據(jù)表做雙份備份嗎?”

            “有多少回你們都看到了那些嚴(yán)重的宕機(jī)事故都是因?yàn)橐恍┯薮赖某绦騿T以為那些愚蠢的代碼不需要經(jīng)過(guò)測(cè)試而導(dǎo)致的?“

            他的所有這些觀點(diǎn)都很有價(jià)值,但他只向我們展示了問(wèn)題的一面。現(xiàn)實(shí)中并不是所有的應(yīng)用都需要如此謹(jǐn)小慎微的測(cè)試。并不是所有的應(yīng)用都跟戰(zhàn)地手術(shù)或巨額資金核算那么重要。(更不要說(shuō)在很多情況下的為”合理避稅“而做的帳務(wù):))。

            一個(gè)更重要的原因是,100%的測(cè)試覆蓋率并不能保證bug的不出現(xiàn)。就連Uncle Bob自己也承認(rèn):

            ”測(cè)試并不能杜絕bug。但測(cè)試能保證程序的行為是符合預(yù)期的。“

            這很顯然指的是:同一個(gè)程序員在程序里埋下的概念性或邏輯性錯(cuò)誤,由他自己測(cè)是絕對(duì)測(cè)不出來(lái)的。

            最終,所有的問(wèn)題歸結(jié)于ROI(投資收回率)和實(shí)用主義。有些應(yīng)用比其它應(yīng)用需要更多的測(cè)試。有些bug需要比其它bug投入更多的精力去修復(fù)。 究竟是否需要在自動(dòng)化測(cè)試是投入更多的時(shí)間和財(cái)力,或多少覆蓋率是合適的還是過(guò)分了,這都需要人的主觀判斷。

            精品综合久久久久久97| 91精品日韩人妻无码久久不卡| 欧美午夜A∨大片久久| 亚洲精品无码成人片久久| 亚洲国产另类久久久精品| 99久久精品免费国产大片| 久久久久久久久66精品片| 国产精品美女久久久久久2018| 国产成人精品久久亚洲高清不卡| 日本高清无卡码一区二区久久| 中文字幕人妻色偷偷久久| 久久精品国产72国产精福利| 亚洲国产精品无码久久一线| 狠狠精品久久久无码中文字幕 | 久久亚洲精品国产精品| 国产高清美女一级a毛片久久w| 精品国产乱码久久久久软件| 国产成人精品久久| 久久精品国产免费观看三人同眠| 91亚洲国产成人久久精品| 久久久久人妻精品一区二区三区| 久久精品夜色噜噜亚洲A∨| 国内精品久久久久影院一蜜桃 | 久久夜色精品国产亚洲| 丁香五月综合久久激情| 久久精品国产亚洲AV嫖农村妇女 | 久久99精品久久久大学生| 久久精品国产99久久丝袜| 久久综合九色综合欧美狠狠| 欧美一区二区三区久久综| 99久久综合国产精品免费| 久久夜色精品国产亚洲av| 精品久久久久中文字幕一区| 国产成人久久精品麻豆一区 | 国产精品免费看久久久香蕉| 精品999久久久久久中文字幕| 无码精品久久久久久人妻中字| 久久久久免费精品国产| 一本一本久久aa综合精品| 亚洲欧美日韩久久精品第一区| 中文字幕精品久久久久人妻|