文章詳情頁
java - 單元測試對dao層的測試有什么好的實踐方案?
瀏覽:144日期:2023-12-23 18:47:53
問題描述
比如對某個新增的dao進行單元測試,那豈不是要真的往數(shù)據(jù)庫中插入一條數(shù)據(jù)?每次單元測試都新增一條數(shù)據(jù)?
還有,查詢操作,返回一個List的對象集合,怎么判斷數(shù)據(jù)是準確的呢?
對于單元測試,大家有什么好的實踐方案嗎?
問題解答
回答1:單元測試中使用數(shù)據(jù)庫,可以考慮兩種方案:
搭建一個長期使用的測試數(shù)據(jù)庫,作為單元測試,測試開始前或完成后清空無關數(shù)據(jù),即可保證測試的可重復性。缺點是多個人同時運行單元測試時,可能會失敗。
使用內(nèi)存數(shù)據(jù)庫(如 H2)。優(yōu)點是無需清空無關數(shù)據(jù),缺點是要將數(shù)據(jù)庫初始化過程(如建表語句)納入單元測試中。如果初始化很復雜,也會影響單元測試的效率。
至于如何驗證查詢結(jié)果,基本上根據(jù)業(yè)務邏輯來。比如我單元測試運行到這里,查詢這個一定會返回 27 條記錄,那就驗證返回記錄數(shù)是否為 27。其他情況可以自己設計。
標簽:
java
上一條:java - 數(shù)據(jù)庫一條記錄為什么經(jīng)過hibernate查詢變成一個對象了呢??下一條:java中成員變量productDao并沒有初始化,為什么可以調(diào)用方法?
相關文章:
1. nignx - docker內(nèi)nginx 80端口被占用2. docker網(wǎng)絡端口映射,沒有方便點的操作方法么?3. docker綁定了nginx端口 外部訪問不到4. fragment - android webView 返回后怎么禁止重新渲染?5. angular.js - angular內(nèi)容過長展開收起效果6. php - mysql 模糊搜索問題7. docker不顯示端口映射呢?8. java - 為什么此私有靜態(tài)變量能被訪問呢?9. thinkphp5.1學習時遇到session問題10. dockerfile - 我用docker build的時候出現(xiàn)下邊問題 麻煩幫我看一下
排行榜

熱門標簽