学习搭建api自动化测试框架(pytest):python3+request+allure(一)

最近学习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在浏览器打开就没问题,原因还未找到,有大神知道望解答。

本地直接用浏览器打开:

学习搭建api自动化测试框架(pytest):python3+request+allure(一)_第1张图片

通过pycharm在浏览器打开:

学习搭建api自动化测试框架(pytest):python3+request+allure(一)_第2张图片

学习搭建api自动化测试框架(pytest):python3+request+allure(一)_第3张图片

6)未研究框架中的email模块,需要时在学习

7)allure有很丰富的用法,后续继续研究如何丰富测试用例,比如接口依赖,场景测试等。

你可能感兴趣的:(测试,记录积累)