继续集成jenkins+allure+pytest+python邮件发送(报告截图selenium实现)+python钉钉机器人通知

简介: 继续集成jenkins+allure+pytest+python邮件发送(报告截图selenium实现)+python钉钉机器人通知

实现思路

'''
0.邮件和钉钉都要在自动化执行完成后再去执行,不然拿到的数据和报告就不是最新的(重点)
1.由于报告是在线展示,我这是本地,就使用selenium去登录截图2个报告的页面,也可以截更多。保存到本地
2.通过邮箱发送截图附件实现邮箱发送报告
3.jenkins下拉代码会储存到工作空间,工作空间保存到本地,找到报告的数据文件查看是否有可以统计测试结果的
4.把原始的报告数据文件加以处理发送钉钉机器人
'''


报告截图

'''获取jenkins报告截图基于selenium'''
import math
from selenium import webdriver
from time import sleep
def ctrl_alt():
    def driver_(test=1):
        if test == 1:
            # 后台运行浏览器,不打开,但是这样打开截图不全,暂时没解决,使用的是打开浏览器的方式,用Jenkins运行时是无痕的,非常到位
            chrome_options = webdriver.ChromeOptions()
            chrome_options.add_argument('--headless')
            driver = webdriver.Chrome(chrome_options=chrome_options)
        else:
            # 启动浏览器
            driver = webdriver.Chrome()
        return driver
    driver = driver_(2)
    driver.get('http://127.0.0.1:1111/login?from=%2F')
    driver.maximize_window()
    a = driver.find_elements_by_class_name('normal')
    a[0].send_keys('lcf')  # 账号
    a[1].send_keys(123456)  # 密码
    driver.find_element_by_class_name('submit-button').click()  # 登录
    # 报告页面1
    print('截图开始')
    driver.get('http://127.0.0.1:1111/job/%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95-gitee%E4%BB%A3%E7%A0%81/allure/')
    sleep(1)
    driver.get_screenshot_as_file(r'F:\jb\baogao.png')  # 截图操作
    # 报告页面2
    driver.get('http://127.0.0.1:1111/job/%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95-gitee%E4%BB%A3%E7%A0%81/allure/#graph')
    sleep(1)
    driver.get_screenshot_as_file(r'F:\jb\baogao1.png')
    print('截图结束')
    driver.quit()

邮箱发送

没啥好说的,代码在网上找的,能用,需要使用qq邮箱发送的话配置server = smtplib.SMTP(‘smtp.qq.com’) ,好像是这样

现在代码里是server = smtplib.SMTP(‘smtp.163.com’)

'''发送本地allure报告图片邮件'''
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.image import MIMEImage
from email.mime.application import MIMEApplication
from allure_dd import ctrl_alt
# 配置邮箱信息
ctrl_alt()#截图
sender = 'xxxx@163.com'  # 发件人的地址
password = 'KWKYGKdfdsfOBH'  # 此处是我们刚刚在邮箱中获取的授权码
receivers = '666666@qq.com'  # 邮件接受方邮箱地址,可以配置多个,实现群发,注意这里要是字符串
# 邮件内容设置
content = MIMEText("<html><h2>测试报告,误回复</h2>", _subtype="html", _charset="utf-8")
msg = MIMEMultipart('related')
msg.attach(content)
# 添加图片附件
imageFile = r"F:\jb\baogao.png"
imageApart = MIMEImage(open(imageFile, 'rb').read(), imageFile.split('.')[-1])
imageApart.add_header('Content-Disposition', 'attachment', filename=imageFile)
msg.attach(imageApart)
imageFile = r"F:\jb\baogao1.png"
imageApart = MIMEImage(open(imageFile, 'rb').read(), imageFile.split('.')[-1])
imageApart.add_header('Content-Disposition', 'attachment', filename=imageFile)
msg.attach(imageApart)
# 邮件标题设置
msg['Subject'] = 'python发送附件测试-图片、Excel'
# 发件人信息
msg['From'] = sender
# 收件人信息
msg['To'] = receivers
# 通过授权码,登录邮箱,并发送邮件
try:
    server = smtplib.SMTP('smtp.163.com')  # 配置网易邮箱的smtp服务器地址
    server.login(sender, password)
    server.sendmail(msg['From'], msg['To'].split(','), msg.as_string())
    print('发送成功')
    server.quit()
