使用Jacoco獲取 Java 程序的代碼執(zhí)行覆蓋率的步驟詳解
Jacoco是Java Code Coverage的縮寫,顧名思義,它是獲取Java代碼執(zhí)行覆蓋率的一個工具,通常用它來獲取單元測試覆蓋率。它通過分析Java字節(jié)碼來得到代碼執(zhí)行覆蓋率,因此它還可以分析任何基于JVM的語言(如Croovy、Kotlin)的覆蓋率。本文不討論如何用Jacoco獲取單元測試的代碼覆蓋率,而是從Jacoco的原理出發(fā),介紹如何通過Jacoco獲取SIT或者UAT的測試覆蓋率。更準確來講,是獲取一個應用執(zhí)行過的代碼占總代碼的比率。包括字節(jié)碼指令覆蓋率,分支覆蓋率,圈復雜度覆蓋率,行覆蓋率,方法覆蓋率和類覆蓋率。
Jacoco原理簡介
Jacoco通過修改喂給JVM的字節(jié)碼來達到獲取那些代碼執(zhí)行了的目的。修改方式有兩種,一種在線(on-the-fly),是通過Java agent,在JVM執(zhí)行字節(jié)碼之前動態(tài)對其進行修改,這種方式更靈活,也是Jcoco的一大特性。另一種是離線(offline)模式,在Java程序字節(jié)碼文件(.class文件)生成之前進行修改,這樣的字節(jié)碼就不純了。一般在無法使用on-the-fly方式的時候才使用offline方式。
上面這些概括起來講,Jacoco最牛X的地方就在于它能夠知道一個基于JVM的應用程序中哪些代碼(指令、分支、行、方法、類)被執(zhí)行了。用它除以總代碼量,就得到了代碼執(zhí)行覆蓋率。
由此,我們可以推斷出Jacoco生成單元測試覆蓋率報告的原理:單元測試代碼會調(diào)用被測試代碼,被測試代碼的字節(jié)碼指令會被Jacoco截獲,用被截獲的代碼量除以總代碼量,就算出了單元測試代碼覆蓋率。舉一反三,在SIT或者UT的時候,也需要執(zhí)行Java應用程序中的代碼,因此可以也通過Jacoco獲取被執(zhí)行過的代碼,從而計算出SIT,UT測試代碼覆蓋率。
使用Jacoco生成代碼執(zhí)行覆蓋率報告
接下來通過一個實驗介紹如何使用Jacoco獲取一個Java web應用代碼的執(zhí)行率。就拿Tomcat自帶的example應用來做實驗,我們在啟動Tomcat時帶上Jacoco的Java agent;然后在頁面上做一些點擊操作,觸發(fā)后臺Java代碼的執(zhí)行;再抓取包含執(zhí)行情況數(shù)據(jù),放到.exec的二進制文件中;最后由這些二進制文件生成html格式的報告,驗證被覆蓋的代碼是否和我們點擊的內(nèi)容相關(guān)。
下載Jacoco(https://www.jacoco.org),解壓縮。
下載Tomcat(https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/ 清華mirror),然后解壓縮,進入bin目錄,找到catalina.bat文件(Windows)。
修改如下代碼,讓Tomcat在啟動時帶上Javacoco的agent。
set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS%"
修改為
set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS% -javaagent:C:\Users\Robot\Application\jacoco-0.8.5\lib\jacocoagent.jar=destfile=jacoco.exec,output=tcpserver"
其中指定了javaagent是C:\Users\Robot\Application\jacoco-0.8.5\lib\jacocoagent.jar,解壓Jacoco可以得到;指定了output是tcpserver,也就是需要通過訪問一個地址才能獲取到數(shù)據(jù)。默認地址是本地IP地址,端口號是6300。其它參數(shù)說明見:https://www.jacoco.org/jacoco/trunk/doc/agent.html。
設(shè)置完成之后,雙擊Tomcat bin目錄下的startup.bat,啟動Tomcat??刂婆_可以看見javaagent設(shè)置生效。此時Jacoco就可以動態(tài)地攔截喂給JVM的字節(jié)碼,并且監(jiān)聽6300端口號和所以本機地址,等待獲取代碼執(zhí)行情況數(shù)據(jù)(暫且稱為.exec文件數(shù)據(jù))的請求。
輸入地址http://127.0.0.1:8080/ ,打開Tomcat 歡迎頁面,做一些點擊操作,可以確定它已經(jīng)執(zhí)行了一些字節(jié)碼。
獲取執(zhí)行情況數(shù)據(jù),在jacococli.jar所在目錄(與jacocoagent.jar目錄一致)執(zhí)行命令:
java -jar jacococli.jar dump --port 6300 --destfile data/jacoco-it.exec
Jacoco會在當前目錄下生成data/jacoco-it.exec文件,這個文件是一個二進制文件,我們無法直接查看它,需要用它生成html或者其它格式的文件。
執(zhí)行如下命令生成html報告。--classfiles制定應用程序的class文件所在目錄,--html指定html報告所在目錄。
java -jar jacococli.jar report data/jacoco-it.exec --classfiles C:/Users/Robot/Application/apache-tomcat-9.0.29/webapps/examples/WEB-INF/classes --html html
打開html目錄下的index.html文件就可以看到報告了。
小結(jié)
上面實驗比較簡單,只為輔助對Jacoco原理的理解。理解了原理之后,參照官網(wǎng)的手冊就可以用Jacoco來做一些實用的操作,提高Java代碼的質(zhì)量。
以上就是使用Jacoco獲取 Java 程序的代碼執(zhí)行覆蓋率的步驟詳解的詳細內(nèi)容,更多關(guān)于使用Jacoco獲取 Java 程序的代碼執(zhí)行覆蓋率的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
淺談String、StringBuffer和StringBuilder之間的區(qū)別
這篇文章主要介紹了淺談String、StringBuffer和StringBuilder之間的區(qū)別,通過字面量方式為字符串賦值時,此時的字符串存儲在方法區(qū)的字符串常量池中,需要的朋友可以參考下2023-10-10java 將 list 字符串用逗號隔開拼接字符串的多種方法
這篇文章主要介紹了java 將 list 字符串用逗號隔開拼接字符串,本文給大家分享四種方法,每種方法通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12springboot內(nèi)置tomcat之NIO處理流程一覽
這篇文章主要介紹了springboot內(nèi)置tomcat之NIO處理流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12java對象和json的來回轉(zhuǎn)換知識點總結(jié)
在本篇文章里小編給大家分享了一篇關(guān)于java對象和json的來回轉(zhuǎn)換知識點總結(jié)內(nèi)容,有興趣的朋友們可以學習下。2021-01-01