BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

谁来检查我们的单元测试?NCover2!

| 作者 王翔(Vision Wang) 关注 0 他的粉丝 发布于 2007年10月11日. 估计阅读时间: 3 分钟 | Google、Facebook、Pinterest、阿里、腾讯 等顶尖技术团队的上百个可供参考的架构实例!

随着NUnit和Visual Studio.NET 2005的推出,对.NET代码作单元测试似乎越来越容易了,而且更加自动化。但您是否考虑过这些单元测试是否真正“有效”呢?还是仅仅自我安慰的“额外工作量”呢?NCover起码可以帮忙做做检查。以前NCover是个开源的框架,最近它已经被商品化了。

Gnoso把NCover升级成为2.0版,并把它商品化了。虽然,之前通过开源方式可以获得NCover,但可能因为它定位的领域太吸引人了,以至于它的升级速度和集成性方面反倒总是差强人意。NCover是一个用来检查.NET单元测试代码与实际代码覆盖分析的工具,它在执行单元测试的过程中对执行情况进行监测,然后会记录下单元测试都调用过哪些代码,不过最重要的是它记录下哪些代码实际没有被单元测试掉用到。你也许觉得“我严格按照Write a little,Test a little”的步骤在编写单元测试,就是漏掉也很显眼,因为我写了[todo]了,但事实情况并非如此:

  • 面向对象一个特点就是多态,虚方法、抽象方法、重载方法、委托这些都很可能成为您察看不到的“死角”;
  • 1000行的代码也许做这么一次覆盖检查不麻烦,不过如果您负责一个1,000, 000行代码的项目,想看看大家是不是把该做的单元测试都作了,恐怕要写要记录的东西不是3、4个人可以做得来的;
  • 这些都不算最坏的情况,软件界有一个不变的规律就是变化本身,如果增加或者修改掉了一块功能,单凭人工在代码中翻腾一次这个经历就太痛苦了,不过这还没有短痛,都是长痛,别忘了唯一不变的就是变化。

虽然不一定特别权威,但NCover起码从覆盖角度告诉我们“你的单元测试做的是否够好”。很多人更喜欢它是因为他无须象其他类似工具在代码上增加“痕迹”,它可以直接在生产代码上进行检查,而且可以对Web Service和.NET Windows Service这些后台服务类代码进行检查。此次2.0产品化版本中,主要对产品得易用性作了较大改善,以前游离在外面的NCoverExplorer被集成到NConver里面,这样检查报告看起来更加人性化,而且还支持同时看多个项目(Project),毕竟.NET项目开发一般都是Solution层次的,一遍遍打开每个项目的报告确实惹人烦。企业版中还有一个特别有用的特性,就是可以把执行路径画出来,并记录下每个步骤的执行时间,相信您以前总碰到过类似的困扰——“到底怎么了,为什么跑得这么慢啊?”。NCover可以用图形化的方式展现这个执行过程。生产代码检查+Assembly检查+可视化执行路径,相信NCover会成为性能调整和代码优化的得力工具。

商品化之后,试用NCover感觉比以前舒服多了(不过要收100$+的使用许可了)。相信对于开发团队,尤其是“代码就是设计”的敏捷团队而言,NCover也可以作为一个不错的把关工具。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

testing the requirements! by yin cheng

No perfect software, but software should delivery requirments. Continuous Testing, integration is the key. If budget can not afford, unit test could be skipped, but some of them can not, this is depending on your experience.

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

1 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT