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

junit3与junit4的区别(转载)

 
阅读更多

Junit4最大的亮点就是引入了注解(annotation),通过解析注解就可以为测试提供相应的信息,抛弃junit3使用命名约束以及反射机制的方法。

/**

 * 被测试类

 */

package com.stock.finance.service;

 

import java.util.List;

import java.util.zip.DataFormatException;

import com.stock.finance.db.dao.TableCompanyDAO;

import com.stock.finance.db.model.TableCompany;

 

/**

*

 */

public class CompanyService {

    private TableCompanyDAO dao = new TableCompanyDAO();

   

    public CompanyService(){

    }

    /**

     * @param code

     * @param name

     * @param masterBusiness

     */

    public void insert(String code,String name,String masterBusiness){

        TableCompany company = new TableCompany(code, name);

        company.setMasterBusiness(masterBusiness);

        insert(company);

    }

    /**

     * @param company

     */

    public void insert(TableCompany company){

        dao.save(company);

    }

    /**

     * @return

     */

    public int companyNum(){

        List<?> list = dao.findAll();

        return list.size();

    }

   

    public void justForDisplay() throws DataFormatException{

        throw new DataFormatException();

    }

}

/**

 * junit3测试类

 */

package test.com.stock.finance.service;

import java.util.zip.DataFormatException;

import com.stock.finance.service.CompanyService;

import junit.framework.TestCase;

/**

 */

public class Tester3 extends TestCase {

         private CompanyService service = new CompanyService();

         protected void setUp() throws Exception {

                   super.setUp();

         }

         protected void tearDown() throws Exception {

                   super.tearDown();

         }

         public final void testInsertStringStringString() {

                   fail("Not yet implemented"); // TODO

         }

         public final void testInsertTableCompany() {

                   fail("Not yet implemented"); // TODO

         }

         public final void testCompanyNum() {

                   fail("Not yet implemented"); // TODO

         }

         public final void testJustForDisplay() {

                   try {

                            service.justForDisplay();

                   } catch (DataFormatException e) {

                            assertTrue("捕获异常正确", true);

                   }

         }

}

/**

 * junit4测试类

 */

package test.com.stock.finance.service;

//静态引用

import static org.junit.Assert.*;

 

import java.util.zip.DataFormatException;

 

import org.junit.After;

import org.junit.AfterClass;

import org.junit.Before;

import org.junit.BeforeClass;

import org.junit.Ignore;

import org.junit.Test;

 

import com.stock.finance.service.CompanyService;

 

/**

*

 */

public class Tester4 {

         private CompanyService service = new CompanyService();

         /**

          * @throws java.lang.Exception

          */

         @BeforeClass

         public static void setUpBeforeClass() throws Exception {

         }

         /**

          * @throws java.lang.Exception

          */

         @AfterClass

         public static void tearDownAfterClass() throws Exception {

         }

         /**

          * @throws java.lang.Exception

          */

         @Before

         public void setUp() throws Exception {

         }

         /**

          * @throws java.lang.Exception

          */

         @After

         public void tearDown() throws Exception {

         }

         @Test

         @Ignore

         public final void testInsertStringStringString() {

//               fail("Not yet implemented"); // TODO

         }

         @Test(timeout = 1000)

         public final void testInsertTableCompany() {

//               fail("Not yet implemented"); // TODO

         }

         @Test

         public final void testCompanyNum() {

                   fail("Not yet implemented"); // TODO

         }

         @Test(expected = DataFormatException.class)

         public final void testJustForDisplay() throws DataFormatException {

                   service.justForDisplay();

         }

}

