eclipse中Junit的配置.docx

上传人:b****6 文档编号:7196537 上传时间:2023-01-21 格式:DOCX 页数:12 大小:20.12KB
下载 相关 举报
eclipse中Junit的配置.docx_第1页
第1页 / 共12页
eclipse中Junit的配置.docx_第2页
第2页 / 共12页
eclipse中Junit的配置.docx_第3页
第3页 / 共12页
eclipse中Junit的配置.docx_第4页
第4页 / 共12页
eclipse中Junit的配置.docx_第5页
第5页 / 共12页
点击查看更多>>
下载资源
资源描述

eclipse中Junit的配置.docx

《eclipse中Junit的配置.docx》由会员分享,可在线阅读,更多相关《eclipse中Junit的配置.docx(12页珍藏版)》请在冰豆网上搜索。

eclipse中Junit的配置.docx

eclipse中Junit的配置

Eclipse中的JUnit环境配置实例

一、简介

   JUnit是一款由ErichGamma(《设计模式》的作者)和KentBeck(极限编程的提出者)编

写的开源的回归测试框架,供Java编码人员做单元测试之用。

当前版本4.1,可以从

www.junit.org网站上获得。

与早期的JUnit3相比,JUnit4.1依赖于Java5.0的新特性,因此

无法兼容于jdk1.4,可以说是一个全新的框架。

   由于这里使用的IDE是Eclipse3.2.1加语言包,已经集成了junit4.1,因此便免去下载和配置类

库的麻烦了^_^

二、创建项目

   下面打开Eclipse,点击菜单“文件”->“新建”->“项目”或“新建”按钮,打开“新建”对话框:

请选中“Java项目”,点击“下一步”,进入“新建Java项目”对话框:

在这个对话框中需要设置项目的名称以及项目所在目录,我为自己的项目起名为JUnitTest,目录为

F:

\YPJCCK\JUnit\Eclipse\JUnitTest。

由于Eclipse自带了JUnit类库,因此此时点击“完成”

即可。

三、编写用于测试的JavaBean

   用于测试的JavaBean很简单,名为Book,只有id和name两个属性,这两个属性将分别用于两

个用例当中。

下面开始编写该JavaBean。

   请点击“文件”->“新建”->“类”,打开“新建Java类”对话框,设置包为net.test.unit.junit,名称

为Book,并确保“publicstaticvoidmain(String[]args)”选项没有选中,然后点击“完成”。

修改代码如下:

packagenet.test.unit.junit;

   

publicclassBook{

   

       privateStringid=null;

       privateStringname=null;

   

       publicStringgetId(){

           returnid;

       }

   

       publicvoidsetId(Stringid){

           this.id=id;

       }

   

       publicStringgetName(){

           returnname;

       }

   

       publicvoidsetName(Stringname){

           this.name=name;

       }

   

}

至此,用于测试的JavaBean编写完成。

四、编写测试用例

   这里只用了一个类进行测试,名为BookTest。

以前像这样的类是需要继承

junit.framework.TestCase的,但由于JUnit4.1充分利用了Java5.0新增的注解功能,因此

便无须再这样做了。

当然,JUnit4.1仍然提供对旧方式的支持,不过这里并不打算介绍。

   BookTest类包含两个用例,分别对应该类的caseId和caseName方法,即每个方法实现一个

用例。

与JUnit3.8.1不同,在JUnit4.1中不再强制要求方法名以test开头,而是允许随意命名,

只要符合Java的命名规范就行,这里为了表明这点,特意用了case开头,但测试用例必须以@Test

注解。

此外,BookTest还有setUp和tearDown这两个方法,并分别使用@Before和@After来进

行注解,前者在每个测试方法开始之前执行,多用来做初始化;后者在每个测试方法完成之后执行,

多用来清理资源。

注意,这两个方法的命名同样没有限制,且定义的数量也没有限制,只是必须用

@Before和@After进行注解。

另外,JUnit4.1还提供了@BeforeClass和@AfterClass注解,功

能与@Before和@After类似,但前者是用在所有用例执行之前做初始化、之后做清理,而后者是在

每个用例执行之前做初始化、之后做清理。

下面开始编写BookTest。

   在Eclipse中,创建BookTest类有两种方法:

方法一,像前边创建Book类一样,点击“文件”->

“新建”->“类”来创建;方法二,先在“包资源管理器”中选中Book类,然后点击“文件”->“新建”->

“JUnit测试用例”,打开“新建JUint测试用例”窗口:

此时会发现,很多信息已经被Eclipse自动添加进来了。

如果想利用Eclipse自动创建测试方法,请

点击“下一步”。

由于本文会自行编写测试方法,因此请直接点击“完成”。

   创建BookTest类后,修改代码如下:

packagenet.test.unit.junit;

   

importstaticorg.junit.Assert.*;

   

importorg.junit.After;

importorg.junit.Before;

importorg.junit.Test;

   

