在之前的版本中,Junit在设计上并没有指定测试方法的执行顺序,方法的调用就是根据reflection api的返回顺序。鉴于Java平台并没有规定一个特定的顺序,甚至其返回的顺序有一定的随机性,依赖于JVM的顺序非常的不明智。
当然,编写良好的测试用例是不应该依赖于测试方法的执行顺序的。但万一存在这样的情况呢?这个时候“确定顺序”带来的可预测的测试失败总是好过随机的测试失败。
从4.11版本开始,Junit将默认使用一种确定性的顺序,也即MethodSorters.DEFAULT。如果想改变测试方法的执行顺序可以为测试用例添加FixMethodOrder注解,并且指定其方法的排序类型,可选的MethodSorters有:
- DEFAULT,根据方法名称的hashCode进行比较;
- NAME_ASCENDING,根据方法名称进行比较;
- JVM,使用JVM返回的顺序。
示例(官网的,其实无需示例):
- @FixMethodOrder(MethodSorters.NAME_ASCENDING)
- public class TestMethodOrder {
- @Test
- public void testA() {
- System.out.println("first");
- }
- @Test
- public void testB() {
- System.out.println("second");
- }
- @Test
- public void testC() {
- System.out.println("third");
- }
- }