前提:需要安裝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
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()
def test001(self):
assert 2==2
三、Pytest的運行方式
. 點號,表示用例通過
F 表示失敗 Failure
E 表示用例中存在異常 Error
思考:實際開發中是直接assert 1==2嗎?
四、文件讀取
4.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())
4.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
五、Allure
Allure是一款輕量級并且非常靈活的開源測試報告框架。 它支持絕大多數測試框架, 例如TestNG、Pytest、JUint等。它簡單易用,易于集成。
-
首先配置allure的環境變量
Allure下載image -
驗證allure是否配置成功
image 其次要安裝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的用戶場景,即測試需求
案例
實現用戶登錄功能,場景為登錄成功和登錄失敗
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函數可以將字符串轉化成命令在服務器上運行
Pytest和allure效果展示
5.1.3 with allure.step()
用于描述測試步驟,將會輸出到報告中
5.1.4 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效果展示
作業
單元測試:通過讀取csv/xml數據并且結合使用allure展示測試報告,驗證開發中的add()和reduct()操作(在@allure.story分別實現相加減)
作者:XiaoQu
鏈接:http://www.lxweimin.com/u/21209aff37c1
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。