目录
一、整体思路
接口自动化框架是基于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端经常登录态失效,可以把脚本部署到服务器中,每分钟请求一次,保持登录态