使用Jacoco獲取 Java 程序的代碼執行覆蓋率的步驟詳解
Jacoco是Java Code Coverage的縮寫,顧名思義,它是獲取Java代碼執行覆蓋率的一個工具,通常用它來獲取單元測試覆蓋率。它通過分析Java字節碼來得到代碼執行覆蓋率,因此它還可以分析任何基於JVM的語言(如Croovy、Kotlin)的覆蓋率。本文不討論如何用Jacoco獲取單元測試的代碼覆蓋率,而是從Jacoco的原理出發,介紹如何通過Jacoco獲取SIT或者UAT的測試覆蓋率。更準確來講,是獲取一個應用執行過的代碼占總代碼的比率。包括字節碼指令覆蓋率,分支覆蓋率,圈復雜度覆蓋率,行覆蓋率,方法覆蓋率和類覆蓋率。
Jacoco原理簡介
Jacoco通過修改喂給JVM的字節碼來達到獲取那些代碼執行瞭的目的。修改方式有兩種,一種在線(on-the-fly),是通過Java agent,在JVM執行字節碼之前動態對其進行修改,這種方式更靈活,也是Jcoco的一大特性。另一種是離線(offline)模式,在Java程序字節碼文件(.class文件)生成之前進行修改,這樣的字節碼就不純瞭。一般在無法使用on-the-fly方式的時候才使用offline方式。
上面這些概括起來講,Jacoco最牛X的地方就在於它能夠知道一個基於JVM的應用程序中哪些代碼(指令、分支、行、方法、類)被執行瞭。用它除以總代碼量,就得到瞭代碼執行覆蓋率。
由此,我們可以推斷出Jacoco生成單元測試覆蓋率報告的原理:單元測試代碼會調用被測試代碼,被測試代碼的字節碼指令會被Jacoco截獲,用被截獲的代碼量除以總代碼量,就算出瞭單元測試代碼覆蓋率。舉一反三,在SIT或者UT的時候,也需要執行Java應用程序中的代碼,因此可以也通過Jacoco獲取被執行過的代碼,從而計算出SIT,UT測試代碼覆蓋率。
使用Jacoco生成代碼執行覆蓋率報告
接下來通過一個實驗介紹如何使用Jacoco獲取一個Java web應用代碼的執行率。就拿Tomcat自帶的example應用來做實驗,我們在啟動Tomcat時帶上Jacoco的Java agent;然後在頁面上做一些點擊操作,觸發後臺Java代碼的執行;再抓取包含執行情況數據,放到.exec的二進制文件中;最後由這些二進制文件生成html格式的報告,驗證被覆蓋的代碼是否和我們點擊的內容相關。
下載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,也就是需要通過訪問一個地址才能獲取到數據。默認地址是本地IP地址,端口號是6300。其它參數說明見:https://www.jacoco.org/jacoco/trunk/doc/agent.html。
設置完成之後,雙擊Tomcat bin目錄下的startup.bat,啟動Tomcat。控制臺可以看見javaagent設置生效。此時Jacoco就可以動態地攔截喂給JVM的字節碼,並且監聽6300端口號和所以本機地址,等待獲取代碼執行情況數據(暫且稱為.exec文件數據)的請求。
輸入地址http://127.0.0.1:8080/ ,打開Tomcat 歡迎頁面,做一些點擊操作,可以確定它已經執行瞭一些字節碼。
獲取執行情況數據,在jacococli.jar所在目錄(與jacocoagent.jar目錄一致)執行命令:
java -jar jacococli.jar dump --port 6300 --destfile data/jacoco-it.exec
Jacoco會在當前目錄下生成data/jacoco-it.exec文件,這個文件是一個二進制文件,我們無法直接查看它,需要用它生成html或者其它格式的文件。
執行如下命令生成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文件就可以看到報告瞭。
小結
上面實驗比較簡單,隻為輔助對Jacoco原理的理解。理解瞭原理之後,參照官網的手冊就可以用Jacoco來做一些實用的操作,提高Java代碼的質量。
以上就是使用Jacoco獲取 Java 程序的代碼執行覆蓋率的步驟詳解的詳細內容,更多關於使用Jacoco獲取 Java 程序的代碼執行覆蓋率的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- springboot項目中jacoco服務端部署使用
- 在idea中使用JaCoCo插件統計單元測試覆蓋率的實現
- Android使用acoco統計代碼行覆蓋率介紹
- 解決tomcat 靜態頁面(html)中文亂碼的解決終極篇
- IDEA 2021.3 使用及idea2021.3.1激活使用方法