publicclassBookTest{

   

       Bookbook=null;

   

       @Before

       publicvoidsetUp()throwsException{

           System.out.println("测试开始!

");

           book=newBook();

           System.out.println("book对象被初始化!

");

       }

   

       @After

       publicvoidtearDown()throwsException{

           System.out.println("book对象将被清理!

");

           book=null;

           System.out.println("测试结束!

");

       }

   

       @Test

       publicvoidcaseId(){

           book.setId("001");//设置id属性的值为001

           //使用Assert查看id属性的值是否为001

           assertEquals("001",book.getId());

           System.out.println("id属性被测试!

");

       }

   

       @Test

       publicvoidcaseName(){

           book.setName("ASP");//设置name属性的值为ASP

           //使用Assert查看name属性的值是否为JSP,这是个必然出现错误的测试

           assertEquals("JSP",book.getName());

           System.out.println("name属性被测试!

");

       }

       

}

这里setUp和tearDown方法没什么好说的,就是执行了对book对象的初始化和清理,不过

caseId和caseName需要说明一下。

前者是在对book的id属性进行测试,首先赋值为”001”,然

后使用assertEquals方法查看id属性中存放的值是否是期待的值,由于我的期待值也是”001”,所

以执行后这个用例应该是成功的;后者则是对book的name属性进行测试,也是首先赋值为”ASP”

,然后使用assertEquals方法查看其值是否是期待的,由于我特意将期待值设定为根本不可能的”

JSP”,因此这个用例执行后会出现一个错误。

关于assertEquals方法,是Assert类的一个静态方法。

在程序开头有这样一行代码,“import

staticorg.junit.Assert.*;”,利用了Java5.0提供的静态导入将Assert类静态导入,因此我们

在程序中可以直接使用Assert类的任何静态方法。

下面简单介绍一下静态类org.junit.Assert。

该类主要包含8类22个方法,如下:

   1.assertEquals(),8个重载,用来查看对象中存的值是否是期待的值,与字符串比较中使用的

equals()方法类似;

   2.assertFalse()和assertTrue(),各2个重载,用来查看变量是是否为false或true,如果

assertFalse()查看的变量的值是false则测试成功,如果是true则失败,assertTrue()与之相反;

   3.assertSame()和assertNotSame(),各2个重载,用来比较两个对象的引用是否相等和不

相等,类似于通过“==”和“!

=”比较两个对象;

   4.assertNull()和assertNotNull(),各2个重载,用来查看对象是否为空和不为空;

   5.fail(),2个重载,意为失败,用来抛出错误。

我个人认为有两个用途:

首先是在测试驱动开发

中,由于测试用例都是在被测试的类之前编写,而写成时又不清楚其正确与否,此时就可以使用fail方

法抛出错误进行模拟;其次是抛出意外的错误,比如要测试的内容是从数据库中读取的数据是否正确

,而导致错误的原因却是数据库连接失败。

五、运行BookTest

   编写好BookTest后,就可以运行了。

请点击运行按钮旁边的倒三角,选择“运行为”->“1JUnit

测试”,此时运行效果如下图:

在图片的左侧可以看到“JUnit”一栏,而且里边还有一个错误。

不过这个错误是预计之内的,如果不

想看到,可以将testName()方法中的”JSP”改成”ASP”,此时的运行效果如下图:

此时您会看到,“JUnit”栏中的进度条已不是红色,而是绿色的,这说明已经没有错误了。

六、测试套件

   当有多个测试类需要同时进行测试时,应使用测试套件来完成该工作。

但Eclipse3.2.1所提供的

测试套件创建功能无法很好地支持JUnit4.1,所以我们只能手工来创建了。

   点击“文件”->“新建”->“类”创建一个类,类名为AllTests,如下图:

点击“完成”,修改代码如下:

packagenet.test.unit.junit;

   

importorg.junit.runner.RunWith;

importorg.junit.runners.Suite;

   

@RunWith(Suite.class)

@Suite.SuiteClasses(BookTest.class)

publicclassAllTests{}

这里空类AllTests使用@RunWith和@Suite.SuiteClasses进行注解,以作为测试程序入口。

要测试的类BookTest作为@Suite.SuiteClasses注解的参数,然后将测试套件Suite作为参数设

置给运行器@RunWith。

下面就可以选中该文件,点击“运行为”->“1JUnit测试”了。

   这里注意一点,@Suite.SuiteClasses注解支持数组,例如:

       @Suite.SuiteClasses({BookTest.class,BookTest2.class})

这样就可以一次运行多个测试类了。

七、命令行下

   前边介绍的运行方式都是基于Eclipse的,其实JUnit自身也提供了办法,可以在命令行下执行如

下命令:

   java-cpjunit-4.1.jar所在文件夹;org.junit.runner.JUnitCore

net.test.unit.junit.AllTests

如果要运行多个测试类,如下:

   java-cpjunit-4.1.jar所在文件夹;org.junit.runner.JUnitCore

net.test.unit.junit.AllTestsnet.test.unit.BookTest

八、JUnit使用进阶

   @Ignore注解,忽略测试,用于忽略暂时不想运行的测试用例。

以BookTest为例,在文件头部

添加引用“importorg.junit.Ignore;”,然后修改caseName方法:

@Ignore

@Test

   publicvoidcaseName()

点击“运行为”->“1JUnit测试”,运行效果如下:

此时caseName()方法已经被忽略了。

   @Test注解的expected参数,异常测试,用于测试是否会抛出指定的异常,若抛出则为成功,反

之为失败。

请在BookTest中新增一个测试用例:

   @Test(expected=ArithmeticException.class)

   publicvoidcaseException(){

       intn=2/0;

   }

这个测试用例是以0为除数,运行效果如下:

成功!

因为指定的ArithmeticException异常被抛出了。

   @Test注解的timeout参数,限时测试,用于限定测试用例耗费的时间,单位毫秒,如果测试用例

没有在限定时间内完成则为失败,否则以测试用例的执行结果为准。

请在BookTest中新增一个测试

用例:

@Test(timeout=1000)

   publicvoidcaseWhile(){

       for(;;){

       }

}

这是一个死循环,1秒之后将被强制停止,运行效果如下:

由于超时,运行失败。

   @Parameters注解,参数化测试,用于对同一测试用例测试一组数据。

请新建一个“JUnit测试

用例”BookTest2,修改代码如下:

packagenet.test.unit.junit;

   

importstaticorg.junit.Assert.assertEquals;

   

importjava.util.Arrays;

importjava.util.Collection;

   

importorg.junit.After;

importorg.junit.Before;

importorg.junit.Test;

importorg.junit.runner.RunWith;

importorg.junit.runners.Parameterized;

importorg.junit.runners.Parameterized.Parameters;

   

@RunWith(Parameterized.class)

publicclassBookTest2{

   

       privateStringexpectedId;

       privateStringtargetId;

       privateStringexpectedName;

       privateStringtargetName;

   

       Bookbook=null;

   

       @Parameters

       publicstaticCollectionResult(){

           returnArrays.asList(newObject[][]{

               {"002","001","JSP","ASP"},

               {"001","001","ASP","ASP"}

               });

       }

   

       publicBookTest2(StringexpectedId,StringtargetId,StringexpectedName,

StringtargetName){

           this.expectedId=expectedId;

           this.targetId=targetId;

           this.expectedName=expectedName;

           this.targetName=targetName;

       }

   

       @Before

       publicvoidsetUp()throwsException{

           System.out.println("测试开始!

");

            book=newBook();

            System.out.println("book对象被初始化!

");

       }

   

       @After

       publicvoidtearDown()throwsException{

           System.out.println("book对象将被清理!

");

            book=null;

            System.out.println("测试结束!

");

       }

   

       @Test

       publicvoidcaseId(){

           book.setId(targetId);//设置id属性的值

            //使用Assert查看id属性的值

            assertEquals(expectedId,book.getId());

            System.out.println("id属性被测试!

");

       }

   

       @Test

       publicvoidcaseNames(){

           book.setName(targetName);//设置name属性的值

            //使用Assert查看name属性的值

            assertEquals(expectedName,book.getName());

            System.out.println("name属性被测试!

");

       }

}

这个例子其实就是BookTest的扩展版,但在原基础上有几点变化:

首先是文件头部增加了一行代码:

@RunWith(Parameterized.class),用来调用BookTest2类

运行;

其次是定义了一个用@Parameters注解的Result静态方法,该方法用来存放测试数据,本例存放了

2组数据,每组4个;

再次是定义了一个带参数的构造函数,其参数个数与每组测试数据的个数相等;

   最后是定义了expectedId等4个成员变量,用来传递测试数据到测试用例中。

下面执行BookTest2,运行效果如下:

测试用例运行了两遍,第一遍由于期待值和设定值不相等而失败,第二遍则运行成功。

   junit.framework.JUnit4TestAdapter类。

依赖于Java5.0新特性,开发测试用例无需继承

junit.framework.TestCase的JUnit4.1已经推出一段时间了,但有些自带JUnit测试环境的

IDE,例如NetBeans5.5甚至旧版Eclipse仍只支持JUnit3,无法正确运行基于JUnit4.1环境

开发的测试用例,因此要解决这个问题,需要借助于junit.framework.JUnit4TestAdapter类。

新建类TestSuite,修改代码如下:

packagenet.test.unit.junit;

   

publicclassTestSuite{

   

       publicstaticvoidmain(String[]args){

           junit.textui.TestRunner.run(TestSuite.suite());

       }

   

       publicstaticjunit.framework.Testsuite(){

           returnnewjunit.framework.JUnit4TestAdapter(AllTests.class);   

       }

}

其中最重要的是suite方法,该方法通过junit.framework.JUnit4TestAdapter类使基于JUnit

4环境创建的AllTests类能够运行于JUnit3命令行环境下。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 研究生入学考试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1