JAVA覆盖率工具EMMA详细解析

时间:2020-08-09 18:55:25 JAVA认证 我要投稿

JAVA覆盖率工具EMMA详细解析2016

  EMMA 是一个开源、面向 Java 程序测试覆盖率收集和报告工具。它通过对编译后的 Java 字节码文件进行插装,在测试执行过程中收集覆盖率信息,并通过支持多种报表格式对覆盖率结果进行展示。那么EMMA覆盖率工具有什么原理,怎么使用?下面跟yjbys小编一起来学习一下吧!

  首先介绍一下EMMA 是一个开源、面向 Java 程序测试覆盖率收集和报告工具。它通过对编译后的 Java 字节码文件进行插装,在测试执行过程中收集覆盖率信息,并通过支持多种报表格式对覆盖率结果进行展示。EMMA可以统计函数覆盖、类覆盖、行覆盖等,据说最新版支持分支覆盖。

  查看了一下EMMA的'基本原理,大致分为以下步骤:插桩(instr),运行,收集(ctl),报告(report)。

  插桩

  命令行:java emma instr -cp /usr/local//anrs/lib/anrs.jar -m overwrite -ix +com.* -Dmetadata.out.file=test.em

  参数介绍:

  -cp,指定插桩的路径,多个jar包可以用,分割

  -m:输出模式

  overwrite:重新jar包,anrs.jar

  default:copy, 需要加上-d参数,指定输出路径。有插桩,才cp一份class到指定路径

  fullcopy:需要加上-d参数,指定输出路径。 不管有没有插桩,都cp一份class到指定路径

  -merge:合并。

  default:yes。 如果metadata指定输出的文件一样,将两次插桩信息进行合并

  no。不合并两次插桩信息

  -ix:指定需要插桩的class

  +com.*: + 指包含

  -com.*:-指排除

  运行

  一般情况下,直接运行应用程序即可。EMMA会启动一个监听端口,用来后面收集信息(ctl)。这个端口是固定的,47653。

  如果我们的应用是多进程的,就会出现启动失败。其实EMMA也提供了一个命令,进行端口设置:-Demma.rt.control.port=39123

  还有host指定,-Demma.rt.control.host=192.168.22.22. default is localhost

  这个参数需要加在程序启动命令里

  EMMA还有简单的配置文件:java -Demma.properties=my.properties

  my.properties format: tag=value

  收集

  一般有两种收集信息方法:

  1. 程序退出,自动收集,在当前运行目录下生成coverage.ec

  2. 命令行:

  java -cp /usr/jdk/jdk1.6.0_23/jre/lib/ext/emma.jar emma ctl -connect localhost:47653 -command coverage.get,coverage.ec

  报告

  命令行:

  java -cp /usr/jdk/jdk1.6.0_29/jre/lib/ext/emma.jar emma report -r html -in anrs.em coverage.ec –sp src/-Dreport.html.out.file=coverage.html

  参数介绍

  -r: report type:html,txt,xml

  -sp: sourcecode path

  项目应用

  1 项目特点

  应用程序会启动多个进程,启动脚本也会执行jar包。---需要解决emma端口冲突

  测试过程中,由于bug会修改代码,版本迭代。希望统计这些版本的整个覆盖率信息---emma支持多个版本的覆盖率统计

  希望每个case都有自己独立的覆盖率统计信息,同时也要有整个的覆盖统计信息。

  2 应用

  每个case执行的步骤:

  1. 判断是否更新了jar包

  1.1 更新:插桩,指定同个文件名合并到一起

  1.1.1 stop app

  1.1.2 设置 EMMAPORT 环境变量

  1.1.3 启动一个应用进程,指定EMMAPORT:-Demma.rt.control.port=$EMMAPORT

  1.1.4 循环1.1.2 & 1.1.3,启动完所有的进程

  1.2 未更新:

  1.2.1 清除执行信息:

  java -cp /usr/jdk/jdk1.6.0_23/jre/lib/ext/emma.jar emma ctl -connect localhost:47653 -command coverage.reset

  2. 执行case

  3. 收集执行信息

  3.1 把所有进程的执行信息收集到一个文件里

  java -cp /usr/jdk/jdk1.6.0_23/jre/lib/ext/emma.jar emma ctl -connect localhost:47653 -command coverage.get,coverage.ec

  3.2 每个case需要有独立的执行信息

  cp coverage.ec coverage_caseNo.ec

  4. 生成报告

  测试完这个版本后,生成报告

【JAVA覆盖率工具EMMA详细解析2016】相关文章:

JAVA覆盖率工具EMMA介绍05-08

Java IDE详细介绍201610-02

Java ClassLoader原理详细分析201605-14

java命令行参数解析201611-11

java语言的特性解析08-14

西班牙留学开支详细解析07-13

关于Ajax的详细解析11-10

宠物狗梳毛工具详细用法10-02

关于Java动态代理的解析10-08