• 0
  • 0
分享
  • 简记前后端如何实现统计测试覆盖率——软件测试圈
  • 恬恬圈 2023-11-21 14:22:27 字数 3786 阅读 1243 收藏 0

  恰逢项目初起之时,代码基础各部分都有待完善。第一天上项目发现前后端几乎没有测试,遂决定加个测试覆盖率的限制。

  前端

  前端用的react, 测试用的jest。Jest是Facebook的一个专门进行Javascript单元测试的工具,适合React全家桶使用。因jest本身内置代码覆盖率,便新建了jest.config.json来实现统计前端测试覆盖率的需求。

  {
    "collectCoverage": true,
    "coverageDirectory": "reports",
    "collectCoverageFrom": [
      "src/**/*.js",
      "!**/node_modules/**"
    ],
    "coverageReporters": [
      "clover",
      "html"
    ],
    "coverageThreshold": {
      "global": {
        "branches": 80,
        "functions": 80,
        "lines": 80,
        "statements": 80
      }
    },
    "moduleFileExtensions": [
      "js"
    ],
    "modulePaths": [
      "<rootDir>"
    ],
    "testRegex": "(/__tests__/.*|\\.test)\\.js$"
  }

  1、testRegex:设置识别哪些文件是测试文件(正则形式),与testMatch互斥,不能同时写。

  2、moduleFileExtensions: 测试文件的类型 moduleFileExtensions: ['js','json','jsx','node']

  3、rootDir: 默认值是当前目录。

  4、collectCoverage: 默认值false。

  5、coverageDirectory: 输出coverage report的目录。

  6、collectCoverageFrom: 可配置哪些文件需要收集覆盖率,哪些不需要。

  7、coverageThreshold: 配置需要达到的测试覆盖率的百分比。

  配置完jest.config.json之后,在package.json内配置。

  "scripts": {
      "test": "jest --config jest.config.json",
      "prepush": "npm run lint && git secrets --scan -r && npm run test"
   }

  当开发运行npm run test或git push时会运行测试以及统计测试覆盖率。同时项目目录reports/index.html可查看测试覆盖率的report. 如果测试覆盖率没有达到配置的百分比,则push会失败。

1-1.jpg

1-2.jpg

  后端

  后端用的java gradle,测试是junit。一开始想的比较多,老想着在prepush的时候进行控制,在spike解决统计测试率的时候没能正确的拆分task,导致花了比较长的时间去spike。后经指点,重点去寻找统计java测试覆盖率的方法。发现jacoco可以实现并且满足我的需求。

  JaCoCo(Java Code Coverage)是一种分析单元测试覆盖率的工具。很多第三方的工具提供了对Jacoco的集成,如Jenkins等。使用它可以给出代码中哪些部分被单元测试测到,哪些部分没有没测到,并且给出整个项目的单元测试覆盖情况百分比。

  统计测试覆盖率

  首先因使用的gradle,所以需要在build.gradle下面引入jacoco,并进行一系列配置。

  apply plugin: 'jacoco'
  jacocoTestReport {
      reports {
          xml.enabled false
          html.enabled true
      }
  }

  轻松配置完之后愉悦的运行./gradlew jacocoTestReport,完美的在build/jacoco/test/html/index.html看见了测试覆盖率的report。

1-3.jpg

  提交!

  上jenkins一看 build挂了!

  在运行TASK:test的时候报错Caused by: java.lang.NoSuchFieldException: $jacocoAccess,但本地运行良好。怀疑是jacoco根本没被下载下来。寻觅许久,发现jacoco有个issue是跟jdk11不能友好合作。而我们恰好用的就是jdk11和jacoco0.7.。

  所以在我们的build.gradle中需要配置jacoco的版本就能解决。修改后:

  apply plugin: 'jacoco'
  jacoco {
      toolVersion = "0.8.2"
  }
  jacocoTestReport {
      reports {
          xml.enabled false
          html.enabled true
      }
  }

  集成jenkins

  我想要在jenkins上也能看见测试覆盖率的report,所以需要修改jenkinsfile。

  stage('build') {
      agent {
          docker {
            image 'echohe/gradle'
            args '-v $HOME/.gradle:/root/.gradle -e JAVA_TOOL_OPTIONS="-Dfile.encoding=UTF8"'
          }
      }
      steps {
          sh 'gradle build '
          script {
              echo "Stage test coverage report starting: ====="
              try {
                timeout(time:25, unit:'MINUTES') {
                  sh './gradlew jacocoTestReport'
                }
              } finally {
                if (fileExists('./build/reports/jacoco/test/html/index.html')) {
                  echo '==== test coverage report exists, prepare to publish'
                  publishHTML(target: [
                    allowMissing: true,
                    alwaysLinkToLastBuild: false,
                    keepAll: false,
                    reportDir: 'build/reports/jacoco/test/html/',
                    reportFiles: 'index.html',
                    reportName: 'test coverage report',
                    reportTitles: 'test coverage report']
                  )
                } else {
                  echo '==== test coverage report does NOT exists!!!'
                }
                echo "build state: ${currentBuild.result}"
                sh 'rm -rf ./build/reports/jacoco'
              }
          }
      }
  }

  这样在jenkins的build stage就能生成测试覆盖率的report,并且使用了publishHTML,就能在jenkins上出现测试覆盖率的link,点击之后会显示./build/reports/jacoco/test/html/index.html的内容。

1-4.jpg


作者:全世界最酷的李大厨    

来源:http://www.51testing.com/html/00/n-4481500.html

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

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 大家好,本人混过大厂,待过创业公司,爱给开发同学提Bug的测试妹纸一枚。2021年,是工作的第六年,也是具有突破性成长的一年,一直挺喜欢六这个数字,果然不负期望,带来了我好多惊喜。一、工作工作六年,一直从事的都是软件测试岗,一路走来可以说还是挺顺利的,在熟悉了各类业务,测试工具和简单的管理之外,略显疲惫,明显感觉工作遇到了瓶颈。后面在请教大佬,领导和同行的朋友,以及看过一些书籍后,慢慢找到了发力的方向,正在尝试突破瓶颈中。今年,负责的两个项目,日常工作正常开展,没有出现过线上事故,下面从测试人的角度总结下工作:一)业务在去年偏底层项目的基础上,新接手了一个Web项目,但是业务并不复杂,简单分为...
            0 0 1264
            分享
          •   在一般的面试环节过后,聊过自我介绍、业务问题、基本信息、简历信息这些,HR往往会跟你聊聊人(xian)生(liao)~  却有人好不容易过关斩将到了终面,在跟公司高管在轻松的氛围下“闲聊”后,与即将到手的offer失之交臂。  其实,面试官没有太多时间来“闲聊”,去了解你的私生活,问的每个话题都是想从侧面更多的了解你,每一句都是带有目的的,因为从应聘者进公司的那瞬间,面试可能就已经开始了。  在面试中,不存在脱口而出而没有用意的问题。  面试官会从见到面试者或是第一次电话起,直到确定是否录用为止,都是在评估应聘者的过程,有些面试官会用一些轻松的语句让气氛变得轻松活跃,让应聘者放松警惕,从而...
            0 0 934
            分享
          • 基本上测试过程中有效的找bug都要依赖测试用例,新同学了解功能点也离不开用例的执行。但是用例并不是从一开始就很完美,是需要经过多个版本更新之后还能经得住考验,那就离不开我们每一个人的维护,去其糟粕取其精华。测试用例的组成成分和维护方法:测试用例的组成成分:测试用例由测试目的,测试步骤,预期结果,测试结果组成。测试结果包括:pass通过,fail未通过,n/a无效;测试用例还需要统计通过率,失败率,无效率。—————————————————————————————————————————————测试用例的维护方法:一般的公司维护测试用例是用excel,表格上附上历史修改记录,每个版本测完之后用例...
            3 3 7650
            分享
          • 我们已经了解到了初级测试所需要具备的能力,和入门条件 那么我们在中级测试阶段需要哪些能力呢? 假如你会一门变成语音那中级对于你来说更加简单,假如不会也没有关系,那我们可以先学习工具是如何使用的,然后再针对自己的编程薄弱环节进行学习。 1. 自动化工具的使用 推荐工具:QTP,selenium(编程语言,可以根据自己的喜好进行学习,基本的语言都是支持的) 2. 性能工具的使用 学习和使用性能工具,公司开发出来的产品不能只有几个用户,肯定会存在大批量并发压测的需求,那么就需要我们去了解如何借助外力来达到成千上万的用户进行访问。 推荐工具:loadrunner,jmeter 3. 抓包工具的操作...
            2 6 5567
            分享
          •   TikTok Shop "链接很快就会在社交媒体应用中变得更加常见。据彭博社报道,该公司正在测试一项新功能,它能自动识别平台视频中的商品,然后提供一个链接,"在 TikTok Shop 上查找类似商品"。该公司发言人没有立即回应置评请求,该功能也更像是一个早期测试。  去年 11 月,Business Insider 曾对同一功能进行过测试,我们还发现了去年9月和10月包含 "在 TikTok 商店查找类似商品 "按钮的视频。TikTok 此前证实,它正在美国和英国的少数用户中测试该功能。一位在视频中添加了产品链接的用户没有被告知该链接将被...
            0 0 684
            分享
      • 51testing软件测试圈微信