httprunner3.x总结24 - hrun3常见的测试前置、测试后置处理

1、关于hrun3中setup、teardown的使用

import json
import pymysql
import requests
from pymysql.constants import CLIENT
from login import get_config_value

"""
hrun3中一些常见的测试前置后置处理:
(1)直接数据库处理表格数据
(2)根据 response 调用相关增删改查接口
"""


header = {
    "accept-language": get_config_value("Header", "accept-language"),
    "Authorization": get_config_value(role="expert_001", key="token"),
    "Content-Type": "application/json; charset=utf-8",
}
host = get_config_value(key1="Host", key2="rem_host_001")


def setup_banner_test_005(name):
    """
    清理可能遗留的脏数据
    @param name: png格式的图片名字
    @return:
    """
    conn_base_admin = pymysql.connect(
        host="xxx",
        port=123,
        user="xxx",
        password="xxx",
        db="xxx",
        charset="utf8",
        client_flag=CLIENT.MULTI_STATEMENTS,
    )
    curs_base_admin = conn_base_admin.cursor()
    sql = f"delete from tb where filename = xxx;"
    curs_base_admin.execute(sql)
    conn_base_admin.commit()


def tear_down_test_004(phone_number):
    """
    批量执行sql处理数据
    :param phone_number: 手机号
    :return: 
    """
    # (1)从第一个db库中获取 id
    conn_base_admin = pymysql.connect(
        host="xxx",
        port=123,
        user="xxx",
        password="xxx",
        db="xxx",
        charset="utf8",
        client_flag=CLIENT.MULTI_STATEMENTS,
    )
    curs_base_admin = conn_base_admin.cursor()
    sql = f"select id from user where phone_number = {phone_number};"
    curs_base_admin.execute(sql)
    conn_base_admin.commit()
    id = curs_base_admin.fetchall()[0][0]
    
    # (2)从第二个db库处理相关数据
    conn = pymysql.connect(
        host="xxx",
        port=123,
        user="xxx",
        password="xxx",
        db="xxx2",
        charset="utf8",
        client_flag=CLIENT.MULTI_STATEMENTS,
    )
    # 2.通过数据库连接,创建游标(可以通过游标执行sql语句)
    curs = conn.cursor()
    sql = f"""
    SET @openId = '{str(id)}';
    delete from tb where tb_expert.xx_id = @openId;
    delete from tb where tb_expert.xx_id = @openId;
    delete from tb where tb_expert.xx_id = @openId;
    """
    curs.execute(sql)
    conn.commit()
    data = json.dumps({})
    url = host + "/xx/yy"
    with requests.put(url=url, headers=header, data=data) as response:
        res = response.json()
        print(res)


def teardown_hook_clean_file(response):
    """
    删除接口执行后的相关数据
    @param response:
    @return:
    """
    data_content = response.body["data"]
    if data_content == []:
        return None
    file_id = [x["id"] for x in data_content]
    for i in file_id:
        url = (host + f"/diagn/xxx/{i}")
        with requests.delete(url=url, headers=header) as response:
            print("成功删除用户操作手册界面的内容")
    return response.json()
  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿_焦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值