接口测试框架实战(四) | 通用 API 封装实战
本文节选自霍格沃玆测试学院内部教材,进阶学习,文末加群!
在 APIObject 设计模式中,需要一个 base_api
作为其他 API 步骤的父类,把通用功能放在这个父类中,供其他的 API
直接继承调用。这样做的优点在于,减少重复代码,提高代码的复用性。
通用 API 封装实战
在上一章节在演示使用 API-Object 设计模式对脚本进行改造时提到了 base_api
。不过在上一章,仅仅只是封装了一个 utils
中的一个简单方法。并没有完全体现出 base_api
的实际作用。
接下来,我们通过通用接口协议的定义与封装实战,来实际体会一下 base_api
的巧妙之处。
- base_api.py
在代码内,对 request 进行一层封装,当然在这里还看不出来具体的优势:
import requests
class BaseApi:
def request(self, method, url, **kwargs):
self.json_data = requests.request(method=method, url=url, **kwargs)
return self.json_data
- wework.py
继承于类 BaseApi
,可以 直接调用 父类中的 request
方法(不需要导入 requests 库),从而发起一个 get 请求:
from test_interface.test_wework.api.base_api import BaseApi
class WeWork(BaseApi):
corpid = "ww93348658d7c66ef4"
contact_secret = "T0TFrXmGYel167lnkzEydsjl6bcDDeXVmkUnEYugKIw"
token = dict()
token_url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
def get_access_token(self):
r = self.request(method="get", url=self.token_url,
params={"corpid": self.corpid, "corpsecret": self.contact_secret})
return r.json()
- test_wework.py
继承于类 WeWork
,主要目的只是为了检查上面的 get_access_token(self)
是否成功:
from test_interface.test_wework.api.wework import WeWork
class TestWeWork(WeWork):
def test_get_access_token(self):
r = self.get_access_token()
assert r["errcode"]==0
以上,在上面的案例中,在 base_api.py 中对 requests 进行了多一层的封装,这样只要是属于 BaseApi
这个类的子类,都可以无需引用而直接调用 requests 库。从而发起各种各样的请求,实现了通用接口协议的定义与封装。
更多接口测试框架实战进阶内容,我们在后续文章分享。关注 「 霍格沃兹测试学院 」公众号,获取更多测试开发干货内容。
来霍格沃兹测试开发学社,学习更多软件测试与测试开发的进阶技术,知识点涵盖web自动化测试 app自动化测试、接口自动化测试、测试框架、性能测试、安全测试、持续集成/持续交付/DevOps,测试左移、测试右移、精准测试、测试平台开发、测试管理等内容,课程技术涵盖bash、pytest、junit、selenium、appium、postman、requests、httprunner、jmeter、jenkins、docker、k8s、elk、sonarqube、jacoco、jvm-sandbox等相关技术,全面提升测试开发工程师的技术实力
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了