zoukankan      html  css  js  c++  java
  • 利用Jenkins插件实现多个job并行后再触发job

    前言

    在利用Jenkins来自动执行自动化脚本,有时因某些原因,或者为了提高用例运行效率,可能需要创建多个job来同时跑脚本。

    比如我之前接触过用Jenkins来跑 Robot Framework 的自动化脚本,因为用例太多了,于是考虑创建多个job并行跑,而 Robot Framework 中恰好有个合并报告 rebot 的功能,于是当多个job跑完后,便可将各个job的报告合并,最后就得到了一个最终的报告结果。

    但创建了多个job后,我们可能不知道每个job要多久才能执行完,这样我们就不容易拿到合并后的报告,同时也不太好确定如何及时的将报告结果通过邮件发送给他人,后来在网上找到了Jenkins的一个插件,它很好的解决了我遇到的问题。

    安装 Join 插件

    这是一个触发job的插件,它可以设置等待当前job的所有下游job都执行完后,再触发另一个job,有了它便可以很好的处理上面的问题。

    在Jenkins控制台,进入系统管理->插件管理->可选插件,搜索 Join 找到该插件进行安装。

    安装Join插件

    安装成功

    安装完成后,也可以在已安装列表中找到该插件。

    已安装列表

    使用 Join 插件

    在运用 Join 插件时,一般在当前job有多个下游的job时才能体现它的意义。因此,创建多个job并设计如下场景:

    job A:最开始触发的job,它的下游是B1、B2
    job B1:运行部分用例,与B2并行跑
    job B2:运行部分用例,与B1并行跑
    job C:等待A、B1、B2都跑完后,才会被触发。

    job A 中,做如下配置:

    构建后步骤

    job A配置步骤

    在构建后操作步骤,选择 Join Trigger 时,如果发现点了没反应,可以尝试下再多安装另一个插件: Parameterized Trigger,该插件的作用是使各个job连接的时候可以传递一些job相关的信息。安装之后最好重启Jenkins,然后配置job时再点击Join Trigger 就发现正常了。

    安装Parameterized Trigger插件

    job B1/B2 ,用于执行用例,按实际情况设置即可。

    job C ,在其他Job都执行完后才触发,可用于汇总报告结果及发送邮件。

    以上设置完成后,当job A触发构建执行完后,其下游的 job B1/B2 开始并行跑,当 job B1/B2 都执行完,由耗时久的那个job通知并触发构建 job C ,由 job C 执行合并报告操作,并发送邮件。

  • 相关阅读:
    python学习笔记十五-生成器
    python学习笔记十四-迭代器
    python学习笔记十三-装饰器
    The Zen of Python, by Tim Peters
    python学习笔记十二-函数
    python学习笔记十一-集合set
    tensorflow2 gpu 在 win10 上安装过程和问题处理
    anaconda navigator stuck 卡在 loading applications... 处理
    python工具pip加速For windows
    WCF With StructureMap
  • 原文地址:https://www.cnblogs.com/wintest/p/12212430.html
Copyright © 2011-2022 走看看