JUnit4中@AfterClass @BeforeClass @after @before的区别对比

JUnit4使用Java5中的注解(annotation),以下是JUnit4常用的几个annotation: 
@Before:初始化方法   对于每一个测试方法都要执行一次(注意与BeforeClass区别,后者是对于所有方法执行一次)
@After:释放资源  对于每一个测试方法都要执行一次(注意与AfterClass区别,后者是对于所有方法执行一次)
@Test:测试方法,在这里可以测试期望异常和超时时间 
@Test(expected=ArithmeticException.class)检查被测方法是否抛出ArithmeticException异常 
@Ignore:忽略的测试方法 
@BeforeClass:针对所有测试,只执行一次,且必须为static void 
@AfterClass:针对所有测试,只执行一次,且必须为static void 
一个JUnit4的单元测试用例执行顺序为:
@BeforeClass -> @Before -> @Test -> @After -> @AfterClass; 
每一个测试方法的调用顺序为:

@Before -> @Test -> @After;

package mypack.Condition;

import static org.junit.Assert.*;

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;

public class JUnit4Test {

	    @Before    
	    public void before() {     
	        System.out.println("@Before");     
	    }     
	    @Test    
	         /**   
	          *Mark your test cases with @Test annotations.    
	          *You don’t need to prefix your test cases with “test”.   
	          *tested class does not need to extend from “TestCase” class.   
	          */    
	    public void test() {     
	        System.out.println("@Test");     
	        assertEquals(5 + 5, 10);     
	    }     
	    @Ignore    
	    @Test    
	    public void testIgnore() {     
	        System.out.println("@Ignore");     
	    }     
	    @Test(timeout = 50)     
	    public void testTimeout() {     
	        System.out.println("@Test(timeout = 50)");     
	        assertEquals(5 + 5, 10);     
	    }     
	    @Test(expected = ArithmeticException.class)     
	    public void testExpected() {     
	        System.out.println("@Test(expected = Exception.class)");     
	        throw new ArithmeticException();     
	    }     
	    @After    
	    public void after() {     
	        System.out.println("@After");     
	    }     
	    @BeforeClass    
	    public static void beforeClass() {     
	        System.out.println("@BeforeClass");     
	    }      
	    @AfterClass    
	    public static void afterClass() {     
	        System.out.println("@AfterClass");     
	    }
}
输出结果:

@BeforeClass
@Before
@Test(timeout = 50)
@After
@Before
@Test(expected = Exception.class)
@After
@Before
@Test
@After
@AfterClass

三.@BeforeClass、@AfterClass与@Before、@After的对比:

@BeforeClass and @AfterClass @Before and @After
在一个类中只可以出现一次

在一个类中可以出现多次,即可以在多个方法的声明前加上这两个Annotaion标签,执行顺序不确定

方法名不做限制 方法名不做限制
在类中只运行一次 在每个测试方法之前或者之后都会运行一次

@BeforeClass父类中标识了该Annotation的方法将会先于当前类中标识了该Annotation的方法执行。
@AfterClass 父类中标识了该Annotation的方法将会在当前类中标识了该Annotation的方法之后执行

@Before父类中标识了该Annotation的方法将会先于当前类中标识了该Annotation的方法执行。
 @After父类中标识了该Annotation的方法将会在当前类中标识了该Annotation的方法之后执行
必须声明为public static 必须声明为public 并且非static
所有标识为@AfterClass的方法都一定会被执行,即使在标识为@BeforeClass的方法抛出异常的的情况下也一样会。 所有标识为@After 的方法都一定会被执行,即使在标识为 @Before 或者 @Test 的方法抛出异常的的情况下也一样会。

        特别说明:

        1.@BeforeClass 和 @AfterClass 对于那些比较“昂贵”的资源的分配或者释放来说是很有效的,因为他们只会在类中被执行一次。相比之下对于那些需要在每次运行之前都要初始化或者在运行之后 都需要被清理的资源来说使用@Before和@After同样是一个比较明智的选择;

        2.如果类里面可以有多个注解过@Before和@After的方法,它们的执行顺序是未知的;

        3.@BeforeClass  @AfterClass注解是junit提供的另外的两个注解,必须设置在public 静态方法之上,表示在class加载之前执行,这样设置的方法只会执行一次,而@Before @After则会再每次test之前/之后执行;

        4.在JUnit4中,如果测试类继承了TestCase类,那么所有的Annotation都不会起作用。




©️2020 CSDN 皮肤主题: 大白 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值