此文收集一些平时使用单元测试碰到的问题和解决办法,供你们参考。html
Microsoft UnitTestFramework | 若是须要元素的顺序一致,可使用CollectionAssert.AreEqual;若是不须要考虑顺序,可使用CollectionAssert.AreEquivalent。(有的地方说MSTest的Assert.AreEqual支持集合类型比较,我测试过,忽悠人的) |
nUnit | 同上 |
xUnit | xUnit的Assert.Equal(c1, c2)能够支持集合类型比较,c1和c2的元素顺序必须一致 |
Microsoft UnitTestFramework和nUnit的用法很是相似,而xUnit因为吸收了nUnit的设计上的经验,用法更加简洁。下面是周公写的两篇文章,nUnit和xUnit介绍的很是详细,你们能够阅读一下:git
单元测试的目标是一次只验证一个方法,小步的前进,细粒度的测试,可是假如某个方法依赖于其余一些难以操控的东东,好比说网络链接、数据库链接、系统时间、或者是Servlet容器,那么咱们该怎么办呢?要是你的测试依赖于系统的其余部分,甚至是系统的多个其余部分呢?在这种状况下,假若不当心,你最终可能会发现本身几乎初始化了系统的每一个组件,而这只是为了给一个测试创造足够的运行环境让它们能够运行起来。忙乎了大半天,看上去咱们好像有点违背了测试的初衷了。这样不只仅消耗时间,还给测试过程引入了大量的耦合因素,好比说,可能有人兴致冲冲地改变了一个接口或者数据库的一张表,忽然,你那卑微的单元测试的神秘的挂掉了。在这种状况发生几回以后,即便是最有耐心的开发者也会泄气,甚至最终放弃全部的测试,那样的话后果就不能想像了。github
再让咱们看一个更加具体的状况:在实际的面向对象软件设计中,咱们常常会碰到这样的状况,咱们在对现实对象进行构建以后,对象之间是经过一系列的接口来实现。这在面向对象设计里是最天然不过的事情了,可是随着软件测试需求的发展,这会产生一些小问题。举个例子,用户A如今拿到一个用户B提供的接口,他根据这个接口实现了本身的需求,可是用户A编译本身的代码后,想简单模拟测试一下,怎么办呢?这点也是很现实的一个问题。咱们是否能够针对这个接口来简单实现一个代理类,来测试模拟,指望代码生成本身的结果呢?幸运的是,有一种测试模式能够帮助咱们:mock对象。Mock对象也就是真实对象在调试期的替代品。web
关于何时须要Mock对象,Tim Mackinnon给咱们了一些建议:sql
.NET Mock Framework有哪些,能够看看下面几个网页:数据库
关于Mock框架的实现方式,大概有两种:基于动态代理实现;基于编译时静态织入实现。各个框架的用法看一下介绍很快就能够掌握了,关键是如何使用各类mock技术,存在的争论主要有下面几个:编程
实际状况中,我会根据项目实际状况来选型。考虑的因素主要有:安全
测试驱动数据库开发,也称为TDDD(Test-Driven Database Development),是把TDD的理念运用到数据库开发的过程当中,经过数据库测试来定义数据库的行为,如同经过测试定义应用程序代码逻辑同样,来保证数据库重构过程当中的质量。网络
使用 TDDD 的优势包括:app
推荐感兴趣的朋友看看伍斌老师翻译《测试驱动数据库开发——Test-Driven Database Development: Unlocking Agility》这本书:
目录结构:http://my.safaribooksonline.com/book/databases/database-design/9780132776486
伍斌老师的译者序:让数据库应用开发再也不裸奔——Test-Driven Database Development译者序
样章试读:http://ptgmedia.pearsoncmg.com/images/9780321784124/samplepages/032178412X.pdf
原做者Max Guernsey的PPT:http://www.maxthe3rd.com/test-driven-database-development/TDD-Database.pdf
因为这块研究不深,暂时列举一些数据库单元测试框架,将来若是研究更加深刻了,再专门写文章介绍。
数据库单元测试的框架: