关于软件单元测试/TDD的成本和收益

发表于:2010-01-07来源:作者:点击数: 标签:tddTDDTdd单元收益
关于软件单元测试/ TDD 的成本和收益 单元测试方法 最近我在公司搞代码评审,做的历程中发明一个抵触的问题:评审发明了问题,于是须要重构,可是重构须要有完美的单元测试做保证,而名目已靠近 开发 完结,基础没有单元测试,后果发明的问题只能放置,由于

         关于软件单元测试/TDD的成本和收益   单元测试方法

  最近我在公司搞代码评审,做的历程中发明一个抵触的问题:评审发明了问题,于是须要重构,可是重构须要有完美的单元测试做保证,而名目已靠近开发完结,基础没有单元测试,后果发明的问题只能放置,由于你很难下决计去为了完美一个货色而去冒损坏它的危险!

  这样上来,代码评审将流于情势。

  我意识到TDD与code review有着很周到的联络,其实以前就据说过迅速的十二个实际都是有内在联络的。

  于是,我又转而开端宣扬单元测试和TDD的必要性和益处,比方单元测试是最好的文档、单元测试是主动化的回归测试能够掩护代码不被损坏、能够加强重构的自自信心、能够疾速反应进步开发效力……

  但我的共事还是有几点担忧的问题:

  1、写测试须要老本;

  2、测试自身也能够出错;

  3、测试也须要掩护,需求变了本来只有改一处,如今须要改两处了;

  4、关于一些简朴的CRUD,真有必要去测吗?我鼠标点两下不就行了?

  总之就是经过我的宣扬,他们已经基础认同了从久远看TDD是值得做的,但还是担忧短期内老本会增添以致影响了以落伍度。

  不处理这个担忧,就没方法让他们在目前工期压力下做这件事件。

  所以这回探讨的焦点在短期老本和收益。

  首先我以为,即使是短期看,也是值得去TDD的,这是我实际历程中的以为:

  1、写测试须要老本

  这个老本不大,而且能很快的发出,比方增添了debug集成测试的时光;

  2、测试自身也能够出错

  测试出错解释你对顺序行动的预期错了,这属于需求了解问题,无法防止;

  3、测试也须要掩护,需求变了本来只有改一处,如今须要改两处了

  我以为这是个伪问题,由于假如你有测试套件的话,它实际上就替代了以前的具体设计文档,并且改起来更随意;

  4、关于一些简朴的CRUD,真有必要去测吗?我鼠标点两下不就行了?

  假如用了ORMapping框架,外面机关重重,因而CRUD也不简朴,而且查问素来都不会简朴,各种条件组合须要测的中央很多。

  欢送大家宣布本人的想法和看法。

原文转自:http://www.ltesting.net