程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java單測void類型的辦法詳解

Java單測void類型的辦法詳解

編輯:關於JAVA

Java單測void類型的辦法詳解。本站提示廣大學習愛好者:(Java單測void類型的辦法詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是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辦法外部的執行類調用的狀況;

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或許任務能帶來一定的協助,假如有疑問大家可以留言交流。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved