jenkins html报告qps,使用jenkins pipeline,并发selenium测试 --- 你值得了解

一、契机

相信很多使用selenium进行UI测试,再对接jenkins时,都是简单的在jenkins上将命令输入就完事了。

但是,相信你一定会遇到以下问题:

1、你需要同时跑不同文件或不同类的用例,怎么处理?用selenium grid,但我仅仅是功能,不想去区分浏览器,并且代码中我也不想写grid?

2、在jenkins中并发,怎么将报告合并成一份?

3、用测试框架的并发插件,比如nose processes, pytest的xdist,都是在一台机器上,执行selenium 同时打开多个浏览器,你确保机器能受得了?

二、思路

带着以上几个问题,网上一直没有好的解决方法,普遍使用的是selenium grid,但相信很多人对grid都不喜欢

最近在看jenkins中的pipeline模式,发现其中有一个很好用的功能:parallel 并发,那就来用parallel来解决我们以上的问题

三、解决

jenkins的pipeline就不多介绍,看官网https://jenkins.io/doc/book/pipeline/就行,以后看时间会写写这方面的文章

1)先看看用Declarative方法写的并发parallel

a1afa63df1e8d0dfbf9cf31cefc75cb17e7.jpg

04ceb4958c598d3f90c90fb9af7948b5cbc.jpg

pipeline {

agent none

stages {

stage('Run Tests') {

parallel {

stage('Run_test1') {

agent {

label"10.3.208.151"}

steps {

script{

sh"sleep 20"}

}

}//-----------------------------------------------------------stage('Run_test2') {

agent {

label"10.3.208.151"}

steps {

script{

sh"sleep 10"}

}

}//-----------------------------------------------------------

//----------------------------------------------------------}

}

}

}

View Code

这么简单的一个并发脚本,看看执行时间,总的构建时长为23秒

fa9e424b54ca5eec508289dc901c299d.png

那有了这个基础后,我们将我们的在jenkins上执行selenium脚本全改成pipeline方式,按类或者按文件执行,这里就由你自己控制了。

2)问题一解决了,我们看看问题二,将报告合并

相信很多测试者生成的报告有很多种,有xml格式的,有html格式的,有用allure生成的。这里我们介绍xml和allure格式的,因为html格式的还要自己写合并程序,太麻烦

1,   xml方式的,在jenkins上会直接生成TestReport,所以这个很好处理,只需要在pipeline中的每个stage中用post将 xml发布,如下

post {

always {

junit'acl.xml'}

}

2,  allure方式的,这个我们了解下allure原理,allure是将本地的生成的xml文件最后用allure命令生成报告的,所以我们的难点是怎么拿到在不同机器上的文件,然后再放在一台机器上,最后生成报告。

还好,pipeline有一个stash的方式,是在构建后将文件存在master上,给后续的job使用,后续的job再用unstash拿到

所以我们可以在每个stage中这么写

stash includes: 'allure-results\\*', name: 'xxxxx'

将报告存起来,名字叫xxxx

然后我们在parallel并发的stage外再起一个stage,拿到文件,最后生成报告,如下

stage('Report') {

agent {

label"master"}

steps {

unstash'xxxxxx'unstash'xxxxxx2'}

post {

always {

allure includeProperties: false, jdk:'', results: [[path: 'allure-results']]

}

}

}

完美解决

3)  任务的并发限制

如果你想控制你的并发数量,可以有两种方式实现

1,用节点的executors来限制

好了,基本解决方案已实现,但实际落地,还需要学习很多。比如jenkins中pipeline的各种使用方法,过程中的各种坑。有问题大家可以留言。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值