python pytest框架

一、pytest单元测试框架

1. 什么是单元测试框架
   单元测试是指在软件开发当中,针对软件的最小单位(函数、方法)进行正确性的检查测试。
2.单元测试框架
   Java:junit和testng
   Python:unittest和pytest
3.单元测试框架主要做什么?
    测试发现:从多个文件里面云找到我们测试用例
    测试执行:按照一定的顺序和规则去执行并生成结果
    测试判断:通过判断断言预期结果 和实际结果的差异
    测试报告:统计测试进度,耗时,通过率,生成测试报告

二、单元测试框架和自动化测试框架有什么关系?

  1. 什么是自动化测试框架

  2. 自动化测试框架的作用
                 提高测试效率,降低维护成本
                 减少人工干预,提高测试的准确率,增加代码的重用性
                 核心思想是让不懂代码的人也能够通过这个框架去实现自动化测试

  3. pytest单元测试框架和自动化测试框架的关系
               单元测试框架:只是自动化测试框架中的组成部分之一
               自动化测试框架:只是自动化测试框架中的组成部分之一

         数据驱动......
         关健字驱动
         全局配置文件的封装
         selenium,requests二次封装
         断言
         报告邮件
         更多.....

 接口自动化测试

  1. requests的二次封装
  2. yarml数据驱动
  3. 关健字驱动
  4. 多接口串联
  5. 全局配置文件
  6. 日志监控(调试日志,文件日志,邮件日志)
  7. yaml测试用例的封装(请求封装、读写封装、断言封装)
  8. allure报告的定制开发
  9. pytest只是这个框架中的一个组成部分

接口自动化、web自动化、APP自动化 三大部分

三、pytest简介

  1. pytest是一个非常成熟的python的单元框架,比unittest更灵活
  2. pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自动化
  3. pytest可以实现测试用例的跳过及reruns失败用例重试。
  4. pytest可以和allure生成非常美观的测试报告
  5. pytest可以和Jekins持续集成
  6. pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作。

需要的依赖包:
     pytest
     pytest-xdist  测试用例分布式执行,多CPU分发
     pytest-ordering 用于改变测试用例的执行顺序
     pytest-rerunfailures 用例失败后重跑
     pytest-html  (管理局成html格式的自动化测试报告)
     allure-pytest  用于生成美观的测试报告

     放到requirements.txt中,通过pip install -r requirements.txt  一次性安装所有的文件

查询是否安装成功  :pytest --version

四、使用pytest,默认的测试用例的以及基础应用

1.模块名必须以test_ 开头或者 _test结尾
2.测试类必须以Test开头,并且不能有init方法
3.测试方法必须以test开头

五、pytest测试用例的运行方式

1.主函数模型

(1)运行所有:pytest.main()
(2)指定模块:pytest.main([‘-vs’,’test_login.py’])
(3)指定目录:pytest.main([‘-vs’,’./interface_testcase’])
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成 
  pytest.main([‘-vs’,’./interface_testcase/test_interface.py::test_04_func’])
pytest.main([‘-vs’,’./interface_testcase/test_interface.py::Testinterface::test_03_zhiliao’])

pytest.main(['-vs', '--html=./report/report.html'])

2.命令行模式

(1)运行所有:pytest
(2)指定模块:pytest -vs test_login.py
(3)指定目录:pytest -vs ./interface_testcase
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成 
  pytest -vs ./interface_testcase/test_interface.py::test_04_func

参数详解:
-s:表示输出调试信息,包括 print打印的信息
-v:显示更详细的信息
-vs:这两个参数一起用
-n :支持多线程或者分布式运行测试用例
     如:pytest -vs ./testcase/test_login.py -n 2
--reruns NUM :失败用例重跑
-x:表示只要有一个用例报错,那么测试停止

--maxfail=2  出现两个用例失败就停止
-k :根据测试用例的部分字符串指定测试用例
    如:pytest -vs ./testcase -k “ao”
--html ./report/report.html :生成html的测试报告

生成的测试报告:

3.通过读取pytest.ini配置文件运行
 

 pytest.ini这个文件它是pytest单元测试框架的核心配置文件
1.位置:一般放在项目的根目录
2.编码:必须是ANSI,可以使用notepad++修改编码格式
3.作用:改变pytest默认的行为
4.运行的规则:不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。

[pytest]
addopts = -vs            #命令行的参数,用空格分隔
#addopts = -vs --html ../report/report.html 
testpaths = ./testcase     #测试用例的路径
python_files = test_*.py   #模块名的规则
python_classes = Test*    #类名的规则
python_functions = test   #方法名的规则
markers = 
smoke :冒烟用例
usermanage:用户管理模块
Productmanage:商品管理模块

 

六、pytest执行测试用例的顺序是怎样的呢?


unittest:ascii的大小来绝定执行的顺序
pytest:默认从上到下
改变默认的执行顺序:使用mark标记
@pytest.mark.run(order=3)

七、如何分组执行(冒烟,分模块执行,分接口和web执行)


smoke:冒烟用例,分布在各个模块里面
pytest -vs -m “smoke”
pytest -vs -m “smoke or usermanage”

ini配置了vs,输入命令行时,可以不写-vs
pytest -m “smoke”
pytest -m “smoke or usermanage”
pytest -m “smoke or usermanage or productmanage”

八、pytest跳过测试用例


(1)无条件跳过
@pytest.mark.skip(reason=”微微太漂亮”)
(2)有条件跳过
@pytest.mark.skipif(age>=18,reason=’已成年’)

 


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值