python使用jenkins发送企业微信通知的实现

作者:朝天椒的夏天 时间:2022-06-06 19:40:16 

如果只是想实现将jenkins的构建结果发送到企业微信进行通知,最简便的方式是安装Qy Wechat Notification Plugin插件,网上教程很多就不重复写了,可参考:

一、前言

最近使用Jenkins进行自动化部署,但是部署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于接收方的接收设置,导致不能及时看到相关的发布内容。而由于公司使用的是企业微信,因此考虑Jenkins通知企业微信机器人的实现方式。

二、使用企业微信推送的优势

实时提醒项目参与人员项目信息的更新情况

便于查看

三、配置

3.1 企业微信的配置

3.1.1 进入企业微信群

进入某个群 -> 右击群标签,添加群机器人
注意:企业微信貌似没有像钉钉那样设置配置群机器人权限,因此任何人都能添加机器人。相对于钉钉有点落后

3.1.2 填写机器人信息

python使用jenkins发送企业微信通知的实现

python使用jenkins发送企业微信通知的实现

企业微信的机器人相较于钉钉机器人而言,太简单了。

3.1.3 复制Hook地址

python使用jenkins发送企业微信通知的实现

注意:此处的Webhook将用于Jenkins当中的参数配置。

3.2 Jenkins的配置

3.2.1 安装插件

  • 进入系统管理

  • 进入管理插件

  • 搜索插件(Qy Wechat Notification)

python使用jenkins发送企业微信通知的实现

安装插件后返回首页

3.2.2 配置Webhook

  • 进入 Jenkins Job

  • 进入 Job 配置

  • 前往构建后的操作 -> 选择企业微信通知

python使用jenkins发送企业微信通知的实现

设置Webhook

python使用jenkins发送企业微信通知的实现

3.3测试

  • 选择立即构建

  • 构建

  • 企业微信接收消息-推送结果

python使用jenkins发送企业微信通知的实现

实现的效果如下:

python使用jenkins发送企业微信通知的实现

以下是实现可配置的企业微信通知

1.建企业微信群,添加群机器人,获取机器人的webhook地址

2.jenkins中创建项目,配置如下:

general下This project is parameterized,添加两个string parameter

python使用jenkins发送企业微信通知的实现

分别为企业微信机器人的webhook和项目异常时需通知的责任人

python使用jenkins发送企业微信通知的实现

用户默认值填对应企业微信群中的用户名,才可保证发通知时能够@到对应的人,多个用户名之间用英文逗号隔开

python使用jenkins发送企业微信通知的实现

填写构建执行命令

python使用jenkins发送企业微信通知的实现

构建命令说明如下:


#执行测试用例 pybot.bat 用例路径
#将控制台输出导出到log.txt文件,控制台不再打印日志 >log.txt
#如果前面一条指令执行失败才执行||后面的指令 ||
#如果前面一条指令执行成功才执行&&后面的指令 &&
#执行python脚本,发送企业微信通知,传入webhook地址,jenkins项目名称,发送通知@责任人 python ../wechatNotice.py %url% %JOB_NAME% %principal%

