微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Pytest框架入门到精通一

Python测试框架之前一直用的是unittest+HTMLTestRunner,听到有人说Pytest很好用,所以这边给大家介绍一下Pytest的使用

在这里插入图片描述

pytest是一个非常成熟的全功能的Python测试框架,主要有一下几个特点:

1、简单灵活,容易上手

2、支持参数化能够支持简单的单元测试和复杂的功能测试,还可以用来做Selenium/Appnium/接口自动化测试

3、Pytest具有很多第三方的插件,并且可以自定义扩展,比较好用的如Pytest-Selenium、pytest-html、pytest-rerunfailures、pytest-xdist等

4、测试用例的skip和xfail处理可以很好的鸡儿Jenkins集成report框架----allure也支持了pytest

一、Pytest单元测试框架

在这里插入图片描述

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

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

(1)、什么是自动化测试框架
	它就是自动化测试组长针对一个项目开发的一个代码框架,这个框架封装了很多的基础模块,报告模块等。	
	
(2)、作用
	1、提高测试效率,降低自动化用例的维护成本。
	2、减少人工干预,提高测试准确性,增加代码的重用性。
    3、核心思想是让不懂代码的人也能通过这个框架去实现自动化测试。
    
(3)、pytest单元测试框架和自动化测试框架的关系。
	1、pytest单元测试框架:只是自动化测试框架中的组成部分之一。
	2、pom设计模式:只是自动化测试框架中的组成部分之一。
	3、数据驱动:.....
	4、关键字驱动
	5、全局配置
	6、文件的封装
	7、日志监控selenium,requests二次封装
	8、断言
	9、报告邮件等。

三、Pytest简介

在这里插入图片描述

1.pytest是一个非常成熟的python的单元框架,比unittest更灵活。

2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自动化。

3.pytest可以实现测试用例的跳过以及reruns失败用例重试。

4.pytest可以和allure生成非常美观的测试报告。

5.pytest可以和Jenkins持续集成。

6.pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作。
pytest
pytest-xdist    测试用例分布式执行。多cpu分发。
pytest-ordering    用于改变测试用例的执行顺序(从上到下)
pytest-rerunfailures   用例失败后重跑
pytest-html   (生成html格式的自动化测试报告)
allure-pytest  用于生成美观的测试报告

四、使用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'])

(2).命令行模式
	1、运行所有:pytest 
	2、指定模块:pytest -vs test_login.py 
	3、指定目录:pytest -vs ./interface_testcase 
	4、指定目录: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,可以使用notpad++修改编码格式。 
	3.作用:改变pytest认的行为。 
	4.运行的规则;不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。 
	
[pytest] 
	addopts = -vs   #命令行的参数,用空格分隔 
	
	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 -m "smoke" 
pytest -m "smoke or usermanage or productmanage

八、pytest跳过测试用例

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

九、总结

本文共有三集,并且对Pytest的讲解有配套的视频,如果你想要免费获取这套视频或者此文对你有帮助,或者你对此文有任何疑问,
欢迎加入软件测试技术群:798478386,群里发放的免费资料都是笔者十多年测试生涯的精华。还有同行大神一起交流技术哦。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