《JUnit实战(第2版)》—— 1.3 理解单元测试框架

1.3 理解单元测试框架

JUnit实战(第2版)
单元测试框架应该遵循以下几条最佳实践规则。CalculatorTest程序中一些不起眼的改进就突出体现了所有单元测试框架应该遵循(按照我们的经验)的三大规则:

每个单元测试都必须独立于其他所有单元测试而运行;
框架应该以单个测试为单位来检测和报告错误;
应该易于定义要运行哪些单元测试。
“稍好一点”的CalculatorTest程序虽然向以上规则靠拢了,但仍然存在着不足。例如,为了使每个单元测试能够真正独立运行,就应该在不同的类实例中运行它们,理想的情况是在不同的类加载器(class loader)实例中运行它们。

我们现在能够通过增加一个新的方法并且在main中增加一个对应的try/catch块来增加新的单元测试。显然,这是一个进步,但是在真正的单元测试集中,这样做还远远不够。经验告诉我们,很大的try/catch块会带来诸多维护问题。我们很可能遗漏一个单元测试并且还对此毫无意识!

如果我们可以增加新的测试方法并继续正常工作,那真是太好了。但是,程序又是如何知道要运行哪些方法呢?好吧,我们应该有一个简单的注册过程。一个注册方法至少可以盘点哪些测试正在运行。

另一种方法是使用Java的reflection和introspection功能。程序可以检查自身并决定要运行任何遵循某种命名协定的方法,例如,以“test”开头的方法。

对于单元测试框架而言,使增加测试变得更加简单(上文中提到的第3条规则)听起来像是另一条不错的规则。为了满足这条规则(通过注册或自我检测),还需要编写大量的支持代码,但这将是值得的。虽然起初的工作量会很大,但是随着每次我们增加一个新的测试,所有的努力都会得到回报。

令人高兴的是,JUnit团队为我们解决了这个麻烦。JUnit框架已经支持自我检测方法。它也支持针对每个测试使用不同的类实例和类加载器实例,并逐个报告每个测试的所有错误。既然你已经明白了你为什么要需要一个单元测试框架,那么就让我们进一步来了解JUnit。

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

时间: 2024-11-13 06:42:56

《JUnit实战(第2版)》—— 1.3 理解单元测试框架的相关文章

《JUnit实战(第2版)》—第1章1.3节理解单元测试框架

1.3 理解单元测试框架JUnit实战(第2版)单元测试框架应该遵循以下几条最佳实践规则.CalculatorTest程序中一些不起眼的改进就突出体现了所有单元测试框架应该遵循(按照我们的经验)的三大规则: 每个单元测试都必须独立于其他所有单元测试而运行:框架应该以单个测试为单位来检测和报告错误:应该易于定义要运行哪些单元测试."稍好一点"的CalculatorTest程序虽然向以上规则靠拢了,但仍然存在着不足.例如,为了使每个单元测试能够真正独立运行,就应该在不同的类实例中运行它们,

《JUnit实战(第2版)》—— 导读

前言 JUnit实战(第2版)作为一个屡获殊荣的数学家,我无法容忍平庸.这就是数学所教给我的─不要停止,直到你把它完成,并且不仅要用好的方法,而且要用最好的方法. 当我开始编写软件时,我发现这条原则同样适用.我认识一些同事,他们对自己的工作非常马虎随便,并且我也看到了他们因为自己的疏忽大意而深受其害.他们不耐烦地完成他们的任务,从不担心他们开发的软件质量,更不用说寻找可能的最佳解决方案.对于那些家伙,重用相同的代码就意味着,在任何他们需要相同代码的地方简单地复制和粘贴它即可.我看到了不耐烦地尽快

《JUnit实战(第2版)》目录—导读

版权声明JUnit实战(第2版)Original English language edition, entitled JUnit in Action (Second Edition) by Petar Tahchiev, Felipe Leme, Vincent Massol, Gary Gregory, published by Manning Publications Co., 209 Bruce Park Avenue, Greenwich, CT 06830. Copyright 20