junit3junit4的使用区别如下
1.JUnit3中需要继承TestCase类,但在JUnit4中已经不需要继承TestCase
2.JUnit3中需要覆盖TestCase中的setUptearDown方法,其中setUp方法会在测试执行前被调用以完成初始化工作,而tearDown方法则在结束测试结果时被调用,用于释放测试使用中的资源,而在JUnit4中,只需要在方法前加上@Before
@After 
3.JUnit3中对某个方法进行测试时,测试方法的命令是固定的,例如对addBook这个方法进行测试,需要编写名字为tetAddBook的测试方法,而在JUnit4中没有方法命令的约束,在方法的前面加上@Test,这就代表这个方法是测试用例中的测试方法

4.新的断言assertThat 
5. @BeforeClass  @AfterClass 。在JUnit3,如果所有的test case仅调用一次setUp()tearDown()需要使用TestSetup
6.测试异常处理@Test(expected = DataFormatException.class)
7.设置超时
@Test(timeout = 1000)
8.忽略测试
@Ignore
9.集成测试

 

 

集成测试

    利用TestSuite可以将一个TestCase子类中所有test***()方法包含进来一起运行,还可将TestSuite子类也包含进来,从而行成了一种等级关系。可以把TestSuite视为一个容器,可以盛放TestCase中的test***()方法,它自己也可以嵌套。这种体系架构,非常类似于现实中程序一步步开发一步步集成的现况。

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

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

例如:

### JUnit-3.8.1结构:

import junit.framework.Test;

import junit.framework.TestSuite;

public class TestAll{

    //定义一个suite,对于junit的作用可以视为类似于java应用程序的main

    public static Test suite(){

        TestSuite suite = new TestSuite("Running all tests.");

        suite.addTestSuite( TestCase1.class);

        suite.addTestSuite( TestCase2.class);

        return suite;

    }

}

### JUnit-4.X结构:

import org.junit.runner.RunWith;

import org.junit.runners.Suite;

@RunWith(Suite.class)

@Suite.SuiteClasses({ TestCase1.class, TestCase2.class })

public class AllCalculatorTests {

 

}

//代码示例:在junit3中如何通过执行多个测试方法,却只执行一次setUptearDown方法

import junit.framework.*;
import junit.extensions.TestSetup;
public class AllTestsOneTimeSetup {
    
public static Test suite() {
        TestSuite suite = 
new TestSuite();
        suite.addTest(SomeTest.suite());
        suite.addTest(AnotherTest.suite());
        TestSetup wrapper = 
new TestSetup(suite) {
            
protected void setUp() {
                oneTimeSetUp();
            }
            
protected void tearDown() {
                oneTimeTearDown();
            }
        };
        
return wrapper;
    }
    
public static void oneTimeSetUp() {
        
// one-time initialization code
    }
    
public static void oneTimeTearDown() {
        
// one-time cleanup code
    }
}

 

我个人认为, JUnit4最大的特点是引入了Java5的注释Annotation。
1. @Test
    在JUnit3,所有的test case的方法名都要以"test"为前缀prefix;
    在JUnit4,在test case的方法前加上@Test,就明白了。
@Test 
public void empty() {         
        /* test case 1*/          
        Collection collection = new ArrarList();         
        assertTrue(collection.isEmpty());         
}
 
2. @Before 和 @After
    @Before 和 @After 就是setUp()和tearDown()的替代。
@Before     
public void runBeforeEveryTest() {        
        simpleMath = new SimpleMath();        
}        
     
@After     
public void runAfterEveryTest() {        
        simpleMath = null ;        
}
 
3. @BeforeClass 和 @AfterClass
    在JUnit3,如果想仅调用一次setUp()和tearDown()  for  all test cases, 使用TestSetup类;在JUnit4,就省事了:
@BeforeClass     
public static void runBeforeClass() {        
        // run for one time before all test cases         
}        
     
@AfterClass     
public static void runAfterClass() {        
        // run for one time after all test cases         
}
 
4. 测试异常处理
    在《JUnit3的使用 》文章中,看到旧式的异常测试是在抛出异常的代码中放入 try 块,然后在 try 块的末尾加入一个 fail() 语句:
