目录
3.2 对上面的用例进行分层封装(可根据业务复杂度分两层或者三层,此处演示分三层)
设计框架的原则
- 封装基类方法
对于一些较通用的方法,可以封装,比如发送请求、log日志、公共方法(多个模块均需要调用此方法,可进行封装)。
- 高内聚低耦合
每个用例独立完成自己的测试。
模块与模块之间接口的复杂程度尽量低,比如在类内部尽可能减少方法之间的调用,否则一个方法的变动会影响调用它的另一个方法。
- 脚本分离
业务代码、测试数据应该相互分离,即平时说的数据驱动。代码中不出现具体的数据、配置。而是调用对应的数据文件、配置文件等。
1.框架整体结构
2.框架各个模块说明
public:封装公共方法,包括log、login等
testdata:存放测试数据,包括数据驱动、上传下载的文件、图片等等
conftest.py: 见pytest框架的文章
pytest.ini: 配置文件,见pytest框架的文章
mode:封装接口最底层的内容,包括传参的参数、request的调用等
api:封装业务逻辑的处理,包括前后接口的处理,场景的处理等等
testcase:测试用例层,执行测试用例,用例名以test开头
+report:可以加一个report存放allure生成的测试报告
3.示例
3.1 先写一个测试用例
def test_baidu_select(self):
# headers = {"Content-Type": "application/json;charset=UTF-8"}
headers = {}
url = "http://www.baidu.com"
params = {"wd": "test"}
baidu=requests.request('get',url,headers=headers,params=params)
print(baidu.text)
3.2 对上面的用例进行分层封装(可根据业务复杂度分两层或者三层,此处演示分三层)
3.2.1 mode层
class BaiduMode():
def baidu_search(self):
url = "http://www.baidu.com"
params = {"wd": "test"}
headers={}
baidu = requests.request('get', url, headers=headers, params=params)
return baidu.text
3.2.2 api层
from mode.baidu_mode import BaiduMode
class BaiduApi():
def baidu_search_api(self):
res = BaiduMode.baidu_search(self)
return res
3.2.3 testcase层
from api.baidu_api import BaiduApi
class TestBaidu():
@pytest.mark.test
@allure.title("测试")
def test_baidu_select(self):
baidu = BaiduApi.baidu_search_api(self)
print(baidu)
3.3生成allure测试报告并查看
pytest -sv .\testcase\test_baidu.py -q --alluredir=./report
allure serve .\report\
自动化测试框架思路均类似,可根据实际项目调整适配,根本思想是少改代码多适配,尽量修改数据文件、配置文件等。