• 0
  • 0
分享

一、代码覆盖率

通常我们在做单元测试的时候会接触到代码覆盖率的概念,通过在单元测试的过程中收集代码覆盖率去判断测试用例是否充分,去更精准的定位问题。而对于功能测试或者接口测试比较少的去关注覆盖率数据,功能测试时覆盖率的收集也是比较困难的。然后对于功能测试而言进行代码覆盖率的收集有利于测试工程师去判断哪些分支没有被覆盖,判断是否是设计用例的时候没有做到覆盖,又或者是由于存在bug使得无法覆盖到,从而更精准的去定位bug的位置,去分析问题,节省时间。

二、工具简介

对于java的代码覆盖率的收集,比较常用的工具有emma、jacoco,它们都是免费的代码覆盖率工具。emma目前已经不维护,EclEmma团队推出了jacoco,jacoco可以理解为emma的升级版本。Jacoco可以跟ant、maven、gradle等集成,降低了使用成本,使用更灵活 ;同时它还引入了监控机制,通过JJavaAgent技术监控Java程序。Jacoco还可以更第三方平台进行集成,比如sonar、jenkins,通过第三方平台更友好的将覆盖率数据在web端展示。

三、Java Counters

Jacoco提供了多维度的覆盖率统计方法,包含指令级(Instructions,C0coverage)覆盖,分支(Branches,C1coverage)覆盖、类(classes)覆盖、方法(non-abstract methods)覆盖、行(Lines)覆盖。同时还提供圈复杂度(CyclomaticComplexity)的统计,它会去计算每个类,方法的圈复杂度,根据McCabe1996的定义,圈复杂度可以理解为覆盖所有的可能情况最少使用的测试用例数,同时圈复杂度越高意味着程序越复杂,发生bug的概率越大。

2.1 Instructions

Jacoco在统计覆盖率时最小的统计单位就是字节码指令。通过指令覆盖率统计的是所有的指令哪些被执行了哪些没有被执行,从而得出统计数据。这项规则完全独立于源码格式并且在任何情况下有效,不需要类文件的调试信息。

2.2 Branches

Jacoco对所有的if...else...和switch...case...指令计算了分支覆盖率。分支覆盖会去统计程序中所有的分支数量,并统计哪些被执行哪些没有被执行,从而得出有效的覆盖率数据。

2.3  Classes

类覆盖是收集类的统计数据,计算中每个类中只要有一个方法被执行,这个类就被认定为被执行,那么它的覆盖率就是100%。

2.4 Methods

方法覆盖是收集类中的方法的覆盖率,通常一个非抽象方法都至少有一条指令,只要改方法中有一行被执行,该统计规则就认为他被执行了,该方法的覆盖率就是100%。

2.5 Lines

行覆盖,统计每行代码的覆盖率,只有当每一行代码都被执行到了才会是100%,理论上保证100%的覆盖率就能保证程序不会有bug。

四、准备工作

进入jacoco官网:http://www.eclemma.org/jacoco/ ,下载jacoco-0.7.8.zip。

进入apache官网:http://ant.apache.org/bindownload.cgi ,下载apache-ant-1.9.6-bin.tar.gz。

五、Tomcat 服务配置

1、本地为windows系统,先关闭tomcat服务。

2、将下载得到的jacocoagent.jar拷贝至D:\Program Files (x86)\apache-tomcat-8.0.30-windows-x86\apache-tomcat-8.0.30\lib\

3、修改bin/catalina.bat中JAVA_OPTS的配置

set JAVA_OPTS="-javaagent:%CATALINA_BASE%\lib\jacocoagent.jar=includes=com.yihu.qa.*,
output=tcpserver,port=3344,a
ddress=192.168.1.103"

其中:%CATALINA_BASE%\lib\jacocoagent.jar为安装jacoco的jacocoagent.jar包相对路径;output覆盖率数据输出的形式,有file, tcpserver, tcpclient, 默认是file,file是在jvm停掉时才将覆盖率数据dump出来;address和port可以提供client访问,并dump出覆盖率数据文件,在build.xml会使用。

4、执行 startup.bat 启动tomcat。

六、本地ant配置

1、ant配置

将下载来的ant解压到某个目录下,添加ant环境变量,我的电脑->属性->高级系统设置->环境变量->新建

1.jpg


2.jpg

接下来查看ant配置是否ok,打开命令行,执行ant -version,如下图,表示ant安装成功

3.jpg

Ant -version

2、创建一个ant的目录D:\Program Files (x86)\apache-tomcat-8.0.30-windows-x86\ant,将下载得到的jacocoant.jar拷贝至D:\Program Files (x86)\apache-tomcat-8.0.30-windows-x86\ant

3、配置build.xml

4.jpg

说明:主要需要配置dump任务,jacoco生成报告任务;dump任务主要是为了能够生成.exec文件,在通过jacoco的任务根据源码跟.class文件以及.exec文件得出相应的html格式的覆盖率数据。

如何定义任务: 