《JUnit实战(第2版)》—— 2.2 运行参数化测试

2.2 运行参数化测试 JUnit实战(第2版) Parameterized(参数化)的测试运行器允许你使用不同的参数多次运行同一个测试.代码2.2给出一个Parameterized运行器的实例(你可以在第1章的源代码示例中找到这个测试). 代码2.2 参数化测试 要使用Parameterized的测试运行器来运行一个测试类,那就必须要满足以下要求.首先,测试类必须使用@RunWith注释,并且要将Parameterized类作为它的参数..\Lucene实战\1.tif.其次,你必须声明测试中

《JUnit实战(第2版)》—第1章1.1节证实它能运行

第1部分 认识JUnit JUnit实战(第2版) 欢迎阅读<JUnit实战(第2版)>!JUnit是一个由Kent Beck和Erich Gamma于1995年年底着手编写的框架.自此以后,JUnit框架日益普及,现在已经成为单元测试Java应用程序的事实上的标准. 本书是第2版.<JUnit实战>的第1版非常畅销,由Vincent Massol和Ted Husted于2003年编写,其内容是基于JUnit 3.x版本的. 我们涵盖了JUnit最新的版本4.6,讨论了许多第1版尚

《JUnit实战(第2版)》—— 1.1 证实它能运行

1.1 证实它能运行 JUnit实战(第2版) 一些开发人员认为自动测试是开发过程中非常重要的一部分.你无法证实一个组件能够运行,除非它通过了一系列全面的测试.有两名开发人员觉得这类单元测试如此重要,以至于值得为它编写一个框架.1997年,Erich Gamma和Kent Beck针对Java创建了一个简单但有效的单元测试框架,叫做JUnit.他们的工作遵循了SUnit的设计,而SUnit是Kent Beck早期为Smalltalk创建的一个框架. NITION 框架* 个应用程序的半成品{![

《JUnit实战(第2版)》—— 第2章 探索JUnit的核心

第2章 探索JUnit的核心 JUnit实战(第2版)Mistakes are the portals of discovery. 错误是发现之门. -James Joyce 本章重点 使用核心JUnit类理解JUnit的机制理解JUnit的生命周期在第1章中,我们已经明确了我们需要一种可靠的.可复用的方法来测试我们的程序.我们的解决方案就是编写或复用一个框架来驱动测试代码,以测试程序的API.因为我们的程序对现有的类增加了新的类.新的方法,所以我们也需要增加相应的测试代码.经验告诉我们,有时候

《JUnit实战(第2版)》—第2章2.1节探索JUnit核心

第2章 探索JUnit的核心JUnit实战(第2版)Mistakes are the portals of discovery. 错误是发现之门. -James Joyce 本章重点 使用核心JUnit类理解JUnit的机制理解JUnit的生命周期在第1章中,我们已经明确了我们需要一种可靠的.可复用的方法来测试我们的程序.我们的解决方案就是编写或复用一个框架来驱动测试代码,以测试程序的API.因为我们的程序对现有的类增加了新的类.新的方法,所以我们也需要增加相应的测试代码.经验告诉我们,有时候类

《JUnit实战(第2版)》—— 2.1 探索JUnit核心

2.1 探索JUnit核心 JUnit实战(第2版)第1章中的CalculatorTest程序,如代码2.1所示,定义了一个测试类,它包含了一个单独的测试方法testAdd. 定义一个测试类的要求是,这个类必须是公共的并且包含了一个无参数的构造函数.在我们的示例中,因为我们没有定义任何其他构造函数,所以我们也不需要定义无参数的构造函数:Java会为我们隐式地创建它. 创建一个测试方法的要求是,这个方法必须使用@Test注释,是公共的,不带任何参数,并且返回void类型. 代码2.1 Calcul