【python】向Jira测试计划下,附件中增加html测试报告

news2025/5/13 11:34:23

【python】连接Jira获取token以及jira对象

# 往 jira 测试计划下面,上传测试结果html
def put_jira_file(plain_id):
    # 配置连接jira
    conn = ConnJira()
    jira = conn.jira_login()[2]
    path = jira.issue('O45-' + plain_id)
    attachments_dir = os.path.abspath('..') + '\\test_API\\reports'

    # 遍历目录下所有文件并上传
    for filename in os.listdir(attachments_dir):
        if filename.startswith('.'):
            continue  # 忽略隐藏文件

        file_rule = plain_id + '.html'
        if filename.endswith(file_rule):
            file_path = os.path.join(attachments_dir, filename)
            if os.path.isfile(file_path):
                with open(file_path, 'rb') as file:
                    # 上传附件
                    jira.add_attachment(issue=path, attachment=file, filename=filename)
                    print(f'Attachment {filename} uploaded successfully.')

python 向jira测试用例下,自动化栏,写入自动化测试脚本路径

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2025-02-10 14:15
# @Author  : duxiaowei
# @File    : put_filename_jira.py
# @Software: 这个文件是 : 往jira用例中,添加自动化脚本路径的
#             路径都添加到对应的 jira 号下面的,自动化一栏中


from urllib.parse import urlencode

import requests

from com.connect_jira import ConnJira
from com.connect_mysql import DBmysql
from com.connect_sqllite import DBlite

from com.get_filename import insert_pytest_ready

# 配置连接jira
conn = ConnJira()
cookie, jira_server, jira = conn.jira_login()

"""
automationIdentifier: 自动化备注信息,需要写入,自动化脚本文件路径
tcIssueId: 数据库查出来对应的 jiraissue 中 ID
"""


def put_自动化备注(automationIdentifier, tcIssueId):
    url = jira_server + "/rest/synapse/1.0/testCase/saveAutomationTestIdentifier"
    params = {
        "automationIdentifier": automationIdentifier,
        "tcIssueId": tcIssueId
    }
    payload = {}
    headers = {'Cookie': cookie}
    full_url = url + '?' + urlencode(params)
    # print(full_url)
    response = requests.request("PUT", full_url, headers=headers, data=payload)
    if response.status_code == 200:
        print("推送成功!自动化测试文件推送到对应用例编号下")
    else:
        print("推送失败!自动化测试文件名称,推送失败!")


# 查询mysql数据库,找到对应jiraissue,表中ID,用于传参
def get_jiraissue_ID(issueID):
    select_query = "select ID from jira.jiraissue where issuenum=%s"
    arg = []
    arg.append(issueID)
    try:
        result_mysql = DBmysql().select(select_query, arg)
        return str(result_mysql[0][0])
    except Exception:
        return ""


# 这两个字段,来自sqllite数据库
# issueID = "6050"
# name = ':test_API:testcases:场外:O45_6060&6061&6062_IB_bond_buy_shougong_test.py'
def jira_remark():
    ready_result = DBlite().select(
        "select filename,jira_num,number from pytest_ready where jira_num !='' order by updatetime desc")
    for i in ready_result:
        # 文件名替换字符串
        content = i[0].replace('\\', ':')
        content = content.replace('&', ':')
        print(content)
        issueID = i[1]
        number = i[2]
        # 通过sqllite数据库中,issueID,去查询mysql对应的issue表ID列
        mysql_id = get_jiraissue_ID(issueID)
        # print(mysql_id)
        if mysql_id != "":
            # 推送到,自动化备注
            put_自动化备注(content, mysql_id)
            # 记录推送次数
            sql_update = "update pytest_ready set number=? where jira_num=?"
            number = number + 1
            arg = (number, issueID)
            DBlite().change(sql_update, arg)

# # 需要将jira_remark()放到conftest中,目前每次都会去put一遍,number字段,用于推送记录次数,推送之前最好,拉一下pytest文件到数据
# # 如果一个 jira号下有两个脚本文件,只记录,第一次的那个,这块还需要优化
# insert_pytest_ready()
# jira_remark()

涉及到一个表pytest_ready

create table pytest_ready
(
	id INTEGER
		primary key autoincrement,
	filename VARCHAR(100),
	jira_num VARCHAR(20),
	updatetime TIMESTAMP,
	createtime TIMESTAMP,
	number INTEGER default 0
);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2298372.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM32自学记录(九)

STM32自学记录 文章目录 STM32自学记录前言一、DMA杂记二、实验1.学习视频2.复现代码 总结 前言 DMA 一、DMA杂记 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输,无须CPU干预&…

【C++】C++-教师信息管理系统(含源码+数据文件)【独一无二】

👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。 【C】C教师信息管理系统(含源码&#x…

Java Swing-5.jar 使用 jpackage 打包成 windows 可安装应用(exe,msi,免安装版exe)

环境 jdk17 (jdk14 以后自带将jar 打安装包工具 jpackage,版本从1.8调整到17) Maven:3.2.5 效果 对比 exe4j :免费版在启动的时候总是先弹出一个弹框,告诉用户你在用他们的免费版Launch4j:无法把jre环境打到exe文件中,用户需要单独…

ADC入门准备(十):信号与系统知识回顾

4.7系统函数零极点分布决定时域特性 4.7.1 H(s)极点分布与h(t)的对应图解 4.7.2 H(s)、E(s)极点分布与自由响应、强迫响应特征的对应 4.8 H(s)零极点分布决定频域特性 4.8.1 s平面几何分析法 4.8.2 高通滤波器的频率特性 4.8.3 低通滤波器的频率特性 4.9 二阶谐振系…

wx060基于springboot+vue+uniapp的宿舍报修系统小程序

开发语言:Java框架:springbootuniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包&#…

CCF-GESP 等级考试 2024年9月认证C++二级真题解析

2024年9月真题 一、单选题(每题2分,共30分) 正确答案:A 考察知识点:计算机存储 解析:磁心存储元件是早期计算机中用于存储数据的部件,它和现代计算机中的内存功能类似,都是用于临时…

第二天:工具的使用

每天上午9点左右更新一到两篇文章到专栏《Python爬虫训练营》中,对于爬虫有兴趣的伙伴可以订阅专栏一起学习,完全免费。 键盘为桨,代码作帆。这趟为期30天左右的Python爬虫特训即将启航,每日解锁新海域:从Requests库的…

HarmonyOS:使用List实现分组列表(包含粘性标题)

一、支持分组列表 在列表中支持数据的分组展示,可以使列表显示结构清晰,查找方便,从而提高使用效率。分组列表在实际应用中十分常见,如下图所示联系人列表。 联系人分组列表 在List组件中使用ListItemGroup对项目进行分组&#…

Django5的新特征

Django是一个用Python编写的高级Web框架,它的目标是让开发人员能够快速高效地构建复杂的Web应用程序。自从2008年首次发布以来,Django已经成为开源Web框架中的佼佼者,被广泛应用于各种规模的项目中。Django 提供了一套强大且全面的工具&#…

JVM类加载和垃圾回收(详细)

文章目录 JVM介绍JDK/JRE/JVM的关系 内存结构堆程序计数器虚拟机栈本地方法栈本地内存 类文件字节码文件结构 类加载类的生命周期加载类加载器双亲委派模型 链接初始化类卸载 垃圾回收堆空间的基本结构内存分配和回收原则死亡对象判断方法垃圾收集算法垃圾收集器 JVM 介绍 JD…

基于Flask的影视剧热度数据可视化分析系统的设计与实现

【FLask】基于Flask的影视剧热度数据可视化分析系统的设计与实现(完整系统源码开发笔记详细部署教程)✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 随着互联网技术的飞速发展,影视剧行业的数据量呈爆炸性增长&#x…

Docker Desktop如何恢复出厂设置

在测试dify、ragfow等几个模型过程中,各种拉镜像建容器,导致错误提示“AssertionError(Can t access Redis. Please check the Redis status.)”,两个模型都无法使用,如何清空重建?请参照下面操作: 1、Win…

Android Studio:键值对存储sharedPreferences

一、了解 SharedPreferences SharedPreferences是Android的一个轻量级存储工具,它采用的存储结构是Key-Value的键值对方式,类似于Java的Properties,二者都是把Key-Value的键值对保存在配置文件中。不同的是,Properties的文件内容形…

国自然专项项目申请:AI赋能的急性心肌梗死预警研究|基金申请·25-02-14

小罗碎碎念 急性心肌梗死严重威胁生命健康,因其起病隐匿、发病机制复杂,早期预警困难。现在,转机来了!国自然“AI赋能的急性心肌梗死预警研究”专项项目2025年度指南重磅发布。 该项目致力于攻克难题,通过多学科交叉…

【鸿蒙开发】第二十八章 应用状态的讲解、状态持久化、网络管理、应用数据持久化、文件上传下载

目录 1 应用状态 1.1 LocalStorage:页面级UI状态存储 1.1.1 两个页面共享一个对象 1.1.2 页面间共享 1.1.3 应用逻辑中使用 1.2 AppStorage:应用全局的UI状态存储 1.2.1 概述 1.2.2 基本用法 1.2.3 经常使用的方法 1.3 PersistentStorage&#x…

学习threejs,使用HemisphereLight半球光

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.HemisphereLight 二、…

数仓:核心概念,数仓系统(ETL,数仓分层,数仓建模),数仓建模方法(星型模型,雪花模型,星座模型)和步骤

数仓建模的核心概念 事实表(Fact Table): 存储业务过程的度量值(如销售额、订单数量等)。 通常包含外键,用于关联维度表。 维度表(Dimension Table): 存储描述性信息&…

python 基础知识100问

目录 1 Python中函数的输入参数类型‌: 2 python 第一个方法参数 selt cls 3 类和面向对象 4 Python 中__init__.py 作用 5 python 元类与装饰器 元类与装饰器https://blog.csdn.net/qq_52213943/article/details/145175689?spm1001.2014.3001.5506 6 设…

如何使用 DeepSeek R1 构建开源 ChatGPT Operator 替代方案

开源大型语言模型(LLMs)的兴起使得创建 AI 驱动的工具比以往任何时候都更容易,这些工具可以与 OpenAI 的 ChatGPT Operator 等专有解决方案相媲美。在这些开源模型中,DeepSeek R1 以其强大的推理能力、自由的可访问性和适应性而脱…

【教程】MySQL数据库学习笔记(七)——多表操作(持续更新)

写在前面: 如果文章对你有帮助,记得点赞关注加收藏一波,利于以后需要的时候复习,多谢支持! 【MySQL数据库学习】系列文章 第一章 《认识与环境搭建》 第二章 《数据类型》 第三章 《数据定义语言DDL》 第四章 《数据操…