新的一天开始了,今天仍然是等待提测的一天,所以来总结一下前几天模仿搭建的测试框架吧。我并不觉得我完全理解了,更多的是一种照葫芦画瓢,但是,这个瓢既然已经成功画成了,有必要拿出来成为今天的日更文了。
首先,总结一下搭建测试框架的步骤。(我不确定是专业的....但是应该是一个最简单的吧.....
接下来,就是按照上述步骤开始搭建。
封装请求
我在日常接触到的测试任务,接口都是http
协议下发送请求,所以在这个步骤,主要做的就是封装利用request
发送http
请求的代码,便于后续接口的直接调用。
#httpclient.py
import requests
class client():
def __init__(self,api_root_url):
self.api_root_url=api_root_url
self.session=requests.session()
def request(self,url,method,data=None,json=None,**kwargs):
url=self.api_root_url+url
if method=="get":
return self.session.get(url,**kwargs)
if method=="post":
return self.session.post(url,data,json,**kwargs)
def get(self,url,**kwargs):
return self.request(url,"get",**kwargs)
def post(self,url,data=None,json=None,**kwargs):
return self.request(url,"post",data,json,**kwargs)
这段代码主要实现了两个功能:
- 初始化
root_url
以及建立会话 - 建立调用
request
请求代码方法
封装接口请求方法
该文件中建立的类继承自上方的client
类,目的是调用其中的请求方法,传入的参数主要是包括待测接口涉及的相对url及参数等信息。
#interface.py
from httpclient import client
class demand(client):
def name(self,**kwargs):
return self.get("/name",**kwargs)
def age(self,age,**kwargs):
return self.post("/age/{}".format(age),**kwargs)
这里的请求,每一个都带上了**kwargs
参数,这是因为如果最终的请求会带有params
、json
或是data
参数,可以直接在调用方法时传入,而无需修改这个封装请求的文件。
上面的请求封装结束后,建立一个新的类,传入根url以及建立一个demand类的实例,用于后续测试用例文件的直接调用。
#bridge.py
from interface import demand
class params():
def __init__(self,**kwargs):
self.api_root_url="https://www.****.com"
self.demand=demand(self.api_root_url,**kwargs)
编写测试用例
引用params类,传入必要的参数发起请求,同时利用assert
进行结果判断。
#test_project.py
import pytest
from birdge import params
test_data=params().demand
def test_name():
name_res=test_data.name()
assert name_res.status_code==200
def test_age():
age_res=test_data.age("18")
assert age_res.status_code==201
而后执行pytest -s test_project.py
即可运行测试脚本,完成接口自动化测试。整个的调用过程如下:
截止目前,一个简短的测试框架就搭建完毕了,这之中还有很多优化的环节,即图1的第4个步骤,比如根url参数化,接口传入数据参数化,我们下一个日更文再讲喽~
自我记录,有错误欢迎指正~