java - 單元測(cè)試對(duì)dao層的測(cè)試有什么好的實(shí)踐方案?
問(wèn)題描述
比如對(duì)某個(gè)新增的dao進(jìn)行單元測(cè)試,那豈不是要真的往數(shù)據(jù)庫(kù)中插入一條數(shù)據(jù)?每次單元測(cè)試都新增一條數(shù)據(jù)?
還有,查詢操作,返回一個(gè)List的對(duì)象集合,怎么判斷數(shù)據(jù)是準(zhǔn)確的呢?
對(duì)于單元測(cè)試,大家有什么好的實(shí)踐方案嗎?
問(wèn)題解答
回答1:單元測(cè)試中使用數(shù)據(jù)庫(kù),可以考慮兩種方案:
搭建一個(gè)長(zhǎng)期使用的測(cè)試數(shù)據(jù)庫(kù),作為單元測(cè)試,測(cè)試開(kāi)始前或完成后清空無(wú)關(guān)數(shù)據(jù),即可保證測(cè)試的可重復(fù)性。缺點(diǎn)是多個(gè)人同時(shí)運(yùn)行單元測(cè)試時(shí),可能會(huì)失敗。
使用內(nèi)存數(shù)據(jù)庫(kù)(如 H2)。優(yōu)點(diǎn)是無(wú)需清空無(wú)關(guān)數(shù)據(jù),缺點(diǎn)是要將數(shù)據(jù)庫(kù)初始化過(guò)程(如建表語(yǔ)句)納入單元測(cè)試中。如果初始化很復(fù)雜,也會(huì)影響單元測(cè)試的效率。
至于如何驗(yàn)證查詢結(jié)果,基本上根據(jù)業(yè)務(wù)邏輯來(lái)。比如我單元測(cè)試運(yùn)行到這里,查詢這個(gè)一定會(huì)返回 27 條記錄,那就驗(yàn)證返回記錄數(shù)是否為 27。其他情況可以自己設(shè)計(jì)。
相關(guān)文章:
1. javascript - jquery怎么給select option一個(gè)點(diǎn)擊時(shí)觸發(fā)的事件,如圖 如果選擇自定義觸發(fā)一個(gè)時(shí)間?2. javascript - 怎樣限制同一個(gè)瀏覽器不能登錄兩個(gè)賬號(hào)3. nginx配置server模塊的問(wèn)題4. java - android代碼重構(gòu):如何把a(bǔ)pp設(shè)置里的頭像UI做成通用的?5. 想找個(gè)php大神仿個(gè)網(wǎng)站。6. java - 新手做一個(gè)安卓視頻播放器,想實(shí)現(xiàn)一個(gè)進(jìn)度條,按鈕那種在視頻下方懸浮的功能,不知道思路!7. javascript - angular和jquery都用到了$符號(hào),一起用會(huì)不會(huì)沖突?8. css3 - Typecho 后臺(tái)部分表單按鈕在 Chrome 下出現(xiàn)靈異動(dòng)畫(huà)問(wèn)題,求解決9. mysql優(yōu)化 - 關(guān)于mysql分區(qū)10. 如何將行內(nèi)塊元素的內(nèi)容垂直水平兩個(gè)方向居中?
