赞
踩
实现多环境下的接口测试的核心 “在请求之前,对请求的url进行替换”
实现这一核心主要的步骤可以分为
需要二次封装requests,对请求进行定制化。
将请求的结构体的ur从一个写死的ip地址改为一个(任意的)域名。
使用一个 env 配置文件,存放各个环境的配置信息。
然后将请求结构体中的url替换为env
配置文件中个人选择的url。
将env 配置文件使用yaml 进行管理。
每个步骤看起来挺简单的,但是要实施起来要做很多事情
json
复制代码
使用代码编写一个本地接口:http://127.0.0.1:8080/shancha/test_one 接口返回内容为{"name":"山茶","公众号":"程序员山茶"}
基础请求方法实现:
python
复制代码
# 一、设定基础 # 1.引入requests模块 # 2.设计Api类 # 3.类中增加send方法,方法设定data传入参数,data为字典类型 # 4.send方法中通过requests.request()方法发送请求,request()中传入对应参数,字典key的方式获取 import requests class Api: def send(self, data:dict): res = requests.request(method=data["method"], url=data["url"], headers=data["headers"]) return res # 二、设定测试类 # 1.设计TestApi类 # 2.编写测试方法test_send(self) # 3.方法中通过对象引入测试方法 # 4.设定参数data from InterfaceTestingDifferentEnv import ApiDemo class TestApi: data = { "method": "get", "url": "http://127.0.0.1:8080/shancha/test_one", "headers": None } def test_send(self): api = ApiDemo.Api() print(api.send(self.data).text)
执行结果显示与预期结果一直
在改写参数时我们可以使用代码中的replace来替换对应url数据
kotlin
复制代码
# 修改原方法中代码块,增加第四行以及第五行数据,执行查看结果 def send(self, data:dict): data["url"] = str(data["url"]).replace("127.0.0.1","test_code") print(data["url"]) res = requests.request(method=data["method"], url=data["url"], headers=data["headers"]) return res
如图所示,对应的域名已经被替换为"test_code"
通过这种方式我们能够将对应的url替换为任意的环境,但是这种方式还是相对来讲较为传统,有一个明显的缺点,每执行一次,就要调整一次代码
env
配置文件中选择的url为解决第2点这个问题,我们可以将环境配置信息整合为一个env配置文件,通过调用配置的方式来替换testcode域名
python
复制代码
# 1.在原请求方法中增加env环境存储信息 # 2.在参数请求前,通过读取env配置的方法将url替换 # 一、请求方法类 import requests class Api: env = { "default": "dev", "test_other": { "dev": "127.0.0.1", "test": "127.0.0.2" } } def send(self, data:dict): data["url"] = str(data["url"]).replace("testcode", self.env["test_other"][self.env["default"]]) print("传入的url数据是::"+data["url"]) res = requests.request(method=data["method"], url=data["url"], headers=data["headers"]) return res # 测试类 from InterfaceTestingDifferentEnv import ApiDemo class TestApi: data = { "method": "get", "url": "http://testcode:8080/shancha/test_one", "headers": None } def test_send(self): api = ApiDemo.Api() print(api.send(self.data).text)
注意⚠️:
self.env["test_other"][self.env["default"]] 等同于 self.env["test_other"][self.env["dev"]]
点击执行,结果与第一次基础结果一致,且请求url中“testcode”被更换为指定参数,以后每次执行只要修改default内容即可,但相较于只修改配置yaml文件而言,此种方式仍存在问题
将 env 配置文件真正使用 yaml 数据驱动,实现多环境下的接口测试
为防止手动创建yaml文件出现问题,可以使用代码转换yaml文件
python
复制代码
# 1.创建新类,引入yaml包,打开一个文件,并赋予可写权限 # 2.使用yaml.safe_dump写入数据 import yaml def test_yaml2(): env = { "default": "dev", "test_other": { "dev": "127.0.0.1", "test": "127.0.0.2" } } with open("env.yaml", "w") as f: yaml.safe_dump(data=env, stream=f)
执行后yaml文件创建成功
调用方式修改,直接读取 env.yaml 文件配置
kotlin
复制代码
# 1.直接讲env变量读取修改即可 # 2.后续环境发生改变可以直接修改文件即可 import requests import yaml class Api: # env = { # "default": "dev", # "test_other": { # "dev": "127.0.0.1", # "test": "127.0.0.2" # } # } env = yaml.safe_load(open("env.yaml")) def send(self, data:dict): data["url"] = str(data["url"]).replace("testcode", self.env["test_other"][self.env["default"]]) print("传入的url数据是::"+data["url"]) res = requests.request(method=data["method"], url=data["url"], headers=data["headers"]) return res
与预期结果一致,结果未发生改变,但是执行确实更加便利简介
实现在多环境下进行接口测试,同样的测试用例,我们可以选择更加简洁方便的方法来实现,使用配置文件能够解决很多代码修改问题
自动化测试相关教程推荐:
2023最新自动化测试自学教程新手小白26天入门最详细教程,目前已有300多人通过学习这套教程入职大厂!!_哔哩哔哩_bilibili
2023最新合集Python自动化测试开发框架【全栈/实战/教程】合集精华,学完年薪40W+_哔哩哔哩_bilibili
测试开发相关教程推荐
2023全网最牛,字节测试开发大佬现场教学,从零开始教你成为年薪百万的测试开发工程师_哔哩哔哩_bilibili
postman/jmeter/fiddler测试工具类教程推荐
讲的最详细JMeter接口测试/接口自动化测试项目实战合集教程,学jmeter接口测试一套教程就够了!!_哔哩哔哩_bilibili
2023自学fiddler抓包,请一定要看完【如何1天学会fiddler抓包】的全网最详细视频教程!!_哔哩哔哩_bilibili
2023全网封神,B站讲的最详细的Postman接口测试实战教学,小白都能学会_哔哩哔哩_bilibili
如果对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。
如有不懂还要咨询下方小卡片,博主也希望和志同道合的测试人员一起学习进步
在适当的年龄,选择适当的岗位,尽量去发挥好自己的优势。
我的自动化测试开发之路,一路走来都离不每个阶段的计划,因为自己喜欢规划和总结,
测试开发视频教程、学习笔记领取传送门!!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。