Java單測(cè)void類型的方法詳解
前言
我們?cè)趯W(xué)Java的時(shí)候,老師或者一般的書上都寫著,Java的基本類型有八種。分別是:byte、int、short、long、float、double、char、boolean。但是,今早我在看Java的圣經(jīng)——《Thinking in Java》的時(shí)候,發(fā)現(xiàn)作者在說(shuō)明數(shù)據(jù)類型的時(shí)候,把void也放上去了。這樣就有九種了。百度了一下,有些書也是寫的Java有九種基本類型。
Java的Sevice層會(huì)有很多void類型的方法,比如save*、update*,這類方法只是做一些更新,不會(huì)有返回值,其單測(cè)不能根據(jù)方法的返回值來(lái)編寫,只能采用特殊方法;
本方法環(huán)境:Mockito、testng
被測(cè)試的方法:
想要被測(cè)試的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ī)則對(duì)象 Rule rule = queryRuleById(ruleId); if (null == rule) { throw new IllegalDataException("沒(méi)有查到該規(guī)則"); } rule.setRuleId(ruleId); rule.setRuleName(cleanNewRuleName); rule.setUpdateUcid(ucId); rule.setUpdateTime(new Date()); ruleDao.updateSelective(rule); }
測(cè)試的方法:
void返回的方法測(cè)試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ī)則對(duì)象 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í)行的過(guò)程中,會(huì)先執(zhí)行最后的調(diào)用行,端點(diǎn)1執(zhí)行的過(guò)程中,會(huì)執(zhí)行到端點(diǎn)2的stub,這時(shí)候在斷點(diǎn)2可以獲取到方法執(zhí)行的入?yún)?,?duì)入?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í)候,會(huì)觸發(fā)針對(duì)mock對(duì)象調(diào)用的攔截器,在攔截器中,會(huì)創(chuàng)建一個(gè)動(dòng)態(tài)代理,動(dòng)態(tài)代理的invocation就是new Answer中覆蓋的方法;
使用攔截、代理兩種方法,實(shí)現(xiàn)了對(duì)mock對(duì)象方法的入?yún)?、出參的設(shè)定和獲取,使用這種方式,就可以校驗(yàn)VOID方法內(nèi)部的執(zhí)行類調(diào)用的情況;
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
spring?security需求分析與基礎(chǔ)環(huán)境準(zhǔn)備教程
這篇文章主要為大家介紹了spring?security需求分析與基礎(chǔ)環(huán)境準(zhǔn)備教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03Java微服務(wù)開(kāi)發(fā)之Swagger詳解
Swagger 是一個(gè)規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化 RESTful 風(fēng)格的 Web 服務(wù)。總體目標(biāo)是使客戶端和文件系統(tǒng)作為服務(wù)器以同樣的速度來(lái)更新。文件的方法,參數(shù)和模型緊密集成到服務(wù)器端的代碼,允許API來(lái)始終保持同步2021-10-10Mybatis之Mapper動(dòng)態(tài)代理實(shí)例解析
這篇文章主要介紹了Mybatis之Mapper動(dòng)態(tài)代理實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08關(guān)于spring循環(huán)依賴問(wèn)題及解決方案
這篇文章主要介紹了關(guān)于spring循環(huán)依賴問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06