从参加工作以来,参加了大大小小好几个项目了。对于项目中间的单元测试这一项,有一些想法,不吐不快。主要围绕以下几个方面来说一说。(大家多多批评。)
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阶段,只是对单元测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,欢迎高手指教。一、单元测试的概念单元通俗的说就是指一个实现简单功能的函数。单元测试就是只用一组...
1. “只要程序能运行就可以了,写单元测试浪费时间”:这种看法忽略了单元测试在提高代码质量和维护性方面的重要性。 2. “代码很简单不需要单元测试”:简单代码同样存在错误的可能,且随着时间推移,代码可能会变...
【标题】: 高一语文下册第三单元测试1[精选].doc 【描述】: 高一语文下册第三单元测试1[精选].doc 【标签】: 试题 答案 这篇文档是一份高一语文下册第三单元的测试试卷,包含了基础选择题和文言文阅读理解部分,...
这份文档是关于仁爱版八年级上册英语教材Unit 4的单元测试题及其答案解析。根据提供的文件信息,我们可以分析出以下知识点: 1. 基础词汇和句型理解:文档中包含了各种基础英语词汇和句型的测试题目,例如选项A、B...
都是些自己的看法,不一定准确,欢迎高手指 如何编写软件单元测试用例(白盒测试) 软件测试 前段时间公司进行有关测试的培训,集成测试,性能测试,压力测试说了很多。由于本人还处于Coder阶段,只是对单元测试有...
如何编写单元测试用例(白盒测试)软件测试前段时间公司进行有关的培训,集成测试,,压力测试说了很多。由于本人还处于Coder阶段,只是对测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,...
通过对“七下语文第五单元测试卷及答案精选.doc”的分析,我们可以看到这一单元的测试内容和学习目标的综合体现。 首先,语文知识积累及运用部分,让学生在字音、字形、词语选择和病句修改等方面进行了复习和巩固。...
本文将结合2019-2020学年高中语文第二单元单元测试卷中关于“侠”的相关知识点,探讨侠的概念、特征、担当,以及侠与江湖的关系,并分析武侠文化对现代社会的影响。 首先,侠的概念并非局限于特定的社会阶层或职业...
新人教版的《统计》单元测试3正是围绕这一目标展开,内容涵盖了对数据的收集、整理、分析以及如何从图表中提取信息的能力考察。 首先,测试的第一部分聚焦于兴趣小组的偏好统计。学生被要求通过完成统计图表,对...
这篇文档标题为"新人教版九年级上册英语Unit 2单元测试卷(含听力材料及答案解析).doc",是针对初中三年级上学期英语教材Unit 2的一份综合测试卷,旨在检验学生对本单元内容的理解和掌握情况。描述中的信息表明,这...
这份文档是针对人教版英语八年级上册第一单元的一份测试题,旨在评估学生对本单元内容的理解和掌握程度。下面将详细分析并解释其中涉及的一些知识点。 1. **疑问词的选择**:题目1中询问昨晚做了什么,用"What"引导...
说起单元测试的好处相信大家都能列举出不少,可是很多...”资深敏捷咨询师腾振宇(DanielTeng)在GTUG-TopGeek开发工程管理沙龙就以此为题,结合最近的一个项目,和大家分享了他对单元测试的一些看法。 Daniel先介绍了
11. 情绪与观点的关系:不同的人对同一事物可能有不同的看法,这与他们的情绪状态有关。选择题11中,正确答案是D。 12. 调控情绪:有效的情绪管理包括在适当场合表达情绪,以及提醒自己调整情绪。选择题12中,正确...
因此,2015届高考英语二轮复习中的“Unit 3 Computers”单元测试,成为新人教版必修2中极为重要的一部分,它的设计充分考虑到了高中生对于计算机相关知识的需求,以及高考英语听力测试的特点。 首先,高考英语听力...
这篇文档是针对英语学习的单元同步测试,主题是"未来的生活"(Unit3 Life in the Future)。测试内容涉及了多项选择题,主要检验学生对于词汇、语法、句型理解和文化背景知识的掌握。 1. 题目涉及短语搭配。选项中...
新人教版初中七年级上册英语Unit 6单元测试卷是一份专为初中七年级学生设计的综合型测试材料,其中包含了听力材料及其答案解析,这为学生提供了全方位的学习评估。作为教师在教学计划中的一个重要环节,通过这份单元...
在这一部分,可能会包含一些开放性题目,鼓励学生表达自己对某一文学作品的理解和感受,或是对某一现象的看法。这样的题目设计旨在激发学生的思考,培养他们的批判性思维和创新能力。 综上所述,一份完整的新部编版...
根据提供的文件信息,我们可以推断出这份文档是针对四年级下学期语文课程的第六单元进行的一次单元测试题目集合。由于文件本身没有提供具体内容,我们将基于这个标题和描述中的信息来构建相关的知识点。 ### 四年级...
4. ×,即使是小孩,也应该参与家庭决策,表达自己的看法。 5. ×,尽管年龄小,也应承担适当的家务,这是责任感的培养。 6. ×,在家庭矛盾中,不应偏袒任何一方,而应努力促进和谐。 7. √,家是基础,是情感的...