except smtplib.SMTPException as e:
    print('error', e)

邮箱发送结果


钉钉机器人发送测试结果

现在钉钉机器人不支持发送本地图片,暂时先不发送报告图片到钉钉

'''发送接口测试信息推送钉钉消息'''
import csv
import json
import requests
a=[]
#这是jenkins拉下来代码的存放位置,构建时产生的测试结果信息文件
f = csv.reader(open(r'C:\Users\keking\AppData\Local\Jenkins\.jenkins\workspace\自动化测试-gitee代码\allure-report\data\suites.csv','r',encoding='UTF8'))
for i in f:
    if i[0]!='Status':
        a.append(i)
print(a)
#对原始数据坐下处理
api_run_count=len(a)
api_passed_count=0
api_failed_count=0
failed_case_name=[]
failed_case_path=[]
for i in a:
    if i[0]=='passed':
        api_passed_count+=1
    elif i[0]=='failed':
        failed_case_path.append(i[1])
        failed_case_name.append(i[3])
        api_failed_count+=1
print(api_passed_count)
print(api_failed_count)
print(failed_case_name)
print(failed_case_path)
def dd_robot():
  HEADERS = {"Content-Type": "application/json;charset=utf-8"}
  key = "b7ff3fd2fd9b2dc5f78xxxxxxxxxxxxx0ff1056d172d922cab"
  url = f" https://oapi.dingtalk.com/robot/send?access_token={key}"
  #content里面要设置关键字 我机器人设置的关键字为'接口测试结果:'
  data_info = {
    "msgtype": "text",
    "text": {
    "content": "接口测试结果:"+f'\n总共运行{api_run_count}条用例'
               + f'\n成功{api_passed_count}条用例'
               + f'\n失败{api_failed_count}条用例'
               + f'\n失败用例名称{str(failed_case_name)}'
               + f'\n失败用例地址{str(failed_case_path)}'
    },
    "isAtAll": False
    #这是配置需要@的人
     # ,"at": {"atMobiles": ["15xxxxxx06",'18xxxxxx1']}
  }
  value = json.dumps(data_info)
  response = requests.post(url,data=value,headers=HEADERS)
  if response.json()['errmsg']!='ok':
    print(response.text)
if __name__ == '__main__':
    dd_robot()

我看过报告下的一些文件信息,这个文件的信息可以用来统计

suites.csv文件信息

结构

信息

发送结果


jenkins配置运行python钉钉、邮件脚本

配置邮件发送(重点构建结束触发另一个任务构建)

新建一个任务

配置指定另一个任务构建完成后执行当前任务的构建

配置钉钉发送

除了脚本文件不同其他都不一样

邮箱和钉钉子任务运行

测试

通过修改用例错误数来看邮件失败用例和钉钉的失败用例数是否变化

每次构建自动化测试后会自动构建发送邮箱的任务,实现发邮箱钉钉,结束

3天的学习成果,就是干

