`

关于单元测试的一些看法

阅读更多

从参加工作以来,参加了大大小小好几个项目了。对于项目中间的单元测试这一项,有一些想法,不吐不快。主要围绕以下几个方面来说一说。(大家多多批评。)

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阶段,只是对单元测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,欢迎高手指教。一、单元测试的概念单元通俗的说就是指一个实现简单功能的函数。单元测试就是只用一组...

    如何编写软件单元测试用例(白盒测试)

    都是些自己的看法,不一定准确,欢迎高手指 如何编写软件单元测试用例(白盒测试) 软件测试 前段时间公司进行有关测试的培训,集成测试,性能测试,压力测试说了很多。由于本人还处于Coder阶段,只是对单元测试有...

    如何编写单元测试用例(白盒测试)

    如何编写单元测试用例(白盒测试)软件测试前段时间公司进行有关的培训,集成测试,,压力测试说了很多。由于本人还处于Coder阶段,只是对测试有了些了解。写下来怕以后自己忘记了。都是些自己的看法,不一定准确,...

    我讨厌单元测试:滕振宇谈如何进行单元测试

    说起单元测试的好处相信大家都能列举出不少,可是很多...”资深敏捷咨询师腾振宇(DanielTeng)在GTUG-TopGeek开发工程管理沙龙就以此为题,结合最近的一个项目,和大家分享了他对单元测试的一些看法。  Daniel先介绍了

    软件测试经典面试题 (超实用)

    70、请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。 21 71、测试计划工作的目的是什么?测试计划工作的内容都包括什么?其中哪些是最重要的? 22 72、您所熟悉的测试用例...

    软件测试经典题目5

    82、单元测试、集成测试、系统测试的侧重点是什么? 83、集成测试通常都有那些策略? 84、一个缺陷测试报告的组成 85、基于WEB信息管理系统测试时应考虑的因素有哪些? 86、软件测试项目从什么时候开始,?为...

    Mock框架的三次迭代,让你的单元测试更高效

    对于单元测试中的单元,不同的人有不同的看法:可以理解为一个方法,可以理解为一个完整的接口实现,也可以理解为一个完整的功能模块或者是多个功能模块的一个耦合。根据以往的单元测试经验,在设计单元测试用例时,...

    开发、测试、资料面试题集锦

    3.关于索引的一些看法(是否越多越好) 4.索引的类型 + w: p# I+ ? h+ A1 f* A* ?+ @& W0 W3 x0 f; U知识管理频道5.主键 3 a/ w o, x! a! \: i0 m三.简答题 % X' }1 j/ @1 _. ?2 a- K1.一个用户如何访问数据库,写出...

    dapper-wrapper:这是我对存储库和工作单元模式的看法。 我目前还没有在生产系统中使用它,所以请在使用之前彻底测试它

    这是我对存储库和工作单元模式的看法。 起初我试图尽可能地与数据访问无关,但是这在其应用程序中适得其反,所以我决定只关注 Dapper/DapperExtensions。 理想情况下,您可以在一个地方简单地更改底层实现(例如...

    view-testing-examples:在Web开发中测试视图组件的示例

    查看测试示例 有一些视图组件测试的示例 目录 Backbone.js 第一个稳定版本于2010年发布。它具有MVP架构和某种类似于MVC的模式。 应用 此回购中的应用受此帖子启发。... 在单元测试中,我们测试Co

    space-invaders:我对太空侵略者的看法-但完全与功能编程有关!

    单元测试这种编程风格的主要优点是它非常容易测试。 要使用面向对象编程来彻底创建测试,您需要经过繁琐的过程才能将对象置于所需状态,然后再检查行为是否符合预期。艺术我喜欢为自己创建的东西创建自己的资产,...

    Othello:奥赛罗(Othello)的数字版本,我个人最喜欢的棋盘游戏之一

    从单元测试到体系结构,再到了解一些非常古怪的ES6功能,这个项目已经教会了我很多关于编程的知识。 该项目的目标是拥有一个完整的Web应用程序,其中两个玩家可以互相邀请对方参加会话,并通过HTTPS玩奥赛罗游戏。 ...

    hugsycms:适用于企业应用程序的即用型UI解决方案,作为React样板

    :check_mark_button: UI测试:通过单元测试和e2e测试安全飞行 浏览器支持 不支持IE,Safari和Google浏览器是最好的体验。 边缘 火狐浏览器 Chrome合金 苹果浏览器 歌剧 边缘 最近2个版本 最近2个版本 最近2个...

    r2d2-adventure:编码挑战。 它本来应该是一个控制台应用程序,但我选择在Re​​act中构建它

    我使用生成了一个默认的React应用,其中包括诸如Jest单元测试框架之类的功能。 我在项目中添加了酶,用于测试React组件。 我能够编写单元测试,以涵盖应用程序的业务逻辑以及React组件的显示。 src / components / ...

    Vistas_Reservas_Auditorios:他们是礼堂预订项目的看法

    如果您不愿意阅读, Laracasts包含1100多个视频教程,涉及各种主题,包括Laravel,现代PHP,单元测试,JavaScript等。 通过进入我们全面的视频库,提高自己和整个团队的技能水平。 Laravel赞助商 我们要感谢以下...

    Android用MVP实现一个简单的类淘宝订单页面的示例

    优点:降低耦合,层级职责更明显,易于单元测试 缺点:造成类数量增多,在某些场景下presenter的复用会产生接口冗余 这几天把以前项目上做过的一个类似淘宝订单的页面单独提取出来重新做了一遍,把一些公共代码提取...

    Explorando-Marte

    JUnit用于单元测试; JMockit用于模拟和检查单元测试。设计由于该应用程序只是一个客户端,因此我不想创建一个域层,而只创建一个表示层和一个应用程序层: 看法表示层,负责为用户提供命令行界面,并实现有助于...

    TicTacToe-mvvm:Android MVVM井字游戏

    井字游戏-MVVM 具有MVVM的优点是易于测试和模块化,同时还减少了我们为连接视图+模型而必须编写的粘合代码。模型该模型是我们的井字游戏应用程序的数据+状态+业务逻辑。... 评估现在,单元测试甚至变得更加容易,因为您

Global site tag (gtag.js) - Google Analytics