pytest

前提:需要安装pytest和pytest-html(生成html测试报告)

pip install pytest 和 pip install pytest-html

一、命名规则

Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨

运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown

运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class

二、Pytest生成自带的html测试报告

前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)

pip install pytest-html

2.1 方式一

格式

pytest.main("模块.py")【运行指定模块下,运行所有test开头的类和测试用例】

pytest.main(["--html=./report.html","模块.py"])

代码:

pytest.main(["--html=../report1.html", "test_01.py"])

2.2 方式二

格式

运行指定模块指定类指定用例,冒号分割,并生成测试报告

pytest.main([‘--html=./report.html’,‘模块.py::类::test_a_001'])

运行指定模块指定类指定用例,冒号分割,并生成测试报告

代码

pytest.main(["--html=../report1.html", "test_01.py::TestPy01::testPy001"])

2.3 方式三(无效)

格式

直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】(课堂练习_test)

pytest.main([‘--html=./report.html’])

代码:

pytest.main(["--html=../report1.html"])

2.4 方式四

Pytest调用语句

pytst.main(['-x','--html=./report.html','t12est000.py'])

-x:出现一条测试用例失败就退出测试-v:丰富信息模式, 输出更详细的用例执行信息-s:显示print内容-q:简化结果信息,不会显示每个用例的文件名

扩充:跳过

使用@pytest.mark.skip()跳过该用例(函数)

@pytest.mark.skip()deftest001(self):assert2==2

三、Pytest的运行方式

.点号,表示用例通过F表示失败 FailureE表示用例中存在异常 Error

四、文件读取

4.1 读取csv文件

先创建文件,然后读取

importcsv#导入csv模块classReadCsv():defread_csv(self):item=[]#定义一个空列表c=csv.reader(open("../commonDemo/test1.csv","r"))#得到csv文件对象forcsv_iinc:item.append(csv_i)#将获取的数据添加到列表中returnitem            r=ReadCsv()print(r.read_csv())

4.2 读取xml文件

fromxml.domimportminidomclassReadxml():defread_xml(self,filename,onename,twoname):root=minidom.parse(filename)firstnode=root.getElementsByTagName(onename)[0]secondnode=firstnode.getElementsByTagName(twoname)[0].firstChild.datareturnsecondnode

五、Allure

Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。

首先配置allure的环境变量

验证allure是否配置成功

其次要安装allure

pip install allure-pytest

allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据

5.1 Allure常用的几个特性

@allure.feature# 用于描述被测试产品需求@allure.story# 用于描述feature的用户场景,即测试需求with allure.step():# 用于描述测试步骤,将会输出到报告中allure.attach# 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等

5.1.1 allure.feature

@allure.feature # 用于描述被测试产品需求

5.1.2 allure.story

@allure.story # 用于描述feature的用户场景,即测试需求

5.1.3 with allure.step()

用于描述测试步骤,将会输出到报告中

5.1.4 allure.attach

用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容