知道ddt的基本使用方法之后,练习把之前用excel文件来维护的接口测试用例改用unittest+ddt来实现。
这里我选用yaml文件来管理接口参数,开始本来想用json,但是json无法添加注释,可读性不好。
1.向yaml文件中添加数据
下面截图是接口文档中的各个接口,每个接口都有一个固定的序号,所以在设计每个接口的测试数据时,以序号来区分不同接口
yaml文件内容如下,需要注意的是yaml的语法:
(1)键值对用冒号分割,但是冒号后需要加一个空格
(2)禁止使用tab缩进,只能使用空格键;缩进长度没有限制,只要元素对齐就表示这些元素属于一个层级
(3)字符串可以不用引号标注,也可以加引号,如果想把数字变为字符串,加引号即可
(4)使用#表示注释
2.简单demo:python读取yaml文件,取出接口参数
import yaml fp = open('../dataconfig/信息互动模块接口.yaml', encoding='utf-8') # 有中文字符的话,加编码格式 testdata = yaml.load(fp) t = testdata['5.2.1.4'] print(t)
3.完整流程
(1)封装读取yaml文件方法
handle_yaml.py # coding: utf-8 # author: hmk import yaml import os class HandleYaml: def __init__(self, file_path=None): if file_path: self.file_path = file_path else: root_dir = os.path.dirname(os.path.abspath('.')) # os.path.abspath('.')表示获取当前文件所在目录;os.path.dirname表示获取文件所在父目录;所以整个就是项目的所在路径 self.file_path = root_dir + '/dataconfig/信息互动模块接口.yaml' # 获取文件所在的相对路径(相对整个项目) # self.data = self.get_data() def get_data(self): fp = open(self.file_path, encoding='utf-8') data = yaml.load(fp) return data if __name__ == '__main__': test = HandleYaml() p = test.get_data() print(p['5.2.1.1'])
(2)封装requests请求方法
# coding: utf-8 # author: Archer import requests import json class RunMethod: def post_main(self, url, data, header=None):if header is not None: res = requests.post(url=url, data=data, headers=header) else: res = requests.post(url=url, data=data) # print(res.status_code) # return res.json() return res #为了方便后面断言,这里不再对服务器响应进行json格式编码 def get_main(self, url, data=None, header=None):if header is not None: res = requests.get(url=url, params=data, headers=header) else: res = requests.get(url=url, params=data) print(res.status_code) # return res.json() return res def run_main(self, method, url, data=None, header=None):if method == 'POST': res = self.post_main(url, data, header) else: res = self.get_main(url, data, header) return res # return json.dumps(res, indent=2, sort_keys=False, ensure_ascii=False) # 使用json模块格式化显示结果
(3)一个接口测试用例
# coding: utf-8 # author: Archer import unittest import ddt from base.run_method import RunMethod from utils.handle_yaml import HandleYaml get_data = HandleYaml() # 从yaml文件中取出该接口的参数 params = get_data.get_data()['5.2.1.4'] @ddt.ddt class Test(unittest.TestCase): """加载咨询详情接口""" def setUp(self): self.url = 'http://localhost:8088/ApprExclusiveInterface/api/enterprise/info/consult/loadDetail.v' self.run = RunMethod() @ddt.data(*params) def test(self, value): r = self.run.run_main("GET", self.url, value) print(r) self.assertTrue(value['assert'] in r.text) if __name__ == '__main__': unittest.main()
(4)利用HTMLTestRunner生成测试报告
run_report.py # coding: utf-8 # author: hmk from HTMLTestRunner import HTMLTestRunner import unittest import time, os root_dir = os.path.dirname(os.path.abspath('.')) # 获取当前文件所在目录的父目录的绝对路径,也就是项目所在路径E:\DDT_Interface case_dir = root_dir + '/test_case/' # 根据项目所在路径,找到用例所在的相对项目的路径 print(root_dir) print(case_dir) """定义discover方法""" discover = unittest.defaultTestLoader.discover(case_dir, pattern='test*.py', top_level_dir=None) """ 1.case_dir即测试用例所在目录 2.pattern='test_*.py' :表示用例文件名的匹配原则,“*”表示任意多个字符 3.top_level_dir=None:测试模块的顶层目录。如果没顶层目录(也就是说测试用例不是放在多级目录 中),默认为 None """ if __name__ == "__main__": """直接加载discover""" now = time.strftime("%Y-%m-%d %H_%M_%S") filename = root_dir + '/report/' + now + '_result.html' # 定义报告存放路径 print(filename) fp = open(filename, 'wb') runner = HTMLTestRunner(stream=fp, title='个人网企业网接口测试报告', description='测试结果如下: ') runner.run(discover) fp.close()
ok ,unittest+ddt进行接口测试就完成了,还有很多不足,yaml配置文件还可以继续设计优化,例如可以把请求url也加进去。
其实感觉如何设计测试用例,组织测试数据也是一件很有意思的事情,很多事情都必须先有一个良好的设计思路才会进行的更顺畅。总之勤于思考,多参考他人的思路。不是有句话吗,学而不思则罔,思而不学则殆。
2018-04-29 12:53:22