前提:需要安装pytest和pytest-html(生成html测试报告)
pip install pytest 和 pip install pytest-html
命名规则
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨 案例
import pytest
from xml.dom import minidom
class TestPy01():
def testPy001(self):
print("第一个pytest")
assert 1==1
def testPy002(self):
print("第二个pytest")
assert 1==2
def testPy003(self):
print("第三个pytest")
assert 1 == 1
if __name__ == '__main__':
pytest.main()
unittest:Setup>> setupclass , teardown >> teardownclass(课堂作业)
Pytest: setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样)
运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown 运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class
Pytest生成自带的html测试报告
前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)
pip install pytest-html
加粗样式方式一 格式 pytest.main(“模块.py”)【运行指定模块下,运行所有test开头的类和测试用例】
pytest.main(["--html=./report.html","模块.py"])
pytest.main(["--html=../report1.html", "test_01.py"])
方式二 格式 运行指定模块指定类指定用例,冒号分割,并生成测试报告
pytest.main([‘--html=./report.html’,‘模块.py::类::test_a_001'])
运行指定模块指定类指定用例,冒号分割,并生成测试报告 代码
pytest.main(["--html=../report1.html", "test_01.py::TestPy01::testPy001"])
方式三(无效) 格式 直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】(课堂练习_test)
pytest.main([‘--html=./report.html’])
代码:
pytest.main(["--html=../report1.html"])
方式四 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
Pytest的运行方式 . 点号,表示用例通过 F 表示失败 Failure E 表示用例中存在异常 Error
思考:实际开发中是直接assert 1==2吗?
文件读取 4.1 读取csv文件 先创建文件,然后读取
import csv
class ReadCsv():
def read_csv(self):
item =[]
c = csv.reader(open("../commonDemo/test1.csv","r"))
for csv_i in c:
item.append(csv_i)
return item
r = ReadCsv()
print(r.read_csv())
读取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
Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。
首先配置allure的环境变量
其次要安装allure
pip install allure-pytest
allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据
Allure常用的几个特性
@allure.feature
@allure.story
with allure.step():
allure.attach
allure.feature
@allure.feature
allunre.troy
@allure.story
案例 实现用户登录功能,场景为登录成功和登录失败
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'])
split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'
os.system(split)
Pytest和allure效果展示
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)
|