最近学习python的接口自动化,看了许多,决定使用pytest框架,还有好看的测试报告,在网上看到有介绍较完整的测试框架,在此基础上修改成符合自己习惯的方式,不需要的删去等等,学习中遇到很多坑,在此记录一下几个印象深刻的问题,附上参考学习的框架:https://www.jianshu.com/p/e31c54bf15ee
1.环境安装,安装python3后,需要安装的模块:
pytest
PyYAML
requests
configparser
allure-pytest
requests-toolbelt
pytest-rerunfailures
2.参考文章中对于框架的各个模块已做介绍。
3.学习中,遇到的坑:
1)Session.py中获取cookie时:response.cookies.get_dict() 在调试时总是返回空,后修改为:
login_url = 'http://' + self.config.loginHost_release
parm = self.config.loginInfo_release # 这是从配置文件里取到的参数类型为str
session_debug = requests.session()
# 前面的parm需要转为dict,否则cookie为空
response = session_debug.post(login_url, eval(parm), headers=headers)
cookies = requests.utils.dict_from_cookiejar(session_debug.cookies)
self.log.debug('cookies: %s' % cookies)
return cookies
2)通过yaml文件获取接口参数后,通过request.py发送请求,总是返回url异常,原因是从yaml文件里获取的接口参数data格式有问题,原yaml文件:
Basic:
dec: "基础设置"
parameters:
-
url: /postLogin
data:
-
email: [email protected]
password: 123456
auth: admin
header: {
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko)\
Chrome/67.0.3396.99 Safari/537.36",
"Content-Type": "application/x-www-form-urlencoded"
}
注意上面data下面的“-”,在yaml里代表list,获取后返回的为:[[{'canshu1':'value1', 'canshu2':'value2'}]],有两个[],而在TestCase下的测试用例里取参数时为:response = request.get_request(api_url, params[0], headers[0]),而params[0]为[{'canshu1':'value1', 'canshu2':'value2'}],还有一个[],不是dict形式,所以请求失败,params[0]修改为params[0][0],或者,将yaml文件修改为:
# 去掉-,为dict形式
data:
email: [email protected]
password: 123456
auth: admin
3)request.py中,def __init__(self, env): 有个参数env,在Testcase里的测试用例中调用request时,为request = Request.Request(action),action为测试用例的参数,,在conftest.py中定义好的测试环境(config.ini中的debug或release环境),将“debug”或“release”作为action传入测试用例,在request时获取特定环境的cookie。
4)生成allure报告时,只能执行一次,第二次执行后,html里的index.html内容其实是上一次的内容,用终端命令
allure generate ./Report/xml -o ./Report/html
调试后发现,报错:
Allure: Target directory ./Report/html for the report is already in use, add a '--clean' option to overwrite
意思是需要在执行前清空上一次的报告,因此,在run.py里,将生成报告的命令改为如下:每次运行前将上一次的xml和html报告都清空。
# 定义测试集
# --clean-alluredir清空上一次的xml报告
args = ['-s', '-q', 'TestCase/test_Case.py', '--alluredir', xml_report_path, '--clean-alluredir']
pytest.main(args)
# --clean清空上一次的html报告
cmd = 'allure generate %s -o %s --clean' % (xml_report_path, html_report_path)
shell.invoke(cmd)
5)生成的html报告在本地打开全是404,但通过pycharm在浏览器打开就没问题,原因还未找到,有大神知道望解答。
本地直接用浏览器打开:
通过pycharm在浏览器打开:
6)未研究框架中的email模块,需要时在学习
7)allure有很丰富的用法,后续继续研究如何丰富测试用例,比如接口依赖,场景测试等。