激情五月天婷婷,亚洲愉拍一区二区三区,日韩视频一区,a√天堂中文官网8

<ul id="buwfs"><strike id="buwfs"><strong id="buwfs"></strong></strike></ul>
    <output id="buwfs"></output>
  • <dfn id="buwfs"><source id="buwfs"></source></dfn>
      <dfn id="buwfs"><td id="buwfs"></td></dfn>
      <div id="buwfs"><small id="buwfs"></small></div>
      <dfn id="buwfs"><source id="buwfs"></source></dfn>
      1. <dfn id="buwfs"><td id="buwfs"></td></dfn>
        始創(chuàng)于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊(cè)有禮 登錄
        • 掛牌上市企業(yè)
        • 60秒人工響應(yīng)
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補(bǔ)償
        全部產(chǎn)品
        您的位置: 網(wǎng)站首頁(yè) > 幫助中心>文章內(nèi)容

        單元測(cè)試要做多細(xì)?

        發(fā)布時(shí)間:  2012/9/3 16:42:25

        這篇文章主要來(lái)源是StackOverflow上的一個(gè)回答——“How deep are your unit tests?”。一個(gè)有13.8K的分的人(John Nolan)問(wèn)了個(gè)關(guān)于TDD的問(wèn)題,他說(shuō)——

        “TDD需要花時(shí)間寫(xiě)測(cè)試,而我們一般多少會(huì)寫(xiě)一些代碼,而第一個(gè)測(cè)試是測(cè)試我的構(gòu)造函數(shù)有沒(méi)有把這個(gè)類(lèi)的變量都設(shè)置對(duì)了,這會(huì)不會(huì)太過(guò)分了?那么,我們寫(xiě)單元測(cè)試的這個(gè)單元的粒度到底是什么樣的?并且,是不是我們的測(cè)試測(cè)試得多了點(diǎn)?”

        答案

        StackOverflow上,這個(gè)問(wèn)題的答案是這樣的——

        “I get paid for code that works, not for tests, so my philosophy is to test as little as possible to reach a given level of confidence (I suspect this level of confidence is high compared to industry standards, but that could just be hubris). If I don’t typically make a kind of mistake (like setting the wrong variables in a constructor), I don’t test for it. I do tend to make sense of test errors, so I’m extra careful when I have logic with complicated conditionals. When coding on a team, I modify my strategy to carefully test code that we, collectively, tend to get wrong.”

        老板為我的代碼付報(bào)酬,而不是測(cè)試,所以,我對(duì)此的價(jià)值觀是——測(cè)試越少越好,少到你對(duì)你的代碼質(zhì)量達(dá)到了某種自信(我懷疑這種的自信標(biāo)準(zhǔn)備要高于業(yè)內(nèi)的標(biāo)準(zhǔn),但這種自信也可能是種自大)。如果我的編碼生涯中不會(huì)犯這種典型的錯(cuò)誤(如:在構(gòu)造函數(shù)中設(shè)了個(gè)錯(cuò)誤的值),那我就不會(huì)測(cè)試它。我傾向于去做那些有意義的錯(cuò)誤測(cè)試,所以,我對(duì)一些比較復(fù)雜的條件邏輯會(huì)異常地小心。當(dāng)在一個(gè)團(tuán)隊(duì)中,我會(huì)非常小心的測(cè)試那些會(huì)讓團(tuán)隊(duì)容易出錯(cuò)的代碼。

        這個(gè)問(wèn)題并不新鮮,但是這個(gè)回答對(duì)TDD似乎有一種否定,最亮的是這個(gè)問(wèn)題是由Kent Beck,Kent是XP和TDD的創(chuàng)造者,是敏捷開(kāi)發(fā)實(shí)踐方法的奠基人。以致于還有人調(diào)侃到——

         

        fight club  搏擊俱樂(lè)部

        The world does not think that Kent Beck would say this! There are legions of developers dutifully pursuing 100% coverage because they think it is what Kent Beck would do! I have told many that you said, in your XP book, that you don’t always adhere to Test First religiously. But I’m surprised too.

        只是要地球人都不會(huì)覺(jué)得Kent Beck會(huì)這么說(shuō)啊!我們有大堆忠實(shí)程序員在追求著100%的代碼測(cè)試覆蓋率,因?yàn)檫@些程序員覺(jué)得Kent Beck也會(huì)這么!我告訴過(guò)很多人,你在你的XP的書(shū)里說(shuō)過(guò),你并不總是支持“宗教信仰式的Test First”,但是今天這么說(shuō),我還是很驚訝!

        后面還有一些不人同意Kent, 我一下子從這個(gè)事中想到了《fight club》里的那個(gè)精神分裂者創(chuàng)建了一個(gè)連自己都反對(duì)的地下組織。呵呵。

        其實(shí)我是非常同意Kent的,怎么合適怎么搞,愛(ài)怎么測(cè)試就怎么測(cè)試,只要自己和團(tuán)隊(duì)有信心就可以了。沒(méi)有必要就一定要寫(xiě)測(cè)試,一定要測(cè)試先行。

        其它答案

        八卦完了,我們還是來(lái)認(rèn)認(rèn)真真地看看這個(gè)問(wèn)題中其它的其它答案,因?yàn)檫@個(gè)問(wèn)題的也是國(guó)人愛(ài)問(wèn)題的問(wèn)題。

        第二個(gè)答案:值得借鑒

        • 開(kāi)發(fā)過(guò)程中,單元測(cè)試應(yīng)該來(lái)測(cè)試那些可能會(huì)出錯(cuò)的地方,或是那些邊界情況。
        • 維護(hù)過(guò)程中,單元測(cè)試應(yīng)該跟著我們的bug report來(lái)走,每一個(gè)bug都應(yīng)該有個(gè)UT。于是程序員就會(huì)對(duì)自己的代碼變更有兩個(gè)自信,bug 被 fixed,相同的bug不會(huì)再次出現(xiàn)。

        第三個(gè)答案:給敏捷咨師看的答案

        這個(gè)答案在說(shuō),我們只注意到了TDD中的T,而忽略了第一個(gè)D,就是Driven…… bla bla bla… 又這扯這些空洞的東西了,國(guó)內(nèi)的各種不學(xué)無(wú)術(shù)的敏捷咨詢師最好這一口了。

        第四個(gè)答案:致那些什么都要測(cè)試的人

        如果我們需要測(cè)試一個(gè)像 int square(int x) 這樣的開(kāi)根函數(shù),我們需要40億個(gè)測(cè)試(每個(gè)數(shù)都要測(cè)試)。

        事實(shí)上這種情況可能還更糟糕,如果有這樣一個(gè)方法 void setX(int newX) 不會(huì)更改其它的成員變量,如:obj.z, Obj.y,那么,你是不是還要去測(cè)試一下別的變量沒(méi)有被改變?

        我們只可能測(cè)試那些有意義的,確實(shí)要測(cè)試的案例。

        我的觀點(diǎn)

        我在《TDD并沒(méi)有看上去的那么美》一文中說(shuō)過(guò)我的觀點(diǎn)了,我就不再多說(shuō)了。我還是把下面這些觀點(diǎn)列出來(lái),供大家思考和討論:

        1)我國(guó)的教育對(duì)我們最大的洗腦不是掩蓋事實(shí),而讓我們習(xí)慣于標(biāo)準(zhǔn)答案,習(xí)慣于教條,從而不會(huì)思考!敏捷開(kāi)發(fā)中的若干東西似乎都成了軟件開(kāi)發(fā)中對(duì)某種標(biāo)準(zhǔn)答案的教條,實(shí)在是悲哀!

        2)軟件開(kāi)發(fā)是一種腦力勞動(dòng),是一種知識(shí)密集型的工作,就像藝術(shù)作品一樣,創(chuàng)作過(guò)程和成品是沒(méi)有標(biāo)準(zhǔn)答案的。

        3)軟件的質(zhì)量不是測(cè)試出來(lái)的,而是設(shè)計(jì)和維護(hù)出來(lái)的。就像工匠們?cè)谝稽c(diǎn)一點(diǎn)地同聲雕琢他們的作品一樣。

        UT的粒度是多少,這個(gè)不重要,重要的是你會(huì)不會(huì)自己思考你的軟件應(yīng)該怎么做,怎么測(cè)試。


        本文出自:億恩科技【mszdt.com】

        服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]

      2. 您可能在找
      3. 億恩北京公司:
      4. 經(jīng)營(yíng)性ICP/ISP證:京B2-20150015
      5. 億恩鄭州公司:
      6. 經(jīng)營(yíng)性ICP/ISP/IDC證:豫B1.B2-20060070
      7. 億恩南昌公司:
      8. 經(jīng)營(yíng)性ICP/ISP證:贛B2-20080012
      9. 服務(wù)器/云主機(jī) 24小時(shí)售后服務(wù)電話:0371-60135900
      10. 虛擬主機(jī)/智能建站 24小時(shí)售后服務(wù)電話:0371-60135900
      11. 專(zhuān)注服務(wù)器托管17年
        掃掃關(guān)注-微信公眾號(hào)
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權(quán)所有  地址:鄭州市高新區(qū)翠竹街1號(hào)總部企業(yè)基地億恩大廈  法律顧問(wèn):河南亞太人律師事務(wù)所郝建鋒、杜慧月律師   京公網(wǎng)安備41019702002023號(hào)
          0
         
         
         
         

        0371-60135900
        7*24小時(shí)客服服務(wù)熱線