python3+requests库框架设计03-请求重新封装

在完成了日志类封装之后,那我们就要对测试基类进行实现,在其中对一些请求再次封装,在项目下新建一个Common文件夹,在文件夹下新建Base_test.py文件,项目结构如下。

python3+requests库框架设计03-请求重新封装

具体怎么封装还是要看被测接口需要什么,只能提供一个大致思路,我项目能用的封装,你项目并不一定能用

首先是get请求,第一个肯定是url,实际项目api接口都需要请求字段,那肯定要params参数,基本需要使用请求头来告诉接口是哪个用户做的操作,那就需要headers参数。可能还需要下载文件,那需要files参数。需要把请求的内容,返回的状态,响应内容的日志打印出来,如果请求失败,需要打印错误日志。

请求的接口url也是要打印出来的,等到配置文件的时候再讲。基本代码如下。

import unittest
import requests
from Logs.log import log1
class webrequests(unittest.TestCase): def get(self,url,params=None,headers=None,files=None):
'''封装get方法,return响应码和响应内容'''
try:
r = requests.get(url,params = params,headers = headers,files=files)
log1.info("请求的内容:%s" % params)
status_code = r.status_code # 获取返回的状态码
log1.info("获取返回的状态码:%d" % status_code)
response_json = r.json() # 响应内容,json类型转化成python数据类型
log1.info("响应内容:%s" % response_json)
return status_code,response_json # 返回响应码,响应内容
except BaseException as e:
log1.error("请求失败!",exc_info=1)

来测试一下封装的get请求,使用之前文章中查询天气的get请求接口

from Common.Base_test import webrequests
url = 'https://www.sojson.com/open/api/weather/json.shtml'
payloda = {'city':'上海'}
s = webrequests()
s.get(url,payloda)

python3+requests库框架设计03-请求重新封装

可以看到结果正确

因为项目接口响应内容基本都是json格式,所以在请求封装中,直接做了数据转换。

接下来是post请求,post请求有时候需要提交json格式的数据,有时候不需要,那这就要封装两个方法,剩下的跟get差不多

一般post请求上传文件都不会是带json格式的数据

代码如下。

    def post(self, url, data=None, headers=None,files=None):
'''封装post请求,return响应码和响应内容'''
try:
r = requests.post(url, data=data, headers=headers,files=files)
log1.info("请求的内容:%s" % data)
status_code = r.status_code # 获取返回的状态码
log1.info("获取返回的状态码:%d" % status_code)
response_json = r.json() # 响应内容,json类型转化成python数据类型
log1.info("响应内容:%s" % response_json)
return status_code,response_json # 返回响应码,响应内容
except BaseException as e:
log1.error("请求失败!",exc_info=1) def post_json(self,url,data=None,headers=None):
'''封装post方法,并用json格式传值,return响应码和响应内容'''
try:
data = json.dumps(data).encode('utf-8') # python数据类型转化为json数据类型
r = requests.post(url, data=data, headers=headers)
log1.info("请求的内容:%s" % data)
status_code = r.status_code # 获取返回的状态码
log1.info("获取返回的状态码:%d" % status_code)
response = r.json() # 响应内容,json类型转化成python数据类型
log1.info("响应内容:%s" % response)
return status_code,response # 返回响应码,响应内容
except BaseException as e:
log1.error("请求失败!",exc_info=1)

需要impost json

因为找不到好的post接口做测试,所以就不试了

有时候很多响应内容中某个字段会是一个嵌套字典,而我们需要和某个字段进行断言,那我们可以封装一个这样的方法,遍历字典,通过传入的键。返回嵌套字典中的对应的值

 def getdict(self,dict1,obj,default=None):
''' 遍历嵌套字典,得到想要的value
dict1所需遍历的字典
obj 所需value的键'''
for k,v in dict1.items():
if k == obj:
return v
else:
if type(v) is dict:#如果是字典
re = self.getdict(v,obj,default) # 递归
if re is not default:
return re

那现在来测试一下是否能拿到自己想要的值,通过封装的getdict(),获取在嵌套三层字典中failAction的值

from Common.Base_test import webrequests
response = {'errno': 0, 'msg': 'success', 'result': {'id': '5b4dc7111c0ab20001c3c481', 'cname': '测试001', 'desc': '测试机器人', 'type': 0, 'settings': {'failAction': ['偶母鸡啊', '我不告诉你']}, 'lastView': '2018-07-17T18:38:09.250849551+08:00', 'nickname': '小可爱', 'age': 0, 'gender': 'male', 'hometown': '北京', 'speciality': '打游戏'}}
s = webrequests()
failAction = s.getdict(response,'failAction')
print(failAction)

python3+requests库框架设计03-请求重新封装

可以看到打印的值是正确的

还可以封装一些比如json格式美化显示的方法,可以让日志打印的json更加美观可视化。有兴趣的可以自己去实现下

补充:如果使用https请求时,可以使用verify = false参数来跳过SLL证书认证,发布到生产的代码都应该加上timeout参数,防止请求无响应,程序一直等待响应卡着不继续往下执行。

上一篇:数据压缩之经典——哈夫曼编码(Huffman)


下一篇:10: java数据结构和算法: 构建哈夫曼树, 获取哈夫曼编码, 使用哈夫曼编码原理对文件压缩和解压