public void testCase2() {         
        /* test case 2*/          
        ArrayList emptyList = new ArrayList();    
        try {    
                Object o = emptyList.get(0);    
                fail("Should raise an IndexOutOfBoundsException" );    
        } catch (IndexOutOfBoundsException expected) {    
                assertTrue(true );    
        }    
}
     在JUnit4,添加@Test,使用参数“expected”,并指明抛出异常的Exception类:
@Test(expected = IndexOutOfBoundsException.class ) 
public void testCase2() {         
        /* test case 2*/          
        ArrayList emptyList = new ArrayList();    
        Object o = emptyList.get(0);    
}
 
5. @Ignore
     对于你想暂时不进行的test cse, 在该方法前添加@Ignore
@Ignore("Not Ready to Run" )        
@Test     
public void multiplication() {        
        assertEquals(15, simpleMath.multiply(3, 5));        
}
 
6. 设置超时
    在@Test,使用"timeout"参数。如果测试运行的时间超过指定的毫秒数,则测试失败。
@Test(timeout=3000) 
public void remoteBaseRelativeResolutionWithDirectory()    
 throws IOException, ParsingException { 
  readBuilder.parse("config.xml" );    
}
 
7.添加了新的断言
      JUnit 4 为比较数组添加了两个 assert() 方法:
  public static void assertEquals(Object[] expected, Object[] actual)
      public static void assertEquals(String message, Object[] expected, Object[] actual)
  这两个方法以最直接的方式比较数组:如果数组长度相同,且每个对应的元素相同,则两个数组相等,否则不相等。数组为空的情况也作了考虑。
@Test     
public void listEquality() {        
        List<Integer> expected = new ArrayList<Integer>();        
        expected.add(5);        
     
        List<Integer> actual = new ArrayList<Integer>();        
        actual.add(5);        
     
        assertEquals(expected, actual);        
}
 
8. JUnit4Adapter
     为了能够在JUnit3环境下run JUnit4  test, 所以提供了JUnit4Adapter
public static junit.framework.Test suite() {        
        return new JUnit4TestAdapter(SimpleMathTest.class );        
}
 
9.其他
 失败(assert 方法检测到的预期的错误)与错误(异常指出的非预期的错误)之间不再有任何差别。尽管 JUnit 3 测试运行程序仍然可以区别这些情况,而 JUnit 4 运行程序将不再能够区分。

二、运行原理:

JUnit运行时都是由一个runner运行的。你可以根据需要选择不同的Runner来运行你的测试代码。指定一个Runner,需要使用@RunWith标注,并且把你所指定的Runner作为参数传递给它。系统自动使用默认Runner TestClassRunner 来运行你的代码。如下:

@RunWith (TestClassRunner.class)

public class JavaTest { …… }

 

JUnit4提出了"参数化测试 "的概念,只写一个测试函数,把这若干种情况作为参数传递进去,一次性的完成测试。代码如下:

 

@RunWith(Parameterized.class)
public class JavaTest {
private int param;
private int param2;
private int result;

 @Parameters public static Collection data() {
return Arrays.asList(new Object[][]{ { 2, 4, 6 }, { 0, 0, 0 }, { -3, 9, 6 } });
}

 // 构造函数,对变量进行初始化
public JavaTest(int param, int param2, int result) {
this.param = param;
this.param2 = param2;
this.result = result;
}

@Test public void run() {
//do some thing use args, and assert it
int expected = param + param2;
assertEquals(expected, result);
}
@Ignore("lala") public void lala() {
assertEquals(3,3);
}
} 


首先,你要为这种测试专门生成一个新的类,为这个类指定一个Runner,特殊的功能要用特殊的Runner:@RunWith(Parameterized.class) 
第二步,定义测试数据的集合,也就是上述的data()方法,该方法可以任意命名,但是必须使用@Parameters标注进行修饰。这是一个二维数组,每组数据产生一个测试Instance.
第三步,构造函数,取得传过来的参数。
最后,用取得的参数做测试。@Test public void …

 

