Pytest-测试报告发送到钉钉群

文章介绍了如何在pytest接口自动化测试结束后,通过钉钉自定义机器人将测试报告发送到指定的钉钉群。主要步骤包括获取webhook地址,设置自定义关键词,在代码中添加发送请求的逻辑,并在pytest的钩子函数中调用。最后,验证发送的报告是否准确。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

记录一下pytest接口自动化结束后,将测试报告发送到钉钉群。

第一步:当然是在群里添加钉钉自定义机器人
在这里插入图片描述
添加时最重要的是 webhook地址(发送消息的请求链接信息)、自定义关键词(发送消息内容必须包含关键词才能发送)

具体可以查看官方的介绍文档

https://open.dingtalk.com/document/robots/custom-robot-access/

第二步:在代码中添加发送钉钉消息的请求
直接上代码,很简单
由于该接口测试框架是集成Jenkins,以BUILD_TAG命名文件夹存每次测试的报告

def send_dingtalk_message(BUILD_TAG):
    '''
    :param BUILD_TAG: 
    :return: 
    '''
   	#获取Jenkins项目名称
    JOB_NAME = basedir2.split("/")[-1]
    #获取Webhook的token
    dingtalk_Webhook = ReadConfig().get_config(file_name=Get_project_path('test_case_config'), section='ENV', option='dingtalk_Webhook')
    logger.write_msg(INFO,"开始发送测试报告到钉钉")
	#测试结果HTML报告链接
    html_report=f'http://jks.qa.xxx.com/job/xxx/view/All/job/{JOB_NAME}/ws/report/{BUILD_TAG}/report.html'
    #读取测试结果文案
    path = basedir2 + '/report/result.txt'
    if os.path.exists(path):
        pass
    else:
        print(" %s 文件不存在" % path)
        exit(0)
    with open(file=path,encoding='utf-8',mode='r') as fp:
        result = fp.read()
	#发送的内容必须包含机器人设置的关键字
    cont = "接口自动化已完成,查看结果\n"+result+"\n"+f"测试报告链接:{html_report}"  # 这里要包含新增机器人时候“安全设置”里的关键字,这里是“自动化测试”
    dates = {
        "msgtype": "text",
        "text": {
            "content": cont
        }
    }
    url = f"https://oapi.dingtalk.com/robot/send?access_token={dingtalk_Webhook}" # 输入上面生成的Webhook地址
    headers = {
        'Content-Type': 'application/json'
    }
    #发送请求
    res = requests.post(url=url,data=json.dumps(dates),headers=headers)
    logger.write_msg(INFO,res.json())

发送钉钉消息是用pytest的钩子函数 pytest_terminal_summary,收集测试结果后直接发送

def pytest_terminal_summary(terminalreporter):
    """
    收集测试结果
    """
    metadata = terminalreporter._session
    logger.write_msg(INFO, metadata.config._metadata)
    if 'BUILD_TAG' in metadata.config._metadata.keys():
        logger.write_msg(INFO, f"build_tag={metadata.config._metadata['BUILD_TAG']}")
        BUILD_TAG = metadata.config._metadata['BUILD_TAG']
        send_dingtalk_message(BUILD_TAG)

第三步:验证钉钉发送的报告是否准确
在这里插入图片描述

### Grafana 集成 Zabbix 并配置 Email 与钉钉告警 Grafana 是一个开源的可视化监控工具,支持多种数据源(如 Prometheus、Zabbix、InfluxDB 等)。Zabbix 是一款成熟的 IT 基础设施监控系统,具备强大的告警机制。要将 Zabbix 与 Grafana 进行集成,并在 Grafana 中配置 Email 和钉钉告警,需完成以下关键步骤: #### 1. 安装 Grafana 并集成 Zabbix 数据源 首先确保已安装 Grafana,并添加 Zabbix 插件以支持其数据源。 - 使用 `grafana-cli` 安装 Zabbix 插件: ```bash grafana-cli plugins install alexanderzobnin-zabbix ``` - 重启 Grafana 服务以应用插件: ```bash systemctl restart grafana-server ``` - 登录 Grafana Web UI,进入 **Configuration > Data Sources > Add data source**。 - 选择 **Zabbix datasource**,并填写 Zabbix Server 的 API 地址(如:`http://zabbix.example.com/api_jsonrpc.php`)、用户名和密码。 - 保存并测试连接,确保成功获取 Zabbix 监控数据[^1]。 #### 2. 配置 Grafana 的 Email 告警通知渠道 Grafana 内置了告警引擎,可以基于面板或数据源触发告警并通过 Email 发送- 在 Grafana Web UI 中,进入 **Alerting > Notification channels > Add channel**。 - 选择 **Email** 类型,填写 SMTP 邮件服务器地址、端口、发件人邮箱及收件人列表。 - 可设置自定义标题和内容模板,使用 Go 模板语法进行格式化。 - 测试邮件通知是否正常发送。 示例 SMTP 配置(位于 `conf/grafana.ini`): ```ini [smtp] enabled = true host = smtp.example.com:587 user = [email protected] password = your_password from_address = [email protected] ``` #### 3. 配置 Grafana 的钉钉告警通知渠道 通过 Webhook 接入钉钉机器人实现告警推送。 -钉钉群中创建自定义机器人,获取 Webhook URL。 - 在 Grafana 的 **Notification channels** 中新增类型为 **Webhook** 的通知渠道。 - 设置 Webhook URL 为钉钉机器人的地址。 - 自定义消息体格式,例如使用 JSON 格式发送 Markdown 消息: ```json { "msgtype": "markdown", "markdown": { "title": "Grafana Alert", "text": "## {{ .Status | title }}: {{ .RuleName }}\n{{ .Message }}\n[查看详情]({{ .RuleUrl }})" } } ``` - 测试 Webhook 是否能成功发送钉钉消息[^3]。 #### 4. 创建告警规则并绑定通知策略 - 在 Grafana Dashboard 中编辑面板,切换到 **Alert** 选项卡。 - 设置阈值条件(如 CPU 使用率 > 90% 超过 5 分钟)。 - 选择通知频道(Email 或钉钉),并设置重复告警间隔。 - 保存面板后,Grafana 将自动评估告警状态并在触发时发送通知。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值