标题目录
一、概述
二、环境搭建
三、编写规则
四、Selenium+Pytest案例实操
五、扩展插件
六、conftest配置
七、最后
一、概述
Selenium:
1、基于JavaScript代码库的自动化测试框架,通过脚本语言,模拟用户行为操作,最接近用户真实场景,实现对web自动测试。
2、Selenium,是目前的最火爆企业最主流的webUI自动化框架
Pytest:
1、Pytest是一个非常成熟的全功能的Python测试框架,是unittest框架的扩展,主要特点有以下几点:
(1)简单灵活,非常方便的组织自动化测试用例;
(2)支持参数化,可以细粒度地控制要测试的测试用例;
(3)能够支持简单的单元测试和复杂的功能测试,比如web端selenium/移动端appnium等自动化测试、request接口自动化测试;
(4)pytest具有很多第三方插件,并且可以自定义扩展,比如测试报告生成,失败重运行机制;
(5)测试用例的skip和fail处理;
(6)结合业界最美的测试报告allure+Jenkins,持续集成。
二、环境搭建
pip install - U pytest
pytest-xdist #多线程
pip install - U pytest-rerunfailures #重试运行cases
pip install pytest-html #生成测试报告
pytest --version # 会展示当前已安装版本
三、编写规则
编写pytest测试样例非常简单,只需要按照下面的规则:
(1) 测试文件以test_开头(以test结尾也可以);
(2)测试类以Test开头,并且不能带有 init 方法;
(3)测试函数以test开头;
(4)断言使用基本的assert即可。
四、Selenium+Pytest案例实操
import pytest # 引入pytest包
def test_a(): # test开头的测试函数
print("------->test_a")
assert 1 # 断言成功
def test_b():
print("------->test_b")
assert 0 # 断言失败
if __name__ == '__main__':
pytest.main(['-s', 'class01.py'])
可以包含一个或多个Test开头的测试类,test_开头的函数
1、测试类主函数模式
pytest.main([’-s’, ‘test.py’])
2、命令行模式运行
pytest 文件路径/测试文件名
五、扩展插件
1、测试报告: pytest-html
pytest.main([’-s’,‘test.py’,’–html=./report/result.html’])
:表示当前路径下生成report文件夹,result.html文件
2、批量运行用例:pytest-xdist
pytest.main([’-s’,‘test.py’,’–html=./report/result.html’,’-n=2’])
-n=2 表示2个线程并发运行所有的测试用例
3、allure测试报告:allure-pytest
运行用例:pytest.main([’-s’, ‘-q’, ‘–alluredir’, ‘./report/xml’])
pytest 测试目标文件 --alluredir 数据目录
运行后的结果,是生成xml的数据集合
生成报告:allure generate --clean ./report/xml/ -o ./results/html/
第一个是数据集目录,第二个是生成报告目录
-o是指向目标生成测试报告的目录;
六、conftest配置
当自动化用例越来越庞大的时候,很多用例的数据可以共享,复用,让用例脚本可读性,维护性更高,比如登录等
conftest.py 配置里可以实现数据共享,比如py跨文件共享前置
conftest.py配置脚本名称是固定的,不能改名称
不需要import导入 conftest.py,pytest用例会自动查找
使用Pytest框架后,能深深地感受到它的可扩展性和灵活性,再也不用担心自动化效率低了。
七、最后
对软件测试、接口测试、自动化测试、软件测试零基础入门、性能测试、LR脚本开发、python自动化全栈、面试经验感兴趣可以175317069,群内会有不定期的发放免费的资料链接。如果你有好的学习也资料可以私聊发我,我会注明出处之后分享给大家。
喜欢的话,欢迎【点赞】、【关注】、【喜欢】礼貌三连喔!