三、打包测试:

采取分而治之的方法,我们可以写多个类来降低测试难度。我们有时也希望一次把所有测试跑一遍,这时我们写一个打包类

import junit.framework.JUnit4TestAdapter;
import org.junit.runner.RunWith;
import org.junit.runners.Suite;

 

@RunWith(Suite.class)
@Suite.SuiteClasses({
JavaTest.class,
JustDo.class
})
public class TestAll {
}

 

四、多线程测试

      JUnit4的Test写好以后,对于一些集成度比较高的测试用例,还希望完成并发访问情况下的测试,但是,JUnit4缺省情况没有提供,我希望通过自 己写一个main函数,然后创建几个线程,在几个线程中同时运行测试用例进行测试,来模拟并发访问的情况,下里为具体例子:

public class TestExample {

@Test
public void testMethod() {
System.out.println("test success!");
}
}

public class PerfomanceTest {

public static void main(String[] args) {
new Thread() {public void run() {
 
// JUnitCore.runClasses(new Class[] { TestExample .class });            (1) 
// new JUnitCore().run(Request.method(TestExample .class, "testMethod "));        (2) 
}}.start();
}
}
 
注:标志1或标志2中只要用一种就可以测试。

到这里,我们就可以使用JUnit4来开发我们自己的测试了。

编译和运行JUnit 
在JUnit3中提供了三种运行界面:
TestUI:Provides text-based output to stdout
AwtUI: Provides GUI-based output using the AWT(Abstract Window Toolkit)from Java
SwingUI: Provides GUI-based output using the Swing graphical user interface component kit from Java.

设置好环境变量后,在命令行运行:
java junit.USERINTERFACE.TestRunner classfile

例如:
java junit.testui.TestRunner BaseClassTest

在JUnit4中,只有标准输出界面,使用org.junit.runner.JUnitCore类来运行:
java org.junit.runner.JUnieCore BaseClassTest

分享到:
评论

