jenkins使用python脚本发送企业微信通知
生活随笔
收集整理的這篇文章主要介紹了
jenkins使用python脚本发送企业微信通知
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
如果只是想實現將jenkins的構建結果發送到企業微信進行通知,最簡便的方式是安裝Qy Wechat Notification Plugin插件,網上教程很多就不重復寫了,可參考:https://www.cnblogs.com/jianxuanbing/archive/2019/09/04/11459972.html
實現的效果如下:
以下是實現可配置的企業微信通知
1.建企業微信群,添加群機器人,獲取機器人的webhook地址
2.jenkins中創建項目,配置如下:
general下This project is parameterized,添加兩個string parameter
分別為企業微信機器人的webhook和項目異常時需通知的責任人
用戶默認值填對應企業微信群中的用戶名,才可保證發通知時能夠@到對應的人,多個用戶名之間用英文逗號隔開
填寫構建執行命令
構建命令說明如下:
#執行測試用例 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文件如下
根據導出的日志獲取運行失敗的測試用例標題
#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: #如果標記為失敗的行數大于0fail_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_titleelse:return 0if __name__ == "__main__":GetCaseTitle().get_fail_case_title()如存在運行失敗的測試用例,則發送企業微信通知
#wechatNotice.py #實現企業微信通知import requests import json import urllib3 # import time import sys from GetCaseTitle import GetCaseTitleurllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)class InformRobot:def __init__(self,url): #webhook地址self.url = urlself.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("測試通過")發送通知的效果如下:
總結
以上是生活随笔為你收集整理的jenkins使用python脚本发送企业微信通知的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【实习之路】在广州欢聚时代入职的第一天
- 下一篇: 51nod1693 水群