2018/09/30补记:感谢评论的指正,@FixMethodOrder
的顺序也并不一定是方法在代码中定义的顺序,这与JVM的实现有关,我猜在class中方法名是保存在一个map中,不同JVM对map的实现不同,导致并不一定是按代码定义顺序的。
我们在写JUnit测试用例时,有时候需要按照定义顺序执行我们的单元测试方法,比如如在测试数据库相关的用例时候要按照测试插入、查询、删除的顺序测试。如果不按照这个顺序测试可能会出现问题,比如删除方法在前面执行,后面的方法就都不能通过测试,因为数据已经被清空了。而JUnit测试时默认的顺序是随机的。所以这时就需要有办法要求JUnit在执行测试方法时按照我们指定的顺序来执行。
JUnit是通过@FixMethodOrder
注解(annotation)来控制测试方法的执行顺序的。@FixMethodOrder
注解的参数是org.junit.runners.MethodSorters
对象,在枚举类org.junit.runners.MethodSorters
中定义了如下三种顺序类型:
- MethodSorters.JVM
Leaves the test methods in the order returned by the JVM. Note that the order from the JVM may vary from run to run (按照JVM得到的方法顺序,也就是代码中定义的方法顺序)
- MethodSorters.DEFAULT(默认的顺序)
Sorts the test methods in a deterministic, but not predictable, order() (以确定但不可预期的顺序执行)
- MethodSorters.NAME_ASCENDING
Sorts the test methods by the method name, in lexicographic order, with Method.toString() used as a tiebreaker (按方法名字母顺序执行)
举例说明
以下的代码,定义了三个方法testAddAndGet,testSearch,testRemove
,我设计的时候,是希望三个方法按定义的顺序来执行。
package test;
import org.junit.Assert;
import org.junit.FixMethodOrder;
import org.junit.runners.MethodSorters;
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@FixMethodOrder(MethodSorters.JVM)//指定测试方法按定义的顺序执行
public class TestJNI {
private static final Logger logger = LoggerFactory.getLogger(TestJNI.class);
@Test
public void testAddAndGet(){
logger.info("test 'addBean' and 'getBean' ");
}
@Test
public final void testSearch() {
logger.info("test search CODE from JNI memory...");
}
@Test
public final void testRemove() {
logger.info("test remove CODE from JNI memory...");
}
}
如果@FixMethodOrder
定义为MethodSorters.DEFAULT
或去掉代码中的@FixMethodOrder注解,那么测试用便执行的顺序是
这并不是我要的结果,testRemove
如果先执行了,testSearch
肯定什么也找不到。
如果改成@FixMethodOrder(MethodSorters.JVM)
,则这个执行顺序才是我想要的顺序。