接口自动化框架2.0

目录

一、整体思路

二、针对公司的项目做了些个性化处理

三、测试环境常见问题处理

1.发送请求时,测试环境不稳定

2.正式环境和测试环境跑自动化

 3.保持登录态


一、整体思路

 


接口自动化框架是基于python,unittest,requests,ddt,logging

基本思路
准备数据
单元测试框架
其他优化

✅准备数据
excel存放数据
openxl读取数据

✅单元测试框架
处理数据,json库或者eval方法
发送请求,封装requests库请求

ddt,测试数据参数化,脚本与数据隔离

unittest框架关键词
创建测试类和单元测试函数
脚手架,类级别和方法级别
测试集   
测试报告 beautifulreport


✅其他优化
logging模块:日志打印保存
配置化:域名和接口名,文件路径
公用方法封装到common目录下

1.解决数据依赖

类级别的数据依赖
    ===》》》 动态绑定到类属性;动态获取

     
接口之间的数据依赖
     ===》》》动态绑定到对象的类属性;动态获取

获取


接口依赖常数
 ===》》》属性定义在对应的类里,动态获取对应的类属性

 

2.数据处理
jsonpath表达式,正则表达式


3.单例模式
一个类只有一个实例存在。方式:在包下的init.py文件中,实例化该类。

eg:日志模块封装,就用了单例模式

二、针对公司的项目做了些个性化处理

数据处理部分

1.excel增加是否跑脚本列

有些接口调用比较麻烦:接口A依赖接口B、C、D,而A接口经常调用,其他3个接口很少用,接口A可以拎出单独写

2.接口依赖

接口依赖及处理:

类级别依赖(可以绑定到类属性)、方法级别(绑定到对象属性)、测试函数级别(动态绑定到类属性)

替换数据主要分为2大类:

(1)自定义数据

可以作为一个类的属性,需要该值,用反射获取属性

(2)依赖第三方接口

A依赖B接口返回参数。B返回值可以绑定到类属性/对象属性中,用反射获取对象性

def replace_variables(case_str, objects, type='vary'):   # , imei=None, token=None
    """
    替换变量和常量
    :param case_str: 用例字符串
    :param objects: 类名
    :param type: vary:用例之间的依赖数据;constant:依赖配置
    :return:
    """
    flag = '#' if type == 'vary' else r'&'
    # 找出需要替换的字符串
    re_list = re.findall(f'{flag}.*?{flag}', case_str)

    # 替换字符串
    for item in list(set(re_list)):
        key = item[1:-1]
        case_str = case_str.replace(item, getattr(objects, key))
    return case_str

三、测试环境常见问题处理

1.发送请求时,测试环境不稳定

发送请求出现异常/403,重试3次

import time

import requests
from common import logger
# requests.post(json=)


def req(url, headers, method='post', if_print=True, **kargs):
    """
    发请求:如果出现异常会循环请求|响应为403,会循环请求3次
    :param url:
    :param headers:
    :param method:
    :param res_type: 响应类型
    :param kargs: 请求其他参数:dict
    :return:
    """
    i = 0
    while i < 3:
        try:
            logger.debug('============URL============')
            logger.debug(url)
            logger.debug('============method============\n{}'.format(method))
            logger.debug('============headers============\n{}'.format(headers))
            if if_print is True:
                for key, value in kargs.items():
                    logger.debug('============{}============\n{}'.format(key.lower(), value))
            logger.debug('============请求时间============\n{}'.format(time.strftime('%Y-%m-%d %H:%M:%S')))
            res = getattr(requests, method)(url=url, headers=headers, **kargs)
            logger.debug('============响应状态码============\n{}'.format(res.status_code))
            logger.debug('============响应结果============\n{}'.format(res.text))

            if res.status_code == 403:
                logger.info('响应状态码为403')
                i += 1
                continue
        except requests.exceptions.RequestException as e:
            logger.error(e)
            logger.info('错误次数:{}'.format(i))
            i += 1
        else:
            return res

2.正式环境和测试环境跑自动化

测试环境和正式环境只有域名不一样,所以配置的时候,可以域名和接口名分开配置,方便取值

 3.保持登录态

web端经常登录态失效,可以把脚本部署到服务器中,每分钟请求一次,保持登录态

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值