需要安装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
案例:
案例三:
直接执行pytest.main()
pytest.main([‘--html=./report.html’])
Pytest调用语句
扩充:跳过
使用@pytest.mark.skip()跳过该用例(函数)
@pytest.mark.skip()
def test001(self):
assert 2==2
Pytest的运行方式
文件读取
读取csv文件
读取xml文件
allure
Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。
配置allure的环境变量
pip install allure-pytest
Allure常用的几个特性
@allure.feature # 用于描述被测试产品需求
@allure.story # 用于描述feature的用户场景,即测试需求
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
allure.feature:@allure.feature # 用于描述被测试产品需求
allure.story:@allure.story # 用于描述feature的用户场景,即测试需求
import pytest,allure,os
class TestClass005():
@allure.feature("用户登录功能")#用于定义被测试的功能,被测产品的需求点
@allure.story("登录成功") #用于定义被测功能的用户场景,即子功能点
def test_success(self):
assert 1==1
@allure.feature("用户登录功能")#用于定义被测试的功能,被测产品的需求点
@allure.story("登录失败") #用于定义被测功能的用户场景,即子功能点
def test_fail(self):
assert 1==2
if __name__ == '__main__':
pytest.main(['--alluredir', 'report/result', 'test_06.py']) #生成json类型的测
试报告
split = 'allure ' + 'generate ' + './report/result ' + '-o ' +
'./report/html ' + '--clean' #将测试报告转为html格式
os.system(split) # system函数可以将字符串转化成命令在服务器上运行
with allure.step():用于描述测试步骤,将会输出到报告中
allure.attach:用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
import pytest,os,allure
class TestShop():
@allure.feature("购物车")
@allure.story("产品展示")
def testshow(self):
with allure.step("查看哈吉利系列车信息"):
allure.attach("博越","吉利")
with allure.step("查看哈弗系列车信息"):
allure.attach("H7","哈弗")
if __name__ == '__main__':
pytest.main(['--alluredir', 'report/result', 'test_07.py'])
split = 'allure ' + 'generate ' + './report/result ' + '-o ' +
'./report/html ' + '--clean'
os.system(split)
作业: