python接口自动化之yaml实现数据驱动(单接口)
(1)创建yaml数据
chaxun:
- name: 用户模块查询校验
request:
header:
Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6ImJiMzhmNzIyLThkMTgtNGRkYy1hZGQ5LTk0NmY4YmJmYzBhZiJ9.z1Tj8Rt-GJRaDKuX9MmYko22us8ccEHjLbJrm0-gM5bbZxvhqp82ea2JCs_X1JBS4sDZMuqvFPGBSZClmWVyPA
Content-Type: application/json;charset=UTF-8
Cookie: Admin-Token=eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6ImJiMzhmNzIyLThkMTgtNGRkYy1hZGQ5LTk0NmY4YmJmYzBhZiJ9.z1Tj8Rt-GJRaDKuX9MmYko22us8ccEHjLbJrm0-gM5bbZxvhqp82ea2JCs_X1JBS4sDZMuqvFPGBSZClmWVyPA
User-Agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Mobile Safari/537.36
url: http://127.0.0.1/backend/garage/info
method: post
data:
pageNum : 1
pageSize: 10
garageStatus: ""
city: ""
createTime: ""
keyword: ""
extract: 查询成功
chaxun:
- name: 角色管理模块重置校验
request:
header:
Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6ImJiMzhmNzIyLThkMTgtNGRkYy1hZGQ5LTk0NmY4YmJmYzBhZiJ9.z1Tj8Rt-GJRaDKuX9MmYko22us8ccEHjLbJrm0-gM5bbZxvhqp82ea2JCs_X1JBS4sDZMuqvFPGBSZClmWVyPA
Content-Type: application/json;charset=UTF-8
Cookie: Admin-Token=eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6ImJiMzhmNzIyLThkMTgtNGRkYy1hZGQ5LTk0NmY4YmJmYzBhZiJ9.z1Tj8Rt-GJRaDKuX9MmYko22us8ccEHjLbJrm0-gM5bbZxvhqp82ea2JCs_X1JBS4sDZMuqvFPGBSZClmWVyPA
User-Agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Mobile Safari/537.36
url: http://127.0.0.1/backend/garage/info
method: post
data:
pageNum : 1
pageSize: 10
garageStatus: ""
city: ""
extract: 查询成功
(2)创建读取yaml文件的方法
import yaml
import json
def read_yaml(yaml_file_path):
with open(yaml_file_path, encoding="utf-8") as f:
value = yaml.load(stream=f, Loader=yaml.FullLoader)
return value
(3)调用读取yaml的方法进行接口参数化
#coding=utf-8
#导入日志类便于设置日志信息
from Logs.Log import Logger
from Public.PublicRequest import RunMain
from DataExcel.readExcelData import ExcelUtil
import pytest
import allure
from DataYaml.readYaml import read_yaml
import json
# #设置日志类型参数,打印日志信息
log=Logger('车商管理模块日志').getlog()
excle=ExcelUtil(sheet='cheshang').get_data()
date=read_yaml(r'C:\Users\admin\Desktop\pytest-requests-new-yaml\pytest-request-master\DataYaml\login.yaml')
@allure.feature('用户模块相关功能校验')
class Test_Cheshang():
@pytest.mark.smoke
@allure.story('用户管理查询校验')
def test_find__cheshang_success(self):
log.info(date['chaxun'][0]['name'])
response=RunMain().run_main(date['chaxun'][0]['request']['method'],date['chaxun'][0]['request']['url'],json.dumps(date['chaxun'][0]['request']['data']),date['chaxun'][0]['request']['header'])
assert date['chaxun'][0]['request']['extract'] in response
@pytest.mark.smoke
@allure.story('角色管理重置校验')
def test_find__cheshang_success(self):
log.info(date['chongzhi'][0]['name'])
response=RunMain().run_main(date['chongzhi'][0]['request']['method'],date['chongzhi'][0]['request']['url'],json.dumps(date['chongzhi'][0]['request']['data']),date['chongzhi'][0]['request']['header'])
assert date['chongzhi'][0]['request']['extract'] in response
注意:
单接口方法可以用于同一个接口不同参数的使用
多接口方法可以用于不同接口不同参数的使用