<target name="***">****</target>

如何执行任务:ant targetname

3、执行ant dump,执行成功后可以在ant的目录下发行.exec的文件

5.jpg

ant dump

4、执行 ant report,在ant目录下看到coverage_ant_task文件夹

5、查看报告

在报告中我们可以看到整个项目的各个覆盖率的情况,同时我们也可以查看到各个类方法的覆盖率数据,以及可以看到代码的行覆盖的情况,在方法里可以清晰的看到红色跟绿色,红色代表没有覆盖,绿色代表已经被覆盖了。从而我们可以推断出可能用例不完善这时候需要补充用例去覆盖改部分的内容,如果用例已经覆盖了,需要排查是否是出现了bug。


版权声明:本文出自51Testing原创,51Testing软件测试网及相关内容提供者拥有内容的全部版权,未经明确的书面许可,任何人或单位不得对本网站内容复制、转载或进行镜像,否则将追究法律责任。

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 前言直接入手大家可能没什么概念,迷迷糊糊,先抛出几个问题给大家,快速帮助大家了解接口测试的基本概念。接口测试测什么?什么是接口测试?和单元测试的区别?接口测试的价值和意义?怎么测试接口?怎么写用例,怎么运行用例,测试框架?一、接口测试测什么?说明一下:本人之前在某绿厂工作过,这边项目的诉求是整机的接口进行测试。简单的说一下我这边对接口测试的理解,面对用户使用的app,而app可能使用到的接口大致分成以下几类:三方接口(百度地图,腾讯,阿里,三方开源的依赖库,网络接口(http)等)应用对外提供的接口(自定义的ContentProvider,AIDL等)应用内部明显分层的跨Moudle接口(模块...
            0 0 2400
            分享
          •   引言  如何保证测试的数据质量,说白了,就是如何保证测试数据的准确性。  深聊测试数据  我们想一个问题:在实际的项目测试中,我们的数据质量与什么有关呢?  是 测数数据的多少,还是测试数据的内容?  同样,我先不回答, 我们继续往下聊。  回顾,你在整个项目的测试中,我们这里以接口为例,  你会花费很长时间去构造数据,以保证每次的数据质量都是完美的吗?  纵观整个测试行业,虽然相对于早些年,现在的测试开发工程师的测试质量逐年提升,测试技术也逐年提升。  但是,随着企业的版本迭代的加速, 却很少会有测试开发工程师花费大部分时间在测试数据质量上,  或者说,不是太多的测试开发工程师具备数据质...
            0 0 1294
            分享
          •   有人说:“杂乱无章的自动化只会带来更快的混乱。”不仅更快,而且是更严重、更大的混乱。如果使用得当,自动化可以成为测试团队中令人惊叹的生产力助推器和系统的质量增强器。自动化测试的关键是要正确运用,这是初始最困难的部分。下面,我们会了解最常见的自动化测试挑战以及应对措施。  挑战 1:获得管理层的批准  跟任何公司部门一样,员工总要知道预算允许和不允许的东西。测试人员可能已经知道自动化在商业和技术两方面的优势(缩短上市时间、增加测试覆盖度和准确性、降低每小时的测试成本、更快发现错误等),但是测试人员怎样说服财务部门和软件开发负责人,为自动化测试争取必要的时间和资金?  “自动化测试能提高生产力...
            0 0 1073
            分享
          • 软件性能测试中有一类很重要的测试——负载测试,包括并发测试和容量测试。负载测试的重要工作在于找到系统的性能拐点。在并发测试中我们不断地增加事物的用户并发数,观察系统所可以接受的并发数是否与设置的并发数保持一致,或者在增加并发数的时候观察系统的响应时间是否在可接受的范围之内(比如<3秒》)。当并发数少的时候,实际并发数与设置并发数是一致的,当系统并发数达到一定的数量后,实际并发数保持恒定,不会受到设置并发数的增加而增加了。或者系统的响应时间会超过设定的目标值。如图一所示,A即为我们找到的并发测试的拐点。图一:负载测试的拐点同样,在容量测试中,我们不断地往数据库中灌入数据,在开始数据量比较少...
            0 0 2393
            分享
          •   各位小伙伴们还记上个月小红书APP崩溃闪退,导致大批用户卸载APP重装的事故吗?闪退Bug从凌晨持续到第二天上午。  事发第二天,就有研发在线承认了,因为自己的失误导致了这次事件,评论区也有人担心博主会不会失去工作。  这件事会到此为止吗?有研发人员承认了错误,测试人员还需要负责吗?  也由此引出一个测试人员的最大疑问:  项目上线后出了严重Bug,到底是谁的责任?  目前存在如下两种观点:  Mr.Zhou  Mr.Zhou是企业的研发总监,他看到这个Bug时,确定是测试的锅。  他认为:测试工程师是软件产品质量的最后一个把关者,没有做好更新测试,才导致版本发布上线后APP更新崩溃。因此...
            0 0 1235
            分享
      • 51testing软件测试圈微信