从参加工作以来,参加了大大小小好几个项目了。对于项目中间的单元测试这一项,有一些想法,不吐不快。主要围绕以下几个方面来说一说。(大家多多批评。)
1, 对于一个项目,应该怎样划分在项目中需要测试的类和方法?
举个例子,一个基于被封装后的struts和EJB项目,哪些需要测试?在我看来,大而全是没有必要的。
个人觉得,Action的单元测试属于比较没有用处的一个。因为在画面疏通的过程中,担当者对Action的测试会更加的仔细一些,基本上可以替代非常麻烦的Action单元测试。同时对于Form的测试在没有特殊的方法追加的情况下,也可以省略掉。
然后是Dao层的测试是需要做的,但是针对非框架组成部分的成员来说,测试SQL语句应该就足够了。CMP以及共通Dao的相关测试应该由框架来保证。
然后是service层的测试,用来做框架内部调用的代码的测试可以主动地忽略掉,由框架开发者做出足够的测试就可以了。只针对业务逻辑的相关方法进行测试。在这里顺便提一提设计上的一个问题。如果有通用的业务逻辑处理的话,建议直接使用工具类的形式来提供,而不要使用父类方法然后子类继承的方式,非常的不利于单元测试。(有不同意见的可以批评指正。)
2, 由谁来完成测试类?
我比较倾向于测试和功能代码的担当者不要是一个人。并且写测试的人要比写代码的人更加的熟悉详细设计。写测试和代码的人不一定是详细设计者,写代码的人可以看着详细设计写代码,不一定要非常的熟悉设计者的思路,完成详细设计的功能就可以了(当然,这个是相对的)。但是写测试的人却要清楚的知道每一步发生了什么,输入了什么样的对象,得到了什么样的对象,中间会有什么样的处理。
首先,测试的工作量一点也不小,绝对不是捎带手就能做了的。基本上大一点的业务出现变更的时候,原来的对于该项逻辑的单元测试代码返工量是会比较大的。如果想要做好修复BUG或者是业务变更后的单元测试,耗费的时间比修复BUG和业务变更的时间长很多。对于这个说法,我不知道其他人是否也是这样认为的?当然,在项目组长给你足够的时间的情况下,这个问题不是问题。
其次,当测试和功能代码的担当者分开之后,在项目里面,对于同一块业务,就有了至少两个人熟悉,不会出现只有一个人很明白,其他人都不清楚的尴尬局面。
第三,旁观者清的道理。写测试的和写功能代码的人互相都会有想不全面的地方,有一定的互补性。这样的测试,比较能够测试出代码中的冗余代码。
3, 在任务分配中,测试代码做成需要的时间和功能代码做成需要的时间比例多少是合适的?
个人认为测试和功能代码的时间配比成2:1是一点也不过分的。在大的业务逻辑里面,测试数据的准备需要花很长的时间。
4, 测试驱动开发(TDD)
基本上我现在接触到的项目没有一个符合TDD的要求。有了解TDD的前辈请对我前面的观点进行无情的批判和打击,谢谢。
PS:TDD一定要从上向下的推动。
原因如下:
1,项目经理以下的人没有决策权,也就没有Task的分配权,在不能满足task时间的情况下,要求自己认真完成单元测试是扯淡的。因为单元测试不仅仅是写,还有后期的维护。
(看了很多人发表的意见,都说时间不是不做单元测试的理由,我强烈反对这一点。如果你是项目经理当然时间不是问题,因为时间掌握在你的手上。)
2,TDD要全部组员的配合,要架构师的配合,要详细设计者的配合。
分享到:
相关推荐
由于本人还处于Coder阶段,只是对单元测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,欢迎高手指教。一、单元测试的概念单元通俗的说就是指一个实现简单功能的函数。单元测试就是只用一组...
这份文档是关于仁爱版八年级上册英语教材Unit 4的单元测试题及其答案解析。根据提供的文件信息,我们可以分析出以下知识点: 1. 基础词汇和句型理解:文档中包含了各种基础英语词汇和句型的测试题目,例如选项A、B...
这篇文档是针对四年级学生的一份数学单元测试,主要涵盖了统计学的基础知识。统计学是数据分析的一种基本方法,它在我们的日常生活中有着广泛的应用。在这个单元测试中,孩子们需要掌握如何收集、整理和分析数据,...
1. “只要程序能运行就可以了,写单元测试浪费时间”:这种看法忽略了单元测试在提高代码质量和维护性方面的重要性。 2. “代码很简单不需要单元测试”:简单代码同样存在错误的可能,且随着时间推移,代码可能会变...
【标题】: 高一语文下册第三单元测试1[精选].doc 【描述】: 高一语文下册第三单元测试1[精选].doc 【标签】: 试题 答案 这篇文档是一份高一语文下册第三单元的测试试卷,包含了基础选择题和文言文阅读理解部分,...
都是些自己的看法,不一定准确,欢迎高手指 如何编写软件单元测试用例(白盒测试) 软件测试 前段时间公司进行有关测试的培训,集成测试,性能测试,压力测试说了很多。由于本人还处于Coder阶段,只是对单元测试有...
如何编写单元测试用例(白盒测试)软件测试前段时间公司进行有关的培训,集成测试,,压力测试说了很多。由于本人还处于Coder阶段,只是对测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,...
【标题】和【描述】提及的是七年级下学期语文第五单元的测试卷及答案,这份文档属于【标签】中的“文档”类型。试卷内容涵盖了语言知识积累与运用、口语交际、语病辨析、写景散文的情感表达、名著阅读以及综合性学习...
这篇文档标题为"新人教版九年级上册英语Unit 2单元测试卷(含听力材料及答案解析).doc",是针对初中三年级上学期英语教材Unit 2的一份综合测试卷,旨在检验学生对本单元内容的理解和掌握情况。描述中的信息表明,这...
这份文档是针对人教版英语八年级上册第一单元的一份测试题,旨在评估学生对本单元内容的理解和掌握程度。下面将详细分析并解释其中涉及的一些知识点。 1. **疑问词的选择**:题目1中询问昨晚做了什么,用"What"引导...
说起单元测试的好处相信大家都能列举出不少,可是很多...”资深敏捷咨询师腾振宇(DanielTeng)在GTUG-TopGeek开发工程管理沙龙就以此为题,结合最近的一个项目,和大家分享了他对单元测试的一些看法。 Daniel先介绍了
11. 情绪与观点的关系:不同的人对同一事物可能有不同的看法,这与他们的情绪状态有关。选择题11中,正确答案是D。 12. 调控情绪:有效的情绪管理包括在适当场合表达情绪,以及提醒自己调整情绪。选择题12中,正确...
4. 文章体裁:单元测试中的阅读理解部分选取的是议论文,这种文体旨在探讨并论证一个观点,要求学生理解作者的立场和论据。 5. 论题分析:文章讨论的核心是电子游戏是否可以被视为艺术,涉及艺术的定义、表现形式...
这篇文档是针对英语学习的单元同步测试,主题是"未来的生活"(Unit3 Life in the Future)。测试内容涉及了多项选择题,主要检验学生对于词汇、语法、句型理解和文化背景知识的掌握。 1. 题目涉及短语搭配。选项中...
此文档是针对2015届高考英语二轮复习的“Unit 3 Computers”单元测试,属于新人教版必修2的课件资料。这份单元测试旨在帮助学生复习与计算机相关的英语词汇、表达和语境理解,以准备高考英语听力部分。 1. **听力...
根据提供的文件信息,我们可以推断出这份文档是针对四年级下学期语文课程的第六单元进行的一次单元测试题目集合。由于文件本身没有提供具体内容,我们将基于这个标题和描述中的信息来构建相关的知识点。 ### 四年级...
【标题】和【描述】提及的是一个针对初中七年级上册英语Unit 6的单元测试卷,这份测试卷包含了听力材料以及答案解析,是教师进行教学评估或学生自我检查学习效果的重要参考资料。作为一份教案,它旨在帮助教师设计...
4. ×,即使是小孩,也应该参与家庭决策,表达自己的看法。 5. ×,尽管年龄小,也应承担适当的家务,这是责任感的培养。 6. ×,在家庭矛盾中,不应偏袒任何一方,而应努力促进和谐。 7. √,家是基础,是情感的...
此文档是关于新人教版初中八年级上册英语Unit 5的单元测试卷,包含了听力材料和答案,适用于教师进行教学评估或学生自我检测。该测试卷是教案的一部分,旨在检验学生对本单元英语知识的掌握程度。 1. 听力理解:...