pytest单元测试

1、命名规则

2、pytest生成自带的html测试报告

3、Pytest调用语句

4、Pytest的运行方式

5、文件读取

1、读取CSV文件

2、读取xml文件

6、allure

1、Allure常用的几个特性

2、allure.feature

3、allure.story

4、with allure.step()

5、allure.attach

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

 	pip install pytest 和 pip install pytest-html  

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

	unittest:Setup>>  setupclass , teardown >> teardownclass(课堂作业)
	
	Pytest:   setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样)
	
	运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown
	
	运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class

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

	pip install pytest-html

案例一

	pytest.main(“模块.py”)【运行指定模块下,运行所有test开头的类和测试用例】
	
	pytest.main(["--html=./report.html","模块.py"])

在这里插入图片描述

案例二

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

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

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

案例三

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

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

3、Pytest调用语句

	pytst.main(['-x','--html=./report.html','t12est000.py'])
	
	-x出现一条测试用例失败就退出测试
	-v: 丰富信息模式, 输出更详细的用例执行信息
	-s:显示print内容
	-q: 简化结果信息,不会显示每个用例的文件名

在这里插入图片描述
扩充:

使用@pytest.mark.skip()跳过该用例(函数,在要跳过函数前调用)

	    @pytest.mark.skip()
	    def test001(self):
	        assert 2==2

在这里插入图片描述
4、Pytest的运行方式
. 点号,表示用例通过
F 表示失败 Failure
E 表示用例中存在异常 Error
在这里插入图片描述

5、文件读取
1、读取CSV文件

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

在这里插入图片描述

2、读取xml文件

	from xml.dom import minidom
	class Readxml():
	    def read_xml(self,filename,onename,twoname):
	        root =minidom.parse(filename)
	        firstnode =root.getElementsByTagName(onename)[0]
	        secondnode=firstnode.getElementsByTagName(twoname)[0].firstChild.data
	        return secondnode

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6、allure
介绍

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

配置环境变量
在这里插入图片描述
在这里插入图片描述

验证allure是否配置成功
在这里插入图片描述

其次要安装allure

	pip install allure-pytest

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

1、Allure常用的几个特性

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

2、allure.feature

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

3、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类型的测试报告
    
    #将测试报告转为html格式
    split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'  
    os.system(split)  # system函数可以将字符串转化成命令在服务器上运行

Pytest和allure效果展示
在这里插入图片描述
在这里插入图片描述
4、with allure.step()

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

5、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)

Pytest和allure效果展示
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值