Jenkins Environment Injector Plugin 插件详解

2024-09-02 05:52

本文主要是介绍Jenkins Environment Injector Plugin 插件详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引言

在做自动化测试的过程中,我们需要经常发送测试报告给相关研发、产品和上级,但是Jenkins邮件模板不支持Javascritpt脚本来动态生成数据,只支持静态的HTML代码,那么我们就没有办法了吗?非也,我们可以通过环境变量注入的方式读取外部的数据进行引用从而实现报告数据的真实性和实时性,下面将详细介绍Jenkins环境变量注入插件Environment Injector Plugin的使用。

安装插件Environment Injector Plugin

进入Jenkins插件管理页面可用插件页面搜索Environment Injector Plugin进行安装,安装后记得重启Jenkins服务。
在这里插入图片描述

查看插件展示

新建一个Jenkins Job后就能在构建环境选项中看到Environment Injector Plugin插件相关选项,如下图:
在这里插入图片描述

Environment Injector Plugin配置

勾选將環境變量注入構建過程,则会要求我们提供一个配置文件路径,如下:

在这里插入图片描述
文件格式需为Java .properties文件格式,格式如下:

TOTAL=223
PASSED=0
DESELECTED=0
SKIPPED=0
FAILED=30
ERROR=0
SUCCESSFUL=0.00%
TOTAL_TIMES=42m 36s
EXECUTE_TIME=2023-12-18 12:56:04

下面是小编配置的路径,读者请根据自身实际路径进行配置:
在这里插入图片描述
result.txt中的内容是每次测试运行时动态写入的数据,这样每次这个文件的数据都是动态生成的,然后使用 Environment Injector Plugin进行数据读取引用到Jenkins邮件模板中就能在报告中显示实时的动态数据了。

假设result.txt文本文件中的内容如下;

TOTAL=223
PASSED=0
DESELECTED=0
SKIPPED=0
FAILED=30
ERROR=0
SUCCESSFUL=0.00%
TOTAL_TIMES=42m 36s
EXECUTE_TIME=2023-12-18 12:56:04

注意:result.txt中的数据都是静态数据,是代码动态计算后写入的结果数据,Jenkins 测试报告中不会根据数据进行二次计算,只对数据进行引用。

邮件报告模板

jenkins邮件模板
<h1 style="text-align:center;font-family:arial;color:red;font-size:20px;">以下是Jenkins自动发送的邮件,请勿回复!</font><center></h1><hr><p style="text-align:left">项目名称:$PROJECT_NAME</p >
<p style="text-align:left">场景描述:</p ><p style="text-align:left">见此链接</p ><hr><p style="text-align:left">构建地址:$BUILD_URL</p >
<p style="text-align:left">测试环境:${excute_env}</p >
<p style="text-align:left">构建状态:$BUILD_STATUS</p ><p style="text-align:left">触发原因:${CAUSE}</p ><tr style="text-align:left"><p id="result" style="text-align:left">测试结果:</p ><td style="text-align:left">
<p style="text-align:left">
<span>用例总数:${TOTAL}  
</span><span style="color:green">成功:${PASSED}</span>
<span style="color:red">失败:${FAILED}</span> 
<span style="color:orange">异常:${ERROR}</span> 
<span style="color:gray">跳过:${SKIPPED}</span>
<span style="color:gray">未选择:${DESELECTED}</span> 
</p >
<p id='summry' style="text-align:left">运行成功率:${SUCCESSFUL}  运行时长:${TOTAL_TIMES}  执行时间:${EXECUTE_TIME}</p ></td></tr><p style="text-align:left">测试报告:${PROJECT_URL}${BUILD_NUMBER}/allure</p ><hr>

