Pytest框架相关知识点

Pytest测试框架

一、pytest 单元测试框架

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

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

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

三、pytest简介

		1.pytest是一个非常成熟的python的单元框架,比unittest更灵活。
		2.pytest可以和selneium,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  用于生成美观的测试报告。
	
	    放到require.txt中,通过pip install -r require.txt
	    验证是否安装成功:pytest --version

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

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

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

		1.主函数模式
			(1)运行所有:pytest.main()
			(2)指定模块:pytest.main(['-sv','test_login.py'])
			(3)指定目录:pytest.main(['-sv','./iner_testcase'])
			(4)通过nodeid指定用例运行:nodeid由模块名、分隔符、类名、方法名、函数名组成。
			   pytest.main(['-sv','./iner_testcase/test_login.py::test_04_func'])
		2.命令行模式
			(1)运行所以:pytest
			(2)指定模块:pytest -sv test_login.py
			(3)指定目录:pytest -sv ./iner_testcase
			(4)指定目录:pytest -sv ./iner_testcase/test_iner.py::test_04_func
		   示例:
		      pytest 文件名.py::类名::方法名                               (文件名)          (类名)            (方法名)
		      D:\Indoor_api\testcase\Indoor_reception_api>pytest -sv test_IndoorQt.py::Test_HomePage::test_Inf_HomePage_05

			   # 执行某1个文件下的所有用例
			   pytest -v xxxx.py
			   
			   # 执行某1一个文件下,某1个测试类中的所有用例
			   pytest -v xxxx.py::Test_xxxx
			
			   # 执行1个文件下,某1个测试类中的某1条用例
			   pytest -v xxxx.py::Test_xxxx::test_2_wrongPassword

参数详解:

		-s:表示输出调试信息,包裹print打印的信息
		-v:显示更详细的信息
		-sv:这个参数可以一起用
		-n:支持多线程或者分布式运行测试用例。
		   如:pytest -sv ./testcase/test_login.py -n 2
		
		--reruns Num:失败用例重跑 Num次数
		-x:表示只要有一个用例报错,那么测试停止。
		--maxfail=2 出现两个用例失败就停止。
		-k:根据测试用例的部分字符串指定测试用例。
		   如:pytest -sv ./testcase -k"lo"
		--html ./report/report.html:生成html的测试报告。


	3.通过读取pytest.ini配置文件运行。
	
		pytest.ini这个文件它是pytest单元测试框架的核心配置文件。
		1.位置:一般放在项目的根目录
		2.编码:必须是ANSI,可以使用notpad++修改编码格式。
		3.作用:改变pytest默认的行为。
		4.运行的规则:不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。
		[pytest]
		addopts = -sv --html ./report/log.html    #命令行的参数,用空格分隔
		testpaths = ./testcase                    #测试用例的路径
		python_files = test_*.py                  #模块名的规则
		python_classes = Test*                    #类名的规则
		python_functions = test                   #方法名的规则
		markers =
		    smoke:smoke 冒烟用例
		    usermanage:usermanage 用户管理模块
		    interface:interface 接口
		    UI:UI 界面

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

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

