0


Jmockit使用笔记_基本功能使用@Tested_@Injectable_@Mocked_Expectations

Jmockit使用笔记

测试框架Jmockit集合junit使用

@RunWith(JMockit.class)

写在测试案例类上的注解

@Tested

在测试案例中,写在我们要测试的类上面, 一般用实现类

@Injectable

在测试案例中声明那些我们要测试的类中通过@Autowired注入的类

代码展示如下:

/**
 * @author: xinruoxiangyang9010
 * 我们要测试的业务代码
 */@ServicepublicclassMyServicemplimplementsMyService{@AutowiredprivateMyMapper myMapper;@OverridepublicStringtestMethod(){return"myService";}}
/**
 * @author: xinruoxiangyang9010
 * 测试案例
 */@RunWith(JMockit.class)publicclassMyServicemplTest{@InjectableprivateMyMapper myMapper;@TestedprivateMyServicempl myServicempl;@TestpublicvoidtestMethod(){String result = myServicempl.testMethod();assertEquals("myService", result);}}

如果测试类中忘了用@Injectable修饰被测试代码中所有的注入对象时, 哪怕遗漏了一个, 就会有如下报错信息:

java.lang.IllegalStateException:Missing@Injectablefor field "xxx.xxx.xxx.MyMapper myMapper" in MyServicempl

@Mocked

与@Injectable类似都是在mock对象(这里的mock是指模拟的意思), 但又有区别, @Injectable只会影响被修改的那一个对象, 但是@Mocked 会影响所他所修饰的对象及其子类, 哪怕这个对象时你new出来的; 调用mock对象的方法时不会调用原代码, 会交给JMockit处理, 均返回默认值(int,short,double等返回0,String返回null)

@MockedprivateUser user;

Expectations

字面解释预期,就是指定方法在调用时,返回我们想要的结果(当然有时候结果要我们自己提前准备好)

指定代码中使用的工具类返回我们想要的值

/**
 * @author: xinruoxiangyang9010
 * 业务代码
 */publicclassMyStringUtil{publicstaticStringgetUUID(){return"id_1";}publicstaticStringgetUUID2(){return"id_2";}}
/**
 * @author: xinruoxiangyang9010
 * 测试案例
 */@RunWith(JMockit.class)publicclassMyStringUtilTest{@TestpublicvoidgetUUID(){newExpectations(MyStringUtil.class){{MyStringUtil.getUUID();
                result ="123";}};String resultString =MyStringUtil.getUUID();assertEquals("123", resultString);}}

注意:

第一点 new Expectations(MyStringUtil.class) 这里要把MyStringUtil.class作为参数传进去

第二点 如果Expectations中写的方法, 实际却没有被调用,则测试案例会出现如下错误

@TestpublicvoidgetUUID_test2(){newExpectations(MyStringUtil.class){{MyStringUtil.getUUID();
            result ="123";MyStringUtil.getUUID2();
            result ="222";}};String resultString =MyStringUtil.getUUID();assertEquals("123", resultString);}
Missing 1 invocation to:
xin.ruo.xiang.yang.jmockit.MyStringUtil#getUUID2()
Caused by: Missing invocations
    at xin.ruo.xiang.yang.jmockit.MyStringUtil.getUUID2(MyStringUtil.java)
    at xin.ruo.xiang.yang.jmockit.MyStringUtilTest$2.<init>(MyStringUtilTest.java:35)
    at xin.ruo.xiang.yang.jmockit.MyStringUtilTest.getUUID_test2(MyStringUtilTest.java:31)

在Expectations中指定某个方法被调用多次,返回不同结果

@TestpublicvoidgetUUID_test3(){newExpectations(MyStringUtil.class){{MyStringUtil.getUUID();
                result ="111";
                result ="222";
                result ="333";}};String resultString =MyStringUtil.getUUID();assertEquals("111", resultString);String resultString2 =MyStringUtil.getUUID();assertEquals("222", resultString2);String resultString3 =MyStringUtil.getUUID();assertEquals("333", resultString3);}

这里结合Expectations的使用对@Mocked与@Injectable的不同再进行一下解释

/**
 * @author: xinruoxiangyang9010
 * 业务代码
 */publicclassDiffServiceImplimplementsDiffService{publicStringmethod(){return"real";}}
/**
 * @author: xinruoxiangyang9010
 * 测试案例
 */@RunWith(JMockit.class)publicclassMockAndInjectTest{@TestpublicvoidtestMock(@MockedDiffServiceImpl diffService){newExpectations(){{
                diffService.method();
                result ="mockMethod";}};assertEquals("mockMethod", diffService.method());// @Mocked修饰的变量,即便是再new出来的,也会按照上面我们mock的结果返回assertEquals("mockMethod",newDiffServiceImpl().method());}@Testpublicvoid testInjectable (@InjectableDiffServiceImpl diffService){newExpectations(){{
                diffService.method();
                result ="mockMethod";}};assertEquals("mockMethod", diffService.method());// 注意这里结果的不同, 在对@Injectable修饰的对象进行Expectations指定结果时// 受影响的只是被修饰的对象,如果我们new一个示例出来,是不会受Expectations影响的assertEquals("real",newDiffServiceImpl().method());}}
标签: java junit 单元测试

本文转载自: https://blog.csdn.net/Java_XiaoBei/article/details/126150129
版权归原作者 心。若向阳9010 所有, 如有侵权,请联系我们删除。

“Jmockit使用笔记_基本功能使用@Tested_@Injectable_@Mocked_Expectations”的评论:

还没有评论