Java单测void类型的方法详解

网友投稿 344 2023-06-19


Java单测void类型的方法详解

前言

Java的Sevice层会有很多void类型的方法,比如save*、update*,这类方法只是做一些更新,不会有返回值,其单测不能根据方法的返回值来编写,只能采用特殊方法;

本方法环境:MocksWMXnNito、testng

被测试的方法:

想要被测试的VOID方法Java

@Override

public void updateRuleName(Long ruleId, String newRuleName, Long ucId) {

Assert.notNull(ruleId, "规则ID不能为Null");

Assert.notNull(newRuleName, "规则名称不能为Null");

Assert.notNull(ucId, "操作人的UCID不能为Null");

String cleanNewRuleName = StringUtils.trim(newRuleName);

if (StringUtils.isBlank(cleanNewRuleName)) {

throw new IllegalArgumentException("新的规则名称不能为空");

}

// 查询规则对象

Rule rule = queryRuleById(ruleId);

if (null == rule) {

throw new IllegalDataException("没有查到该规则");

}

rule.setRuleId(ruleId);

rule.setRuleName(cleanNewRuleName);

rule.setUpdateUcid(ucId);

rule.setUpdateTime(new Date());

ruleDao.updateSelective(rule);

}

测试的方法:

void返回的方法测试Java

@Test

public void testUpdateRuleName() {

Long ruleId = 1L;

String newRuleName = "newRuleName";

Long ucId = 123L;

List rules = new ArrayList();

Rule rule = new Rule();

rule.setRuleStatus((byte) DBValueSetting.RULE_STATUS_TAKE_EFFECT);

rules.add(rule);

// 查询规则对象

Map params = new HashMap();

params.put("ruleId", ruleId);

Mockito.when(ruleDao.queryRulesByCondition(params)).thenReturn(rules);

Mockito.doAnswer(new Answer() {

public Object answer(InvocationOnMock invocation) {

// 断点2:这里随后执行

Rule rule = (Rule) invocation.getArguments()[0];

Assert.assertTrue(rule.getRuleName().equals("newRuleName"));

return null;

}

}).when(ruleDao).updateSelective(Mockito.any(Rule.class));

// 断点1:先执行到这里

ruleService.updateRuleName(ruleId, newRuleName, ucId);

}

如注释所示,如果加了两个断点的话,执行的过程中,会先执行最后的调用行,端点1执行的过程中,会执行到端点2的stub,这时候在断点2可以获取到方法执行的入参,对入参进行Assert校验,即可实现目的;

new Anwer是个接口,其中只有一个方法,用于设置方法调用的代理执行入口

doAnswer的实现Java

public interface Answer {

/**

* @param invocation the invocation on the mock.

*

* @return the value to be returned

*

* @throws Throwable the throwable to be thrown

*/

T answer(InvocationOnMock invocation) throws Throwable;

}

当代码执行到“ ruleDao.updateSelective(rule); ”的时候,会触发针对mock对象调用的拦截器,在拦截器中,会创建一个动态代理,动态代理的invocation就是new Answer中覆盖的方法;

使用拦截、代理两种方法,实现了对mock对象方法的入参、出参的设定和获取,使用这种方式,就可以校验VOID方法内部的执行类调用的情况;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java基于正则表达式获取指定HTML标签指定属性值的方法
下一篇:微信小程序 地图map详解及简单实例
相关文章

 发表评论

暂时没有评论,来抢沙发吧~