Python+request 获取响应(elapsed)和响应时间(timeout)《七》
requests发请求时,接口的响应时间,也是我们需要关注的一个点,如果响应时间太长,也是不合理的。
如果服务端没及时响应,也不能一直等着,可以设置一个timeout超时的时间
具体的实现如下:
超时(默认单位:s):
timeout=0.5:设置到不大于0.5s的超时时间
timeout=(0.5,0.8):设置区间时间的等待
当出现超时时,则会抛出此异常:requests.exceptions.ConnectTimeout: HTTPConnectionPool
获取响应时间:
r.elapsed.total_seconds()
#-*- coding:utf-8 -*- import requests from requests import exceptions try: #timeout=0.1 ,timeout=(0.5,0.8) r = requests.post(url=url, data=data, headers=headers, verify=False, timeout=0.5)
r.elapsed.total_seconds() #获取实际的响应时间
print r.json()
except exceptions.Timeout as e:
print("抛出异常")
进阶:
如需要统一所有的测试接口的超时时间都可设置一致的话,那么只需要将timeout添加到配置文件中,统一进行管控即可,在测试的接口中timeout直接给定参数,那么在后期的更改timeout的超时时间,只在配置文件中更改即可。如果timeout的超时时间不需要那么的统一,则只需在每个请求的接口中写即可。
示例:
(1)在 host_header.yaml 的配置文件中添加timeout
########################## 测试环境,通用的headers配置 ######################################
#请求接口的url的域名
host: https://testapp.goodiber.com/v2/ #dev1的测试环境域名
#请求接口的请求头中的共用参数
headers:
"version": "2.3.0"
"version-id": "238"
"os": "ios"
"sign": "123456"
"is-test": "1"
#设置的超时时间
timeout: 10
(2)在使用的py文件,login.py 文件中调用即可。
import yaml
import sys,os
import json
# 导入yaml中的host
reload(sys)
sys.setdefaultencoding("utf-8")
root_path = os.getcwd()[:-5]
with open(root_path + "/Config/host_header.yaml", 'rb') as f:
data = yaml.load(f)
host = data["host"]
timeout = data["timeout"]
.....前面的url、headers的编写此处省略
r = requests.post(url=url, data=data, headers=headers, verify=False,timeout = timeout) #直接给定timeout参数即可
get_reponse = r.json() # 获取到reponse返回的所有内容
result = json.dumps(get_reponse, encoding="utf-8", ensure_ascii=False) #将获取到的reponse中的中文已utf-8的格式显示。否则显示Unicode
1.作者:Syw 2.出处:http://www.cnblogs.com/syw20170419/ 3.本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 4.如果文中有什么错误,欢迎指出。以免更多的人被误导。 |
分类:
接口测试
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2018-05-30 【转】Jmeter-----函数引用和函数重定向