相关推荐

    JUnit 5.pdf

    JUnit Platform负责在JVM上启动测试框架,JUnit Jupiter包含新的编程和扩展模型,JUnit Vintage则提供了运行基于JUnit 3和JUnit 4的测试的能力。 JUnit 5在依赖管理方面提供了元数据和依赖关系图,旨在帮助开发者更...

    Java Unit Testing with JUnit 5 epub

    Java Unit Testing with JUnit 5 英文epub 本资源转载自网络,如有侵权,请联系上传者或csdn删除 查看此书详细信息请在美国亚马逊官网搜索此书

    Mastering Software Testing with JUnit 5_Code 源码

    Mastering Software Testing with JUnit 5_Code 源码 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除

    Pragmatic Unit Testing in Java 8 with JUnit epub

    Pragmatic Unit Testing in Java 8 with JUnit 英文epub 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除

    Mastering Software Testing with JUnit 5 无水印pdf转化版

    Mastering Software Testing with JUnit 5 英文无水印pdf pdf所有页面使用FoxitReader和PDF-XChangeViewer测试都可以打开 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,...

    Pragmatic Unit Testing in Java 8 with JUnit 无水印pdf

    Pragmatic Unit Testing in Java 8 with JUnit 英文无水印pdf pdf所有页面使用FoxitReader和PDF-XChangeViewer测试都可以打开 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有...

    lunwenxiangguan

    导入这些jar包之后,问题游刃而解,是的,我承认自己也是JUnit新手吐舌头。 至于JUnit的jar包和hamcrest的jar包关系,下边我引用一位网友的几段话来解释解释: junit和hamcrest是两个不同的框架,不同的东西。只...

    Ruby Recipes A Problem-Solution Approach epub

    Ruby Recipes A Problem-Solution Approach 英文epub 本资源转载自网络,如有侵权,请联系上传者或csdn删除 查看此书详细信息请在美国亚马逊官网搜索此书

    软件测试基本方法(转载)

    源码级的单元测试可以帮助开发者快速定位和修复代码中的问题,常见的单元测试工具有JUnit(Java)、pytest(Python)和NUnit(.NET)等。 2. 集成测试:当多个单元组合在一起时,集成测试用于检查它们之间的交互和...

    JBPM的开发指南,转载过来的

    ### 3. **开发流程** #### 3.1 配置环境 首先,你需要安装Java开发环境(JDK)和Maven,然后配置JBPM的依赖库到项目中。 #### 3.2 创建流程定义 使用BPMN编辑器创建流程图,保存为`.bpmn2`文件。 #### 3.3 编写...

    [转载]Selenium2.0之WebDriver学习总结(3).docx

    在本文中,我们将深入探讨Selenium 2.0中的WebDriver,这是一个强大的自动化测试工具,用于模拟用户与网页的交互。我们将通过一个实际的登录网易相册、创建相册、发表评论并删除相册的示例,来展示WebDriver的各种...

    <转载>ThinkAndroid

    7. **测试支持**:为了保证代码质量,ThinkAndroid提供了单元测试和集成测试的工具和指导,如JUnit、Mockito和Espresso等,有助于开发者编写可验证的代码。 8. **工具集**:除了上述核心功能,ThinkAndroid还包含了...

    本项目是基于SpringBoot的线上宠物物资购买系统,为个人毕业设计,未经允许禁止转载.zip

    9. **单元测试与集成测试**:为了保证代码质量,项目中可能会包含JUnit或Spock等单元测试框架的测试用例,以及Spring Boot的Test Slice特性进行集成测试。 10. **持续集成/持续部署(CI/CD)**:开发者可能利用...

    JAVA OA平台源码(转载)SPRING BOOT....

    【标题】:“JAVA OA平台源码(转载)SPRING BOOT...” 这个开源项目是一个基于Java技术的OA(Office Automation)管理系统的源代码实现,利用了Spring Boot框架进行开发。Spring Boot是Spring生态中的一个核心组件...

    webwork教程webwork教程webwork教程

    3. 创建一个简单的`HelloWorld`Action,这个Action是WebWork中的核心组件,用于处理用户请求并执行相应的业务逻辑。 4. 编写视图,如JSP页面,来显示Action返回的结果。 **Action(动作)** Action是WebWork中的...

    抽奖软件java

    1. **GUI(图形用户界面)**:Java中的GUI是通过Java Swing或JavaFX库实现的,用于创建可视化组件,如按钮、文本框和面板等,使用户与程序进行交互。在这个抽奖软件中,可能包含启动界面、设置界面、抽奖结果展示...

    IBE-master

    描述提到该实现是“转载自联合开发网”,这意味着可能有一个社区或平台提供了这个开源项目,供开发者学习和使用。这个Java实现提供了对IBE算法的具体代码实现,有助于开发者理解IBE的工作原理,并可以将其集成到自己...

    高仿点评的android应用

    【描述】提到,这个应用是基于Android平台构建的,并且所有数据都在本地,这意味着它没有与远程服务器进行交互来获取或更新信息。这种设计可能使用SQLite数据库存储用户评价、商家信息等,或者使用文件系统存储静态...

    6_安卓学生管理源码_

    【描述分析】:“自己试试吧挺棒的安卓学生管理开发了很长时间转载的别的地方的”这句话指出该源码已经经过长时间的开发,并且质量良好,可能具有较高的可用性和稳定性。同时,这表明源码并非原创,而是从其他来源...

    设计模式 观察者 发布/订阅 Observer

    转载请注明出处,此系列的例子都是本人想了很久认为适合教学容易理解的,若有更好的例子也请发邮件给我一起研究,nj.lg#163.com Observer (观察者模式) 又叫做发布/订阅(Publish/Subscribe)模式。 当一个对象的...

Global site tag (gtag.js) - Google Analytics