`
grzrt
  • 浏览: 188107 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Junit使用简明手册

 
阅读更多

Junit使用简明手册

XP进行开发的过程,unit test是必不可少的环节。作为unit testjunit是首选的工具。本文从使用目的、如何使用、以及使用中需要考虑的问题,简略描述了junit的基本用法。

使用目的
junit
java中书写unit testframework,目前一些流行的unit test工具大都都是在junit上扩展而来的。目前它的版本是junit<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /><chsdate w:st="on" isrocdate="False" islunardate="False" day="30" month="12" year="1899">3.8.1</chsdate>,可以从www.junit.org上下载。

用法
1.
基本使用步骤,Junit的使用非常简单,它的基本使用步骤:

-
创建,从junit.framework.TestCase派生unit test需要的test case

-
书写测试方法,提供类似于如下函数签名的测试方法:

public void testXXXXX();

-
编译,书写完test case后,编译所写的test case

-
运行,启动junit test runner,来运行这个test case

Junit
提供了2个基本的test runner:字符界面和图形界面。启动命令分别如下:

a
图形界面:

java junit.swingui.TestRunner XXXXX

b
字符界面:

java junit.textui.TestRunner XXXXX

2.
使用例子:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

程序代码:

importjunit.frmework.TestCase;
publicclassTestSampleextendsTestCaset{
publicvoidtestMethod1(){
asserttrue(true);
}
}



3. setUp
tearDown,这两个函数是junit framework中提供初始化和反初始化每个测试方法的。setUp在每个测试方法调用前被调用,负责初始化测试方法所需要的测试环境;tearDown在每个测试方法被调用之后被调用,负责撤销测试环境。它们与测试方法的关系可以描述如下:

测试开始 -> setUp -> testXXXX -> tearDown ->测试结束


4.
使用例子:

程序代码:

importjunit.frmework.TestCase;
publicclassTestSampleextendsTestCaset{
protectedvoidsetUp(){
//
初始化……
}
publicvoidtestMethod1(){
asserttrue(true);
}

potectedvoidtearDown(){
//
撤销初始化……
}
}




5.
区分failexception

- fail
,期望出现的错误。产生原因:assert函数出错(如assertFalse(true));fail函数产生(如fail(……))。

- exception
,不期望出现的错误,属于unit test程序运行时抛出的异常。它和普通代码运行过程中抛出的runtime异常属于一种类型。

对于assertfail等函数请参见junitjavadoc

6.
使用例子:

程序代码:

importjunit.frmework.TestCase;
publicclassTestSampleextendsTestCaset{
protectedvoidsetUp(){
//
初始化……
}

publicvoidtestMethod1(){
……
try{
booleanb=……
asserttrue(b);
thrownewException(“Thisisatest.”);
fail(“Unablepoint.”);//
不可能到达
}catch(Exceptione){
fail(“Yes,Icatchu”);//
应该到达点
}
……
}

potectedvoidtearDown(){
//
撤销初始化……
}
}



7.
组装TestSuite,运行更多的test。在junit中,TestTestCaseTestSuite三者组成了composiste pattern。通过组装自己的TestSuite,可以完成对添加到这个TestSuite中的所有的TestCase的调用。而且这些定义的TestSuite还可以组装成更大的TestSuite,这样同时也方便了对于不断增加的TestCase的管理和维护。

它的另一个好处就是,可以从这个TestCase树的任意一个节点(TestSuiteTestCase)开始调用,来完成这个节点以下的所有TestCase的调用。提高了unit test的灵活性。

8.
使用例子:

程序代码:

importjunit.framework.Test;
importjunit.framework.TestSuite;
publicclassTestAll{
//
定义一个suite,对于junit的作用可以视为类似于java应用程序的main

publicstaticTestsuite(){
TestSuitesuite=newTestSuite("Runningalltests.");
suite.addTestSuite(TestCase1.class);
suite.addTestSuite(TestCase2.class);
returnsuite;
}
}



运行同运行单独的一个TestCase是一样的,参见step 1 “运行

9.
使用Ant junit task。我们除了使用java来直接运行junit之外,我们还可以使用junit提供的junit taskant结合来运行。涉及的几个主要的ant task如下:

- <junit>
,定义一个junit task

- <batchtest>
,位于<junit>中,运行多个TestCase

- <test>
,位于<junit>中,运行单个TestCase

- <formatter>
,位于<junit>中,定义一个测试结果输出格式

- <junitreport>
,定义一个junitreport task

- <report>
,位于<junitreport>中,输出一个junit report

具体的语法请参见相关文档。

10.
使用例子:

程序代码:

<junitprintsummary="yes"haltonfailure="no">
<classpath>
<pathrefid="classpath"/>
<pathelementlocation="${dist.junit}"/>
</classpath>

<formattertype="brief"usefile="false"/>
<formattertype="xml"/>
<batchtesttodir="${doc.junitReport}">
<filesetdir="${dist.junit}"includes="**/*Test.class"/>
</batchtest>
</junit>

<junitreporttodir="${doc.junitReport}">
<filesetdir="${doc.junitReport}">
<includename="TEST*-*.xml"/>
</fileset>
<reportformat="frames"styledir="${junit.styleDir}"todir="${doc.junitReport}"/>
</junitreport>



检查表
junit
的使用并不很难,然而要书写一个好的TestCase却并非易事。一个不好的TestCase往往是既浪费了时间,也起不了实际的作用。相反,一个好的TestCase,不仅可以很好的指出代码中存在的问题,而且也可以作为代码更准确的文档,同时还在持续集成的过程中起非常重要的作用。在此给出书写TestCase时需要注意的几点:

-
测试的独立性:一次只测试一个对象,方便定位出错的位置。这有2层意思:一个TestCase,只测试一个对象;一个TestMethod,只测试这个对象中的一个方法。

-
给测试方法一个合适的名字。

-
assert函数中给出失败的原因,如:assertTrue( “… should be true”, ……),方便查错。在这个例子中,如果无法通过assertTrue,那么给出的消息将被显示。在junit中每个assert函数都有第一个参数是出错时显示消息的函数原型。

-
测试所有可能引起失败的地方,如:一个类中频繁改动的函数。对于那些仅仅只含有getter/setter的类,如果是由IDE(如Eclipse)产生的,则可不测;如果是人工写,那么最好测试一下。

-
setUptearDown中的代码不应该是与测试方法相关的,而应该是全局相关的。如针对与测试方法AB,在setUptearDown中的代码应该是AB都需要的代码。

分享到:
评论

相关推荐

    junit使用简明手册.rar

    《JUnit使用简明手册》是针对Java开发人员的一份实用指南,主要涵盖了如何有效地使用JUnit进行单元测试。JUnit是一款广泛使用的开源测试框架,它简化了Java应用的单元测试过程,帮助开发者确保代码的质量和可靠性。...

    junit使用简明手册.doc

    你可以使用 `@Parameters` 注解来定义参数集,然后在测试方法上使用 `@Test` 注解并传入参数。 ```java import org.junit.*; public class ParameterizedTestExample { @Parameters public static Collection[]&gt;...

    junit使用简明手册(含JAR包)

    随着XP软件工程技术的广泛推广,单元测试的作用在软件工程中变得越来越重要,而一个简明易学、适用广泛、高效稳定的单元测试框架则对成功的实施单元测试有着至关重要的作用。在java编程语句环境里,Junit Framework...

    junit.rar_Java编程_Java_

    首先,"junit使用简明手册.mht"可能是对JUnit基本用法的快速指南,涵盖了如何创建测试类、定义测试方法、使用断言以及运行测试的基本步骤。通过这份手册,初学者可以快速上手JUnit的基本操作。 "循序渐进学习Junit....

    Parasoft C++ test 9.2官方用户手册_eclipse_中文版

    4. **单元测试**:C++test支持JUnit和Google Test等单元测试框架,手册会讲解如何创建、运行和管理测试用例,以及如何利用测试覆盖率分析来评估代码质量。 5. **定制化**:用户可以自定义规则集,根据项目需求调整...

    cucumber-reports-plugin:Jenkins插件生成CucumberJVM报告

    为了使该插件正常工作,您必须使用JUnit运行器并生成json报告。 该插件将json报告转换为概述html,并链接到具有统计信息和结果的单独的功能文件html。安装詹金斯。 安装插件。 重新启动詹金斯。 如果您需要更多详细...

    软件开发文档编写要求

    对于自动化测试,如使用JUnit或Selenium,应提供脚本编写规范和执行指南。 总之,软件开发文档编写要求旨在促进团队间的有效沟通,确保项目的顺利进行。通过规范化的文档,可以降低理解成本,提高开发效率,同时也...

    thinkingjava大全(包括第2版、第4版、所有源代码)

    - 集合框架:List、Set、Map接口及其实现类的使用。 - 文件I/O:文件读写、流的概念和操作。 - 多线程:线程的创建、同步、通信。 - 泛型:类型参数化、通配符、类型推断等。 - 枚举和注解:新的语法元素及其...

    team6-titan-2015:CAU 2015年软件工程学期项目

    7. **单元测试与集成测试**:为了确保代码质量,团队可能使用JUnit等工具进行了单元测试,也可能进行了集成测试以确保不同模块的协同工作。 8. **开发工具**:可能使用了Eclipse、IntelliJ IDEA等IDE进行开发,使用...

Global site tag (gtag.js) - Google Analytics