pybot.bat 目录名称/***.robot >log.txt || python ../wechatNotice.py %url% %JOB_NAME% %principal%

以上设置好,即可保存该项目

3.本次使用的是robot框架,测试用例运行完成后控制台输出的日志导出到log.txt文件如下

python使用jenkins发送企业微信通知的实现

根据导出的日志获取运行失败的测试用例标题


#GetCaseTitle.py
#通过控制台输出的日志查找是否有运行失败的用例,如有则获取失败用例的标题

class GetCaseTitle:
   def __init__(self):
       self.file = "log.txt"  #使用jenkins运行测试用例时,会将控制台输出的日志保存到log.txt文件

def get_fail_case_title(self):
       fail_case_line = []
       file = open(self.file, 'r', encoding='gbk')
       for line in file:  # 查找失败的用例行
           if "FAIL" in line:
               line = str(line).replace(" ", "")
               fail_case_line.append(line)
       file.close()

if len(fail_case_line)>0: #如果标记为失败的行数大于0
           fail_case_line = fail_case_line[:-1]  # 去掉最后1行的总运行结果行

fail_case_title = []
           for title in fail_case_line:  # 分别获取失败case的标题
               title = title.split('|')[0]
               if title not in fail_case_line[-1]:  # 判断当前是否是最后一个用例标题,是则后面不再添加|符号
                   fail_case_title.append(title + '  |  ')
               else:
                   fail_case_title.append(title)
           fail_case_title = ''.join(fail_case_title)
           return fail_case_title
       else:
           return 0

if __name__ == "__main__":
   GetCaseTitle().get_fail_case_title()

如存在运行失败的测试用例,则发送企业微信通知


#wechatNotice.py
#实现企业微信通知

import requests
import json
import urllib3
# import time
import sys
from GetCaseTitle import GetCaseTitle

urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)

class InformRobot:
   def __init__(self,url): #webhook地址
       self.url = url
       self.sess = requests.session()

def markdown_robot(self, report_url, principal, failcase):
       data = {
           "msgtype": "markdown",  # 消息类型,此时固定为markdown
           "markdown": {
               "content": "提醒!线上UI测试计划运行失败 \n" +
                          f"测试报告链接:[{report_url}]({report_url}) \n" +
                          f"负责人:@{principal}  \n"
                          f"失败用例名称:{failcase}"

}
       }

re_post = self.sess.post(self.url, data=json.dumps(data), verify=False)
       print(re_post.content, data)

if __name__ == "__main__":
   failcase = GetCaseTitle().get_fail_case_title()  #从GetCaseTitle.py获取执行失败的用例
   if failcase:   #如存在运行失败的用例则发送企业微信通知
       url=sys.argv[1]
       projectname = sys.argv[2]
       principal = sys.argv[3]
       # execute_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
       report_url = "http://172.18.1.1:8080/job/" + projectname + "/ws/log.html"
       InformRobot(url).markdown_robot(report_url, principal, failcase)
   else:
       print("测试通过")

发送通知的效果如下:

python使用jenkins发送企业微信通知的实现

来源:https://blog.csdn.net/qq_15158911/article/details/117406273

标签:python,企业微信,通知
0
投稿

猜你喜欢

  • Django 实现Admin自动填充当前用户的示例代码

    2021-12-23 17:37:26
  • 如何使用scrapy中的ItemLoader提取数据

    2021-01-10 07:02:06
  • asp中常用的字符串安全处理函数集合(过滤特殊字符等)

    2011-02-20 10:40:00
  • Python疫情数据可视化分析

    2022-05-22 05:09:15
  • js 判断一组日期是否是连续的简单实例

    2024-04-17 10:41:12
  • perl特殊符号及默认的内部变量

    2023-08-08 02:13:20
  • Python和Pycharm 环境部署详细步骤

    2022-09-25 02:25:45
  • JS将指定的某个字符全部转换为其他字符实例代码

    2023-08-28 21:01:01
  • 小程序开发之uniapp引入iconfont图标以及使用方式

    2024-04-22 13:09:05
  • document.all与WEB标准

    2008-03-16 14:28:00
  • SQL Server手工插入标识列的方法

    2024-01-27 05:41:35
  • python实现双人五子棋(终端版)

    2022-08-26 14:28:57
  • MySQL Server层四个日志的实现

    2024-01-21 11:16:58
  • Python cookbook(数据结构与算法)让字典保持有序的方法

    2022-04-28 03:28:04
  • pytorch sampler对数据进行采样的实现

    2023-02-09 20:05:40
  • 用SELECT... INTO OUTFILE语句导出MySQL数据的教程

    2024-01-13 19:50:52
  • Python列表list的详细用法介绍

    2021-04-17 06:56:15
  • 微信小程序 支付功能实现PHP实例详解

    2023-11-19 08:53:36
  • SQL Server 存储过程解析

    2024-01-21 22:41:01
  • JavaScript控制台的更多功能

    2024-02-24 12:46:42
  • asp之家 网络编程 m.aspxhome.com