Java單測void類型的方法詳解
前言
我們在學(xué)Java的時(shí)候,老師或者一般的書上都寫著,Java的基本類型有八種。分別是:byte、int、short、long、float、double、char、boolean。但是,今早我在看Java的圣經(jīng)——《Thinking in Java》的時(shí)候,發(fā)現(xiàn)作者在說明數(shù)據(jù)類型的時(shí)候,把void也放上去了。這樣就有九種了。百度了一下,有些書也是寫的Java有九種基本類型。
Java的Sevice層會有很多void類型的方法,比如save*、update*,這類方法只是做一些更新,不會有返回值,其單測不能根據(jù)方法的返回值來編寫,只能采用特殊方法;
本方法環(huán)境:Mockito、testng
被測試的方法:
想要被測試的VOID方法Java
@Override
public void updateRuleName(Long ruleId, String newRuleName, Long ucId) {
Assert.notNull(ruleId, "規(guī)則ID不能為Null");
Assert.notNull(newRuleName, "規(guī)則名稱不能為Null");
Assert.notNull(ucId, "操作人的UCID不能為Null");
String cleanNewRuleName = StringUtils.trim(newRuleName);
if (StringUtils.isBlank(cleanNewRuleName)) {
throw new IllegalArgumentException("新的規(guī)則名稱不能為空");
}
// 查詢規(guī)則對象
Rule rule = queryRuleById(ruleId);
if (null == rule) {
throw new IllegalDataException("沒有查到該規(guī)則");
}
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);
// 查詢規(guī)則對象
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) {
// 斷點(diǎn)2:這里隨后執(zhí)行
Rule rule = (Rule) invocation.getArguments()[0];
Assert.assertTrue(rule.getRuleName().equals("newRuleName"));
return null;
}
}).when(ruleDao).updateSelective(Mockito.any(Rule.class));
// 斷點(diǎn)1:先執(zhí)行到這里
ruleService.updateRuleName(ruleId, newRuleName, ucId);
}
如注釋所示,如果加了兩個(gè)斷點(diǎn)的話,執(zhí)行的過程中,會先執(zhí)行最后的調(diào)用行,端點(diǎn)1執(zhí)行的過程中,會執(zhí)行到端點(diǎn)2的stub,這時(shí)候在斷點(diǎn)2可以獲取到方法執(zhí)行的入?yún)?,對入?yún)⑦M(jìn)行Assert校驗(yàn),即可實(shí)現(xiàn)目的;
new Anwer是個(gè)接口,其中只有一個(gè)方法,用于設(shè)置方法調(diào)用的代理執(zhí)行入口
doAnswer的實(shí)現(xiàn)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;
}
當(dāng)代碼執(zhí)行到“ ruleDao.updateSelective(rule); ”的時(shí)候,會觸發(fā)針對mock對象調(diào)用的攔截器,在攔截器中,會創(chuàng)建一個(gè)動態(tài)代理,動態(tài)代理的invocation就是new Answer中覆蓋的方法;
使用攔截、代理兩種方法,實(shí)現(xiàn)了對mock對象方法的入?yún)?、出參的設(shè)定和獲取,使用這種方式,就可以校驗(yàn)VOID方法內(nèi)部的執(zhí)行類調(diào)用的情況;
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
spring基礎(chǔ)概念A(yù)OP與動態(tài)代理理解
這篇文章主要為大家詳細(xì)介紹了spring基礎(chǔ)概念A(yù)OP與動態(tài)代理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
一文教你掌握J(rèn)ava如何實(shí)現(xiàn)判空
實(shí)際項(xiàng)目中我們會有很多地方需要判空校驗(yàn),如果不做判空校驗(yàn)則可能產(chǎn)生NullPointerException異常。所以本文小編為大家整理了Java中幾個(gè)常見的判空方法,希望對大家有所幫助2023-04-04
Java中Mybatis,SpringMVC,Spring的介紹及聯(lián)系
這篇文章主要為大家詳細(xì)介紹了Java中Mybatis,SpringMVC,Spring的介紹及聯(lián)系,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
Java如何優(yōu)雅實(shí)現(xiàn)數(shù)組切片和拼接操作
在做一道算法題的時(shí)候用到數(shù)組合并,并且有性能要求,這里對Java數(shù)組合并進(jìn)行總結(jié),下面這篇文章主要給大家介紹了關(guān)于Java如何優(yōu)雅實(shí)現(xiàn)數(shù)組切片和拼接操作的相關(guān)資料,需要的朋友可以參考下2024-04-04
Javaweb實(shí)戰(zhàn)之實(shí)現(xiàn)蛋糕訂購系統(tǒng)
隨著網(wǎng)絡(luò)的普及與發(fā)展,網(wǎng)上購物逐漸成為一種主流消費(fèi)的方式。這篇文章主要介紹了通過JavaWeb制作一個(gè)線上蛋糕訂購系統(tǒng),文中示例代碼講解詳細(xì),需要的朋友可以參考一下2021-12-12

