加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java单测void类型的方法详解

发布时间:2020-12-14 14:32:02 所属栏目:Java 来源:网络整理
导读:前言 我们在学Java的时候,老师或者一般的书上都写着,Java的基本类型有八种。分别是:byte、int、short、long、float、double、char、boolean。但是,今早我在看Java的圣经――《Thinking in Java》的时候,发现作者在说明数据类型的时候,把void也放上去了

前言

我们在学Java的时候,老师或者一般的书上都写着,Java的基本类型有八种。分别是:byte、int、short、long、float、double、char、boolean。但是,今早我在看Java的圣经――《Thinking in Java》的时候,发现作者在说明数据类型的时候,把void也放上去了。这样就有九种了。百度了一下,有些书也是写的Java有九种基本类型。

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

本方法环境:Mockito、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<Rule> rules = new ArrayList<Rule>();
 Rule rule = new Rule();
 rule.setRuleStatus((byte) DBValueSetting.RULE_STATUS_TAKE_EFFECT);
 rules.add(rule);
 
 // 查询规则对象
 Map<String,Object> params = new HashMap<String,Object>();
 params.put("ruleId",ruleId);
 Mockito.when(ruleDao.queryRulesByCondition(params)).thenReturn(rules);
 
 Mockito.doAnswer(new Answer<Object>() {
  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<T> {
 /**
 * @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方法内部的执行类调用的情况;

总结

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读