首頁  >  文章  >  Java  >  Java單測void類型的方法詳解

Java單測void類型的方法詳解

高洛峰
高洛峰原創
2017-01-19 14:32:431562瀏覽

前言

我們在學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返回的方法測試JavaJava​​

示,如果加了兩個斷點的話,執行的過程中,會先執行最後的呼叫行,端點1執行的過程中,會執行到端點2的stub,這時候在斷點2可以取得到方法執行的入參,對入參進行Assert校驗,即可實現目的;

new Anwer是個接口,其中只有一個方法,用於設置方法調用的代理執行入口

doAnswer的實現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);
}

當Answer的實作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方法內部的執行類別呼叫的情況;

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或工作能帶來一定的幫助,如果有疑問大家可以留言交流。 🎜🎜更多Java單測void類型的方法詳解相關文章請關注PHP中文網! 🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn