jenkins pipeline流水线集成jacoco,sonar,robot framework,jmeter,fortify

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: jenkins pipeline流水线集成jacoco,sonar,robot framework,jmeter,fortify

1、环境准备

这篇文章的Jenkins集成jacoco,sonar,robot framework,jmeter,fortify仅为本地测试用。

环境为个人笔记本加2台虚拟机:

1、本地物理机,操作系统:win10,ip:192.168.119.1

安装工具:

jdk1.8

maven3.6.3:需配置环境变量

mysql5.7:用于sonarqube和应用服务器演示程序devopsplay

sonarqube7.8:

sonar-scanner-4.2.0.1873:版本需要与sonarqube7.8一致,需配置环境变量。

jmeter:需配置环境变量

python3.75及robot framework环境

fortify V20.1.1

Jenkins及各种插件

git客户端

2、gitlab服务器,centos7(虚拟机),ip: 192.168.119.133

java

gitlab

3、应用服务器,centos7(虚拟机),ip:192.168.119.134

java

2、jenkins流水线配置

在上一节:3.6-使用Jenkins、gitlab、sonar、testNG实现maven项目的自动化构建部署

的基础上,修改pipeline的流水线配置


代码为

node () {
def workspace = pwd()
  stage '拉取代码'
     git changelog: false, credentialsId: 'a4001502-71ca-442a-9b88-8dc408b2dc42', poll: false, url: 'http://192.168.119.133/Dev1/devopsplay.git'
  stage '编译代码'
        bat 'mvn compile'
  stage '运行单测 '
        bat 'mvn test'
    stage 'jacoco单测报告'
        jacoco()
    stage '打包 '
        bat 'mvn clean package -Dmaven.test.skip=true'
    stage 'sonar代码扫描'
      bat 'sonar-scanner'
  stage '部署到服务器'
  sshPublisher(publishers: [sshPublisherDesc(configName: 'devops演示项目应用服务器', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '''cd /home/devopsPlay
kill -9 $(lsof -i:9001 -t)
mv ./new/DevopsPlay-1.0-SNAPSHOT.jar DevopsPlay-1.0-SNAPSHOT.jar 
nohup /usr/local/java/bin/java -jar "/home/devopsPlay/DevopsPlay-1.0-SNAPSHOT.jar"> "/home/devopsPlay/log.txt" 2>&1 &
''', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: 'devopsPlay/new', remoteDirectorySDF: false, removePrefix: 'target', sourceFiles: '**/DevopsPlay-1.0-SNAPSHOT.jar')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
  stage 'rf自动化接口测试'
  sleep 10
  bat 'robot E:/devops/rf/InterfaceAutoTest.robot'
  stage 'rf自动化接口测试报告收集 '
  robot archiveDirName: 'robot-plugin', outputPath: 'E:\\devops\\rf', overwriteXAxisLabel: ''
  stage 'jmeter压测'
  bat 'jmeter -n -t E:/devops/jmeter/performance.jmx -l E:/devops/jmeter/performance.jtl'
  stage 'jmeter压测报告收集'
  perfReport filterRegex: '', sourceDataFiles: 'E:\\devops\\jmeter\\performance.jtl'
    stage 'fortify build'
    bat 'sourceanalyzer -b DevopsPlay -java-build-dir classes "src/**/*"'
    stage 'fortify scan'
    bat 'sourceanalyzer -b DevopsPlay -Xmx1250m -scan -f DevopsPlay.fpr'
    stage 'fortify 生成pdf报告'
    bat 'BIRTReportGenerator -template "Developer Workbook" -source DevopsPlay.fpr -format PDF -output DevopsPlay.pdf'
}

运行测试及说明

(1)拉取git代码:使用Jenkins流水线配置git生成pipeline语法;

(2)mvn compile :单独作为一个节点,若编译不过后续将不会执行;

(3)mvn test:运行单测,需要在工程里编写单测代码;

(4)jacoco():使用jacoco插件收集单测报告,这样的写法需要在pom文件里添加jacoco插件

(5)mvn clean package -Dmaven.test.skip=true:使用mvn打包,跳过单测

(6)sonar-scanner : sonar扫描命令,需要在工程目录下创建sonar.properties配置文件,配置sonar-scanner环境变量。

(7)sshPublisher:部署到服务器,将打好的部署包上传到应用服务器,并执行shell命令:先kill掉正在运行的服务进程,再启动服务。

(8)robot 脚本执行:执行robot的自动化测试脚本,jenkins所在服务器(本机)需安装python和robot framework环境。sleep 10 等待10秒是等应用完成部署。

(9)robot archiveDirName : 使用robot Jenkins插件,解析rf报告。

(10)jmeter脚本压测:执行jmeter脚本,对应用服务器进行压测。需配置jmeter环境变量。

(11)jmeter报告收集:perfReport filterRegex。使用jenkins performance插件解析jmeter报告,需配置jmeter环境变量。

(12-15)fortify代码审计:先执行fortify的build命令,产生一个build-id:DevopsPlay;然后扫描上一步生成的DevopsPlay;最后一步是将fpr报告通过BIRTReportGenerator命令转换为pdf报告。pdf报告可上传至文件服务器。

运行截图如下:

QQ截图20220710222039.png

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
19天前
|
jenkins 持续交付 开发者
自动化部署:使用Jenkins和Docker实现持续集成与交付
【8月更文挑战第31天】本文旨在为读者揭示如何通过Jenkins和Docker实现自动化部署,从而加速软件开发流程。我们将从基础概念讲起,逐步深入到实际操作,确保即使是初学者也能跟上步伐。文章将提供详细的步骤说明和代码示例,帮助读者理解并应用这些工具来优化他们的工作流程。
|
21天前
|
jenkins 持续交付 开发工具
jenkins学习笔记之一:流水线基础语法
jenkins学习笔记之一:流水线基础语法
|
19天前
|
持续交付 jenkins Devops
WPF与DevOps的完美邂逅:从Jenkins配置到自动化部署,全流程解析持续集成与持续交付的最佳实践
【8月更文挑战第31天】WPF与DevOps的结合开启了软件生命周期管理的新篇章。通过Jenkins等CI/CD工具,实现从代码提交到自动构建、测试及部署的全流程自动化。本文详细介绍了如何配置Jenkins来管理WPF项目的构建任务,确保每次代码提交都能触发自动化流程,提升开发效率和代码质量。这一方法不仅简化了开发流程,还加强了团队协作,是WPF开发者拥抱DevOps文化的理想指南。
39 1
|
21天前
|
jenkins 持续交付 网络安全
利用 Jenkins 实现持续集成与持续部署-代码拉取终端的配置
【8月更文挑战第30天】在Jenkins服务器中,git和Gitee是常用的代码拉取终端。Git作为分布式版本控制系统,具备出色的灵活性和可扩展性;而Gitee则在国内网络环境下表现更佳,适合团队协作。Git配置包括安装、设置用户信息及生成SSH密钥等步骤;Gitee配置也类似,需注册账号、创建仓库、配置基本信息并设置远程仓库地址。开发人员提交代码后,可通过Webhook、定时轮询或事件监听等方式触发Jenkins动作,确保持续集成和部署高效运行。正确配置这些触发机制并通过测试验证其有效性至关重要。
42 2
|
21天前
|
jenkins 测试技术 持续交付
利用 Jenkins 实现持续集成与持续部署(一)
【8月更文挑战第30天】Jenkins在软件开发中至关重要,其持续集成与部署功能极大提升了开发效率、保障了软件质量、增强了团队协作并加速了产品上市。实现这些功能前需搭建基础环境:配置合适的JDK版本、设置Git版本控制并准备好目标服务器。在Jenkins中创建新任务,详细配置源码管理、构建触发器(如定时构建或监听代码变更)、构建及部署步骤(如使用Maven编译打包、通过SSH插件或Docker部署)。这些关键配置确保了自动化流程的顺畅运行。
46 1
|
21天前
|
Java jenkins Shell
jenkins学习笔记之五:Maven、Ant、Gradl、Node构建工具集成
jenkins学习笔记之五:Maven、Ant、Gradl、Node构建工具集成
|
21天前
|
jenkins 持续交付
jenkins学习笔记之六:共享库方式集成构建工具
jenkins学习笔记之六:共享库方式集成构建工具
|
23天前
|
监控 jenkins 持续交付
|
27天前
|
Kubernetes jenkins 持续交付
在K8S中,Jenkins如何集成K8S集群?
在K8S中,Jenkins如何集成K8S集群?
|
16天前
|
jenkins 持续交付 网络安全
利用 Jenkins 实现持续集成与持续部署-代码拉取终端的配置
安装Git、配置用户信息、生成SSH密钥以及在Gitee上创建项目仓库等。
43 0