七、如何分组执行(冒烟,分模块执行,分接口和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提供了很多运行参数,比较常用的有:

		-k:只执行指定的用例
		-s:命令行显示测试代码的输出,如果需要输出html结果最好不要-s
		-v:显示详细信息
		-q:不显示详细信息
		--html=path:输出测试结果到html
		安装Pytest
		cmd运行
		pip install -U pytest
		 
		pip3 install pytest -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com
		查看版本
		pytest --version
		 
		知识点
		如果只执行 pytest ,会查找当前目录及其子目录下以  test_*.py  或 *_test.py 文件,找到文件后,在文件中找到以  test 开头函数并执行
		如果只想执行某个文件,可以 pytest start.py 
		加上-q,就是显示简单的结果: pytest -q start.py 
		 
		 
		Pytest用例的设计原则
		用Pytest写用例时候,一定要按照下面的规则去写,否则不符合规则的测试用例是不会执行的
		 
		文件名以 test_*.py 文件和*_test.py
		以  test_ 开头的函数
		以  Test 开头的类,不能包含 __init__ 方法
		以  test_ 开头的类里面的方法
		所有的包 pakege 必项要有__init__.py 文件

Pytest执行用例规则

注意,下面讲的都是在cmd中执行pytest命令

1、当前目录下所有的用例
pytest
 
先进入根目录,然后执行某个目录下的所有用例
pytest 文件夹名/
pytest d:/pyse/pytest/  # 指定测试目录
 
2、执行某一个 py 文件下用例 
pytest 脚本名称.py
  
 
3、运行start.py 模块里面的某个函数,或者某个类,某个类里面的方法
加v和不加-v都可以,加-v的话,打印的信息更详细
 
pytest -v 08_mark.py::TestClass::test_method
 
pytest 08_mark.py::TestClass::test_method
 
pytest start.py::test_answer
 
 
4、运行start.py 模块里面,测试类里面的某个方法
pytest start.py::TestClass::test_two
 
5、-m 标记表达式(后续讲解)
 pytest -m login
将运行用 @pytest.mark.login 装饰器修饰的所有测试,后面再展开讲标记哦
 
 
6、-q 简单打印,只打印测试用例的执行结果
 pytest -q start.py
 
 
7、-s 详细打印
 pytest -s start.py
 
 
8、-x 遇到错误时停止测试
pytest start.py -x
 
 
9、—maxfail=num,当用例错误个数达到指定数量时,停止测试
pytest start.py --maxfail=1
 
 
10、-k 匹配用例名称
执行测试用例名称包含http的所有用例
 
pytest -s -k http start.py
 
 
11、-k 根据用例名称排除某些用例
1 pytest -s -k "not http" start.py
 
 
12、-k 同时匹配不同的用例名称
pytest -s -k "method or weibo" start.py
pytest.main()运行测试用例
 
pytest.main():main中传入不同的指令用以执行指定测试用例
-s: 显示程序中的print/logging输出
-v: 丰富信息模式, 输出更详细的用例执行信息
-q: 安静模式, 不输出环境信息
-k :运行包含某个字符串的测试用例。如:pytest -k add XX.py 表示运行XX.py中包含add的测试用例。关键字匹配,用and区分:匹配范围(文件名、类名、函数名),

运行当前目录下所有(test_*.py 和 *_test.py)

pytest.main()
 
1、在命令行运行带上 -s 参数: pytest -s 
 
那么在 pytest.main() 里面等价于:
 
import pytest

带上-s参数

pytest.main(["-s"])
2、在命令行运行带上多个参数时: pytest -s -x 
 
那么在 pytest.main() 里面等价于:
 
import pytest

带上-s -x参数

pytest.main(["-s", "-x"])
 
 
运行指定路径下的用例
pytest.main(["d:/pyse/pytest/"])  # 指定测试目录
 
pytest.main(['./'])               # 运行./当前目录下所有(test_*.py  和 *_test.py)
 
pytest.main (['./subpath1'])    # 运行./subpath1 目录下用例
 
pytest.main (['./subpath1/test_module1.py'])    # 运行指定模块
 
pytest.main (['./subpath1/test_module1.py::test_m1_1'])  # 运行模块中的指定用例
 
pytest.main (['./subpath2/test_module2.py::TestM2::test_m2_02'])  # 运行类中的指定用例
 
pytest.main (['-k','pp'])         # 匹配包含pp的用例(匹配目录名、模块名、类名、用例名)
 
pytest.main(['-k','spec','./subpath1/test_module1.py'])     # 匹配test_module1.py模块下包含spec的用例
 
pytest.main(['-k','pp','./subpath2/test_module2.py::TestM2'])   # 匹配TestM2类中包含pp的用例

Pytest框架实现一些前后置(固件,夹具)的处理,常用三种。

一、setup/teardown,setup_class/teardown_class
为什么需要这些功能?
比如:web自动化执行用例之前,请问需要打开浏览器吗?用例执行后需要关闭浏览器?
class TestLeftrail():

    # 这个在所有的用例之前只执行一次
    def setup_class(self):
        print('\n在每个类执行前的初始化的工作:比如:创建日志对象,创建数据库的连接,创建接口的请求对象。')
    # 在每个用例之前执行一次
    def setup(self):
        print('\n在执行测试用例之前初始化的代码:打开浏览器,加载网页')

    def test_iner_01(self):

        print('午灵星')

    @pytest.mark.usermanage
    def test_iner_02(self):
        print('己灵星')



    def test_iner_03(self):
        print('申灵星')
        assert 1 == 2

    @pytest.mark.smoke
    def test_iner_04(self):
        print('未灵星')



    def test_iner_05(self):
        print('羊灵星')

    def teardown(self):
        print('\n在执行测试用例之后的扫尾代码:关闭浏览器')

    def teardown_class(self):
        print('在每个类执行猴的扫尾的工作:比如:销毁日志对象,销毁数据库的连接,销毁接口的请求对象。')

注意:和Unittest不一样,全是小写。

二、使用@pytest.fixture()装饰器来实现部分用例的前后置。

装饰器
@pytest.fixture(scope=“”,params=“”,autouse=“”,ids=“”,name=“”)

(1)scope表示的是被@pytest/fixture标记的方法的作用域。function(默认),class,module,
package/session.

(2)params:参数化(支持,列表[],元祖(),字典列表{{},{},{}},字典元祖({},{},{}))
import pytest

@pytest.fixture(scope=“function”,params=[‘灭却师’,‘死神’,‘坡面’])
def my_fixture(request):
return request.param
# print(‘这是前置的方法’)
# yield
# print(‘这是后置的方法’)

class TestLeftrail():


    def test_iner_01(self):

        print('午灵星')

    @pytest.mark.usermanage
    def test_iner_02(self,my_fixture):
        print('己灵星')
        print('-------------'+str(my_fixture))

params=[‘灭却师’,‘死神’,‘坡面’]这里params是参数名,有S。
request.param这里是属性名,是没有S的。
(3)autouse=True:自动执行,默认False

(4)ids:当使用params参数化时,给每一个值设置一个变量名。意义不大。
(5)name:给表示的是被@pytest.finxture标记的方法取一个别名。
当取了别名之后,那么原来的名称就用不了。

三、通过conftest.py和@pytest.finxture()结合使用实现全局的前置应用

(比如:项目的全局登录,模块的全局处理)
1.conftest.py文件是单独存放的一个夹具配置文件,名称是不能更改。
2.用处可以在不同的py文件中使用同一个fixture函数。
3.原则上conftest需要和运行的用例放到统一层。并且不需要做任何的import导入的操作。

总结:
setup/teardown,setup_class/teardown_class 它是作用于所有用例或者所有的类
@pytest.fixtrue()它的作用是既可以部分也可以全部前后置。
conftest.py和@pytest.fixtrue()结合使用,作用于全局的前后置。

四、断言

assert 1 == 2

五、pytest结合allure-pytest插件生成allure测试报告

pytest-html

allure-pytest

1.下载,解压,配置path路径
https://github.com/allure-framework/allure2/releases

path路径配置:D:\allure-2.19.0\bin

验证:allure --version

问题:dos可以验证但是pycharm验证失败,重启pycharm

2.加入命令生成json格式的临时报告
–alluredir ./temp

3.生成allure报告

os.system(‘allure generate ./temp -o ./report --clean’)

allure generate 命令,固定的
./temp 临时的json格式报告的路径
-o 输出的output
./report 生成的allure报告的路径
–clean 清空./report路径原来的报告

class Severity(str, Enum):
BLOCKER = ‘blocker’ # blocker:阻塞缺陷(功能未实现,无法下一步)
CRITICAL = ‘critical’ # critical:严重缺陷(功能点缺失)
NORMAL = ‘normal’ # normal: 一般缺陷(边界情况,格式错误)
MINOR = ‘minor’ # minor:次要缺陷(界面错误与ui需求不符)
TRIVIAL = ‘trivial’ # trivial: 轻微缺陷(必须项无提示,或者提示不规范)

DURATION TREND 持续时间趋势
RETRIES TREND 重试趋势
CATEGORIES TREND 类别趋势

pytest html报告乱码

尝试多种修改conftest的编码格式后,未能成功,最终直接修改python路径\Lib\site-packages\pytest_html内的html_report.py

将这句

head = html.head(html.meta(charset="utf-8"), html.title(self.title), html_css)

修改为:

head = html.head(html.meta(charset="GBK"), html.title(self.title), html_css)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值