Eclipse中创建本身的JUnit测试

  这篇文章将向你介绍Junit,一个用来在项目中进行测试和调试的工具。在介绍完TDD(以测试驱动开发)理论后,将进一步讲解怎样在流行的Eclipse中创建你本身的JUnit测试。向你展现如何测试Hello World这样简单的程序。

  许多书上都讨论了自动测试,可是只有不多的著做注意到这么一个问题,那就是怎样把这些测试组织起来。随着测试的增长,放置和调用这些测试却变得更加麻烦。这将成为一个重要问题,以致于出现了TDD,极限编程(XP)使TDD得以普及。另外,你能够这样理解TDD:经过测试来开发。

  TDD的主要规范 :

  在编写程序代码以前,与之对应的自动测试必须被写好。甚至程序代码并不存在,那也要看见一个失败的测试结果。

  在测试经过后,副本代码必须被丢弃。

  有一个具体步骤(可能指的是《Extreme Programming》)能够被任何一个程序员来参考,而不须要特殊的其余方法。在咱们开始写测试以前,这些步骤(章节)应该被首先阅读——怎样组织自动测试。

  讲解一下不一样种类的测试:

  单元测试:检测模块(也就是类)的正确性。若是对象须要访问外部的数据资源,例如数据库,就须要模拟一个mock objects,但在实际中真实数据与测试环境是不一样的。

  客户测试:这是功能性、系统、和验收测试。用来测试总体的系统特性。在XP中,这些测试由用户编写。

  综合测试:介于用户测试和单元测试之间的桥梁。综合测试帮助测试应用程序的交互性。通常状况下,mock objects不被用于综合测试,它会增长测试时间。一样,综合测试常常依赖特殊的测试环境,例如数据库送来的测试数据。综合测试也须要用到外部类库。例如为J2EE应用程序进行综合测试的类库Cactus。解释这些测试超出了本文的范围,须要更加详细的信息请参考[url]http://jakarta.apache.org/cactus/[/url]。

  开发人员测试:这是用来让开发人员检验本身代码或新函数的。对于每个开发人员,只要有可能,就须要有更多的测试来检验代码。组织这些测试和组织程序代码同样重要。

  在如下章节,只要提到“测试”,那就指的是开发人员测试。

  咱们几乎准备好开始创建测试了,先应该为咱们的测试选择名字。你也许会说,“这不是问题:把‘Test’这个字放在类名前面,就行了!”不会这么快!让我来讲一下这个步骤存在的问题:

  在TDD中,被测试的类或者方法还不存在。

  一个测试可以覆盖多个方法,甚至多个类,这是可能的。

  以上只是一些广泛问题;还存在更多的问题。
   让我来提一个建议,在测试命名时:测试类的名字应该让人一眼就知道这是一个测试类,且能说明它要测试什么,注意是否和其余类重名。按照以上建议作,就很简单了,也不用担忧名字太长或难听。

  即将在Eclipse中用JUnit工具建立咱们第一个测试了。假设你已经下载了一个最新的Eclipse版本。若是尚未,你应该去官方站点[url]http://www.eclipse.org[/url]下载。还须要JUnit,也能够从[url]http://www.junit.org/[/url]下载。

  运行Eclipse。新建一个workplace项目,点击文件->新建->项目,选择Java项目,点击下一步。起一个项目名称,例如ProjectWithJUnit。点击完成。这样就完成新项目的创建了。再来配置一下Eclipse,在构建路径中添加JUnit类库。在工具条上点击项目->属性,选择Java构建路径,库,选择添加外部JAR,浏览Junit被存储的目录,选择junit.jar,点击打开。你将会看见JUnit出如今库的列表中。点击肯定,让Eclipse重建路径。

  如今开发咱们的“Hello World”例子。按照TDD的规则,应该在代码创建之前先把测试写好。为了可以在某出开始,咱们假设将来的类名是HelloWorld,而且有一个方法Say(),这个方法返回String的值(例如“Hello World!”)。

  创建测试,在ProjectWithJUnit的标题上面点击右键,选择新建->其余,展开“Java”选项,选择JUnit。在右边的栏目对话框中选择测试案例,而后下一步。参考图1。

  图1. 在Eclipse中创建JUnit测试
  在测试类这一栏中,写上将要被测试的类名HelloWorld。选择一个测试案例的名字,例如TestThatWeGetHelloWorldPrompt(是的,看上去很长,可是很清楚它的行为。)点击完成。

  TestThatWeGetHelloWorldPrompt的代码以下:

  import junit.framework.TestCase;

  public class TestThatWeGetHelloWorldPrompt
  extends TestCase {
  public TestThatWeGetHelloWorldPrompt(
  String name) {
   super(name);
  }
  public void testSay() {
  HelloWorld hi = new HelloWorld();
  assertEquals("Hello World!", hi.say());
  }
  public static void main(String[] args) {
  junit.textui.TestRunner.run(
  TestThatWeGetHelloWorldPrompt.class);
  }
  }

  代码并不复杂;只是有点不同凡响。然而,让咱们考察一下细节。咱们继承了JUnit的TestCase类,它在JUnit的javadocs定义为“运行众多测试的夹具。”JUnit也有TestSuite类,它是一组测试案例的集合,但在本文中不作讨论。

  创建测试案例的步骤以下:

  一、创建一个junit.framework.TestCase的实例。

  二、定义一些以“test”开头的无返回方法(例如testWasTransactionSuccessful(),testShow(),等等)。

  TestThatWeGetHelloWorldPrompt.java包含这些:TestCase的子类和一个叫作testSay()的方法。这个方法调用了assertEquals()函数,它用来比较咱们预期的值和由say()返回的值。

  main()方法用来运行测试和显示输出的。JUnit的TestRunner处理测试,提供基于图像和文本的输出表现形式。咱们使用基于文本的版本,由于Eclipse支持它,且也适合咱们。当开始运行后,基于文本的版本测试会以文本形式输出,Eclipse会把这些输出自动变成图像界面的输出。

  按照TDD规范,首次运行测试,应该故意让它失败。点击运行->运行为->Junit测试(记住TestThatWeGetHelloWorldPrompt.java应该被突出的显示在包资源管理器中)。在左边窗口,应该看见JUnit窗口而不是包资源管理器,它显示一个红条,一次失败的测试,具体的失败缘由参看图2。若是没有自动显示这些内容,点击JUnit标签(在底部的左边)。

  图2. JUnit中失败的测试
  很好!但却失败了。如今咱们来创建被测试代码:在包资源管理器窗口的ProjectWithJUnit标题上右击,选择新建->类。选择类名,咱们已经假设了它叫HelloWorld,而后直接点击完成。为HelloWorld.java填入下列代码:

  public class HelloWorld {
  public String say() {
  return("Hello World!");
  }
  }

  这段代码很简单,甚至不须要注解,咱们再来看看结果。按照上面描述过的方式,在JUnit的窗口中显示了一个绿条,参看图3。绿条证实测试成功。

  图3. JUnit中成功的测试
  如今,咱们想再让测试失败一次,但缘由不一样。这有助于展现JUnit测试中不一样的报错信息。修改assertEquals()代码,把“Hello World!”变成“Hello Me!”。当再次运行JUnit时,结果变成了红条,在JUnit窗口的底部输出了失败缘由,参看图4。
  图4. JUnit中的ComparisonError
  最后,我想说一下关于测试是开发过程当中的必要部分的话题。测试代码一直是开发中的重要部分。通过近几年的发展,已获得了很大的提升,这要归功于强大的理论研究(好比“expectations-based development”等等),和快速发展的测试工具包,还有测试过程的改进。若是你对这篇文章感兴趣,那请你花一些时间来正式的学习一下测试理论吧,这对你的工做颇有用。
相关文章
相关标签/搜索