相关文章
|
2月前
|
数据采集 Web App开发 存储
打造高效的Web Scraper:Python与Selenium的完美结合
本文介绍如何使用Python结合Selenium,通过代理IP、设置Cookie和User-Agent抓取BOSS直聘的招聘信息,包括公司名称、岗位、要求和薪资。这些数据可用于行业趋势、人才需求、企业动态及区域经济分析,为求职者、企业和分析师提供宝贵信息。文中详细说明了环境准备、代理配置、登录操作及数据抓取步骤,并提醒注意反爬虫机制和验证码处理等问题。
打造高效的Web Scraper:Python与Selenium的完美结合
|
6月前
|
Web App开发 前端开发 JavaScript
探索Python科学计算的边界:利用Selenium进行Web应用性能测试与优化
【10月更文挑战第6天】随着互联网技术的发展,Web应用程序已经成为人们日常生活和工作中不可或缺的一部分。这些应用不仅需要提供丰富的功能,还必须具备良好的性能表现以保证用户体验。性能测试是确保Web应用能够快速响应用户请求并处理大量并发访问的关键步骤之一。本文将探讨如何使用Python结合Selenium来进行Web应用的性能测试,并通过实际代码示例展示如何识别瓶颈及优化应用。
320 5
|
6月前
|
前端开发 JavaScript UED
探索Python Django中的WebSocket集成:为前后端分离应用添加实时通信功能
通过在Django项目中集成Channels和WebSocket,我们能够为前后端分离的应用添加实时通信功能,实现诸如在线聊天、实时数据更新等交互式场景。这不仅增强了应用的功能性,也提升了用户体验。随着实时Web应用的日益普及,掌握Django Channels和WebSocket的集成将为开发者开启新的可能性,推动Web应用的发展迈向更高层次的实时性和交互性。
173 1
|
2月前
|
Web App开发 数据采集 数据安全/隐私保护
Selenium库详解:Python实现模拟登录与反爬限制的进阶指南
Selenium库详解:Python实现模拟登录与反爬限制的进阶指南
|
5月前
|
数据采集 Web App开发 前端开发
Python爬虫进阶:Selenium在动态网页抓取中的实战
【10月更文挑战第26天】动态网页抓取是网络爬虫的难点,因为数据通常通过JavaScript异步加载。Selenium通过模拟浏览器行为,可以加载和执行JavaScript,从而获取动态网页的完整内容。本文通过实战案例,介绍如何使用Selenium在Python中抓取动态网页。首先安装Selenium库和浏览器驱动,然后通过示例代码展示如何抓取英国国家美术馆的图片信息。
304 6
|
6月前
|
数据采集 Web App开发 数据可视化
Python爬虫教程:Selenium可视化爬虫的快速入门
Python爬虫教程:Selenium可视化爬虫的快速入门
|
6月前
|
SQL 机器学习/深度学习 数据库
SQL与Python集成:数据库操作无缝衔接
在开始之前,确保你已经安装了必要的Python库,如`sqlite3`(用于SQLite数据库)或`psycopg2`(用于PostgreSQL数据库)。这些库提供了Python与SQL数据库之间的接口。
|
6月前
|
测试技术 数据安全/隐私保护 开发者
自动化测试的奥秘:如何用Selenium和Python提升软件质量
【9月更文挑战第35天】在软件开发的海洋中,自动化测试是那艘能引领我们穿越波涛的帆船。本文将揭开自动化测试的神秘面纱,以Selenium和Python为工具,展示如何构建一个简单而强大的自动化测试框架。我们将从基础出发,逐步深入到高级应用,让读者能够理解并实现自动化测试脚本,从而提升软件的质量与可靠性。
|
7月前
|
Web App开发 测试技术 持续交付
自动化测试的利器:Selenium与Python的完美结合
【9月更文挑战第21天】在软件开发的世界里,测试是确保产品质量的关键步骤。随着敏捷开发和持续集成的流行,自动化测试工具变得尤为重要。本文将介绍如何使用Selenium和Python进行高效的自动化测试,不仅提供代码示例,还深入探讨如何设计测试用例、选择正确的测试框架、以及如何整合到CI/CD流程中。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧。
106 3
|
6月前
|
SQL 机器学习/深度学习 数据采集
SQL与Python集成:数据库操作无缝衔接2a.bijius.com
Python与SQL的集成是现代数据科学和工程实践的核心。通过有效的数据查询、管理与自动化,可以显著提升数据分析和决策过程的效率与准确性。随着技术的不断发展,这种集成的应用场景将更加广泛,为数据驱动的创新提供更强大的支持。

热门文章

最新文章