by liangjz
emma度量代碼覆蓋率不需要額外編寫單元測試代碼。
支持JAVA GUI、JAVA CONSOLE、JAVA APP SERVER。
一 安裝與配置
EMMA支持jdk1.2 或以上。
下載: http://emma.sourceforge.net/
在我的電腦里面設置CLASSPATH加入emma.jar.
顯示:
E:\jakarta-jmeter-2.3.1\bin>echo %CLASSPATH%
E:\alibaba\tools\emma-stable-2.1-lib\emma.jar;.
二 收集應用的元信息
這一步必須有.class文件或者包含.class文件的jar包。
而且必須在應用執行的目錄下進行(非源代碼的路徑),否則第四步收集信息時出現異常"emma ctl:
coverage.get: RPC failure while executing [coverage.get]
Exception in thread "main" com.vladium.emma.EMMARuntimeException: coverage.get:
RPC failure while executing [coverage.get]
at com.vladium.emma.ctl.CtlProcessor._run(CtlProcessor.java:242)"
收集元信息(會改寫ApacheJmeter.jar內容)
java emma instr -m overwrite -cp ApacheJMeter.jar -out coverage.em
正常時當前目錄生成coverage.em。
三 執行應用程序
jmeter.bat導致異常
Exception in thread "main" java.lang.NoClassDefFoundError: com/vladium/emma/rt/R
T
at org.apache.jmeter.NewDriver.$VRi(NewDriver.java)
at org.apache.jmeter.NewDriver.<clinit>(NewDriver.java)
errorlevel=1
分析確認由于java加載ApacheJMeter.jar包時ClassLoader順序非預期,通過-
Xbootclasspath/p:E:\alibaba\tools\emma-stable-2.1-lib\emma.jar 強制優先加載emma.jar。
故修改jmeter.bat為
%JM_START% %JM_LAUNCH% -Xbootclasspath/p:E:\alibaba\tools\emma-stable-2.1-lib\emma.jar %
JVM_ARGS% %ARGS% -jar "%JMETER_BIN%ApacheJMeter.jar" %JMETER_CMD_LINE_ARGS%
再次啟動jmeter.bat,出現提示
EMMA: collecting runtime coverage data ...
EMMA: runtime controller started on port [47653]
netstat 檢查47653端口處于Listening狀態。
在JMeter界面上操作。后臺會記錄代碼執行狀況
四 收集代碼行、函數、類覆蓋信息
在Jmeter不退出的情況下,執行
java -cp %CLASSPATH% emma ctl -connect localhost:47653 -command coverage.get,coverage.ec
或者Jmeter正常退出的情況下,也會主動收集信息存放在默認的coverage.ec。
五 生成報告
java -cp %CLASSPATH% emma report -r html -in coverage.em,coverage.ec -
Dreport.html.out.file=coverage.html -Dreport.metrics=class:50
原文轉自:http://www.anti-gravitydesign.com