用EMMA对JMeter执行代码覆盖率进行分析

Noella ·
更新时间:2024-11-10
· 779 次阅读

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.1in>echo %CLASSPATH% E:alibaba oolsemma-stable-2.1-libemma.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 oolsemma-stable-2.1-libemma.jar  强制优先加载emma.jar。

故修改jmeter.bat为 %JM_START% %JM_LAUNCH%  -Xbootclasspath/p:E:alibaba oolsemma-stable-2.1-libemma.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



jmeter 覆盖率

需要 登录 后方可回复, 如果你还没有账号请 注册新账号
相关文章