Pytest 与allure测试报告集成

通过Feature, story, step 记录测试的功能,场景及测试步骤

复制代码
# login.py
'''
login_func函数
传入参数是name 和 password
当输入的name和password与数据库db_data中数据一致时,返回"XXX成功登录系统!"
当输入的name存在于数据库db_data但密码不正确时,返回"XXX账号,密码输出错误,请重新输入!"
当输入的name不存在于数据库db_data中时,返回"XXX账号不存在,请输入正确的账号!"
'''

def login_func(name,password):
	db_data = {"name": ['Jie', 'Jack', 'Jame'], "password": {'Jie': '123456', 'Jack': '111111', 'Jame': '222222'}}
	if name in db_data["name"] and str(password) == db_data["password"][name]:
		return(f"{name} 成功登录系统!")
	elif name in db_data["name"] and str(password) != db_data["password"][name]:
		return(f"{name} 账号,密码输出错误,请重新输入!")
	else:
		return(f"{name} 账号不存在,请输入正确的账号!")

login.py是一个登录模块,login_func函数主要实现登录功能

test_mod9.py主要实现对login.py中login_func函数功能测试

复制代码
from login import login_func

@allure.feature("测试登录模块")
class TestMod9:

	@allure.title("测试登录正例01")
	@allure.story("用正确的账号与密码登录")
	def test_login_01(self):
		name = "Jie"
		password = "123456"
		with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):
			login = login_func(name,password)
			exc = f"{name} 成功登录系统!"
			pytest.assume(login == exc)

	@allure.title("测试登录反例02")
	@allure.story("用正确的账号与错误的密码登录")
	def test_login_02(self):
		name = "Jie"
		password = "023456"
		with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):
			login = login_func(name,password)
			exc = f"{name} 账号,密码输出错误,请重新输入!"
			pytest.assume(login == exc)

	@allure.title("测试登录反例03")
	@allure.story("用不存在的账号进入登录")
	@allure.description("当登录账号不存在时,有正确的提示")
	def test_login_03(self):
		name = "Hele"
		password = "023456"
		with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):
			login = login_func(name, password)
			exc = f"{name} 不存在账号,请输入正确的账号!"
			pytest.assume(login == exc)

test_mod9.py测试模块中,包含一个class TestMod9 测试类,测试类下包含了测试登录功能的三个测试用例

@allure.feature("测试登录模块"): 在报告中记录测试需求(即测试用例集的功能,要测试什么)一般修饰测试类(testsuite);

@allure.story("用正确的账号与密码登录"):在报告中记录根据测试需求细化的测试场景(即测试用例场景描述)一般修饰测试用例即方法;

(注:feature与story属于父子关系)

@allure.title("测试登录反例03"):在报告中自定义测试用例标题

@allure.description("当登录账号不存在时,有正确的提示"):报告中测试用例的详细描述

with allure.step(f"使用账号名称:{name},密码:{password}进行登录"): 在报告中记录测试用例中的测试步骤或详细信息,放在测试用例的代码逻辑中;

  • -alluredir=./result/ 为指定报告结果数据存入路径,执行上述命令后会自动在该目录下生成一个result文件夹存放报告数据
复制代码
命令:allure serve ./result/

1、在本地启动一个server查看allure报告

2、根据result文件夹中的数据在项目目录下生成allure-report存入html报告

复制代码
命令:allure generate ./result/
命令:allure open ./allure-report 在本地启动查看allure报告的服务
命令:allure generate ./result/ -o ./allure-report/ --clean # 每次生成报告时先清除原报告数据
相关推荐
我的xiaodoujiao5 天前
API 接口自动化测试详细图文教程学习系列24--如何用Pytest去设计接口测试用例并执行
python·学习·测试工具·pytest
我的xiaodoujiao5 天前
API 接口自动化测试详细图文教程学习系列23--结合Pytest框架使用4-前后置处理
python·学习·测试工具·pytest
wanglei2007086 天前
pytest自动化测试框架项目架构
pytest
词元Max9 天前
2.12 pytest 实战:如何测试 AI 应用
人工智能·pytest
biter down10 天前
11:pytest 框架 assert 验证测试
服务器·windows·pytest
biter down10 天前
14:pytest-order 插件 顺序控制案例
开发语言·python·pytest
我的xiaodoujiao11 天前
API 接口自动化测试详细图文教程学习系列21--结合Pytest框架使用2--断言和插件
python·学习·测试工具·pytest
我的xiaodoujiao11 天前
API 接口自动化测试详细图文教程学习系列22--结合Pytest框架使用3-分组、跳过执行和参数化处理
python·学习·测试工具·pytest
测试员周周14 天前
【Appium 系列】第13节-混合测试执行器 — API + UI 的协同执行
开发语言·人工智能·python·功能测试·ui·appium·pytest