字段解释

  • Jenkins系统变量
    项目名称:$ PROJECT_NAME
    项目地址:$ {PROJECT_URL}
    构建编号: $ {BUILD_NUMBER}
    构建地址:$ BUILD_URL
    构建状态:$ BUILD_STATUS
    触发原因:$ {CAUSE}

  • 自定义变量
    测试环境:$ {excute_env}
    用例总数:$ {TOTAL}
    成功:$ {PASSED}
    失败:$ {FAILED}
    异常:$ {ERROR}
    跳过:$ {SKIPPED}
    未选择:$ {DESELECTED}
    运行成功率:$ {SUCCESSFUL}
    运行时长:$ {TOTAL_TIMES}
    执行时间:$ {EXECUTE_TIME}

上面的系统变量是Jenkins自带的不需要另外定义,自定义变量读者可以根据自己的需要进行定义然后写入到properties文件中(result.txt)

邮件推送配置

由于小编之前已经配置好了邮件推送的默认设置,所以Jenkins系统配置里已经有默认的邮箱推送人了,所以不需要额外配置邮件推送人,另外如果之前没有配置过Jenkins邮件推送,Jenkins Job是无法进行邮件推送的,详细邮件推送配置可以参考小编之前的文章:Jenkins邮件推送配置,这里小编就不赘述了。

配置构建完成邮件推送

在Job构建后操作中选择发送邮件,注意选择第二个 Editable Email,这个可以自定义邮件模板。
在这里插入图片描述

配置邮件内容类型

需要在邮件类型选项Content Type设置为Html选项的,小编设置的最后一项,Both HTML and Plain Text
在这里插入图片描述

配置邮件内容

选择后在邮件选项Default Content中引用上述邮件模板:
在这里插入图片描述
然后应用配置并保存。
在这里插入图片描述
我们也可以看一下在没有引用变量下邮件报告的显示,如下:
在这里插入图片描述

邮件报告预览效果

我们运行下Job看下实际的效果:

如果邮件配置中content type设置的非HTML则 邮件接收到后是HTML代码,如下:
在这里插入图片描述
可以看到邮件中虽然格式不对,但是我们result.txt中的数据是引用到了,这样我们的,目的就达成了。
我们正确设置content type后的效果如下:
在这里插入图片描述
由于小编实际上有些变量没有定义,如测试环境:${excute_env},因为实际在测试过程中我们有很多测试环境,这个小编在Jenkins参数化构建文章中有提到,感兴趣的小伙伴可以看看。

总结

通过本文相信读者能够熟练掌握Jenkins Environment Injector Plugin插件的相关用法,能在推送邮件测试报告数据上更游刃有余。

这篇关于Jenkins Environment Injector Plugin 插件详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129172

相关文章

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

mac中资源库在哪? macOS资源库文件夹详解

《mac中资源库在哪?macOS资源库文件夹详解》经常使用Mac电脑的用户会发现,找不到Mac电脑的资源库,我们怎么打开资源库并使用呢?下面我们就来看看macOS资源库文件夹详解... 在 MACOS 系统中,「资源库」文件夹是用来存放操作系统和 App 设置的核心位置。虽然平时我们很少直接跟它打交道,但了

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

Rust 数据类型详解

《Rust数据类型详解》本文介绍了Rust编程语言中的标量类型和复合类型,标量类型包括整数、浮点数、布尔和字符,而复合类型则包括元组和数组,标量类型用于表示单个值,具有不同的表示和范围,本文介绍的非... 目录一、标量类型(Scalar Types)1. 整数类型(Integer Types)1.1 整数字

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

PyTorch使用教程之Tensor包详解

《PyTorch使用教程之Tensor包详解》这篇文章介绍了PyTorch中的张量(Tensor)数据结构,包括张量的数据类型、初始化、常用操作、属性等,张量是PyTorch框架中的核心数据结构,支持... 目录1、张量Tensor2、数据类型3、初始化(构造张量)4、常用操作5、常用属性5.1 存储(st

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Python在固定文件夹批量创建固定后缀的文件(方法详解)

《Python在固定文件夹批量创建固定后缀的文件(方法详解)》文章讲述了如何使用Python批量创建后缀为.md的文件夹,生成100个,代码中需要修改的路径、前缀和后缀名,并提供了注意事项和代码示例,... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5.