第十六單元 單元測(cè)試之pytest

前提:需要安裝pytest和pytest-html(生成html測(cè)試報(bào)告)

pip install pytest 和 pip install pytest-html  

一、命名規(guī)則
Pytest單元測(cè)試中的類名和方法名必須是以test開頭,執(zhí)行中只能找到test開頭的類和方法,比unittest更加嚴(yán)謹(jǐn)

案例

import pytest
from xml.dom import minidom
class TestPy01():
def testPy001(self):
    print("第一個(gè)pytest")
    assert 1==1

def testPy002(self):
    print("第二個(gè)pytest")
    assert 1==2

def testPy003(self):
    print("第三個(gè)pytest")
    assert 1 == 1
if __name__ == '__main__':
pytest.main()

unittest:Setup>>  setupclass , teardown >> teardownclass(課堂作業(yè))
Pytest:   setup, setup_class和teardown, teardown_class函數(shù)(和unittest執(zhí)行效果一樣)

運(yùn)行于測(cè)試方法的始末,即:運(yùn)行一次測(cè)試函數(shù)會(huì)運(yùn)行一次setup和teardown
運(yùn)行于測(cè)試方法的始末,但是不管有多少測(cè)試函數(shù)都只執(zhí)行一次setup_class和 teardown_class

二、Pytest生成自帶的html測(cè)試報(bào)告
前提條件:需要下載pytest-html模塊(python自帶的生成測(cè)試報(bào)告模塊)

pip install pytest-html

2.1 方式一
格式

pytest.main("模塊.py")【運(yùn)行指定模塊下,運(yùn)行所有test開頭的類和測(cè)試用例】
pytest.main(["--html=./report.html","模塊.py"])

代碼:
pytest.main(["--html=../report1.html", "test_01.py"])

```
image

2.2 方式二

  • 格式
    運(yùn)行指定模塊指定類指定用例,冒號(hào)分割,并生成測(cè)試報(bào)告

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

運(yùn)行指定模塊指定類指定用例,冒號(hào)分割,并生成測(cè)試報(bào)告
代碼

pytest.main(["--html=../report1.html", "test_01.py::TestPy01::testPy001"])

2.3 方式三(無(wú)效)

格式
直接執(zhí)行pytest.main() 【自動(dòng)查找當(dāng)前目錄下,以test_開頭的文件或者以_test結(jié)尾的py文件】(課堂練習(xí)_test)

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

代碼:

  pytest.main(["--html=../report1.html"])

2.4 方式四
Pytest調(diào)用語(yǔ)句

  pytst.main(['-x','--html=./report.html','t12est000.py'])

-x:出現(xiàn)一條測(cè)試用例失敗就退出測(cè)試
-v:豐富信息模式, 輸出更詳細(xì)的用例執(zhí)行信息
-s:顯示print內(nèi)容
-q:簡(jiǎn)化結(jié)果信息,不會(huì)顯示每個(gè)用例的文件名

擴(kuò)充:跳過(guò)
使用@pytest.mark.skip()跳過(guò)該用例(函數(shù))

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

三、Pytest的運(yùn)行方式

      . 點(diǎn)號(hào),表示用例通過(guò)
      F 表示失敗 Failure
      E 表示用例中存在異常 Error

image

思考:實(shí)際開發(fā)中是直接assert 1==2嗎?
四、文件讀取
4.1 讀取csv文件
先創(chuàng)建文件,然后讀取

  import csv   #導(dǎo)入csv模塊
  class ReadCsv():
      def read_csv(self):
        item =[]    #定義一個(gè)空列表
    c = csv.reader(open("../commonDemo/test1.csv","r"))    #得到csv文件對(duì)象
    for csv_i in c:
        item.append(csv_i)      #將獲取的數(shù)據(jù)添加到列表中
    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是一款輕量級(jí)并且非常靈活的開源測(cè)試報(bào)告框架。 它支持絕大多數(shù)測(cè)試框架, 例如TestNG、Pytest、JUint等。它簡(jiǎn)單易用,易于集成。

  • 首先配置allure的環(huán)境變量
    Allure下載

    image
  • 驗(yàn)證allure是否配置成功

    image
  • 其次要安裝allure

  pip install allure-pytest

allure-pytest是Pytest的一個(gè)插件,通過(guò)它我們可以生成Allure所需要的用于生成測(cè)試報(bào)告的數(shù)據(jù)

5.1 Allure常用的幾個(gè)特性

@allure.feature # 用于描述被測(cè)試產(chǎn)品需求
@allure.story # 用于描述feature的用戶場(chǎng)景,即測(cè)試需求
with allure.step(): # 用于描述測(cè)試步驟,將會(huì)輸出到報(bào)告中
allure.attach # 用于向測(cè)試報(bào)告中輸入一些附加的信息,通常是一些測(cè)試數(shù)據(jù),截圖等

5.1.1 allure.feature

@allure.feature # 用于描述被測(cè)試產(chǎn)品需求

5.1.2 allure.story

@allure.story # 用于描述feature的用戶場(chǎng)景,即測(cè)試需求

案例
實(shí)現(xiàn)用戶登錄功能,場(chǎng)景為登錄成功和登錄失敗

  import pytest,allure,os
  class TestClass005():
@allure.feature("用戶登錄功能")#用于定義被測(cè)試的功能,被測(cè)產(chǎn)品的需求點(diǎn)
@allure.story("登錄成功")     #用于定義被測(cè)功能的用戶場(chǎng)景,即子功能點(diǎn)
def test_success(self):
    assert 1==1
@allure.feature("用戶登錄功能")#用于定義被測(cè)試的功能,被測(cè)產(chǎn)品的需求點(diǎn)
@allure.story("登錄失敗")     #用于定義被測(cè)功能的用戶場(chǎng)景,即子功能點(diǎn)
def test_fail(self):
    assert 1==2
  if __name__ == '__main__':
pytest.main(['--alluredir', 'report/result', 'test_06.py'])  #生成json類型的測(cè)試報(bào)告
split = 'allure ' + 'generate ' + './report/result ' + '-o ' + './report/html ' + '--clean'  #將測(cè)試報(bào)告轉(zhuǎn)為html格式
os.system(split)  # system函數(shù)可以將字符串轉(zhuǎn)化成命令在服務(wù)器上運(yùn)行
Pytest和allure效果展示
image

5.1.3 with allure.step()

用于描述測(cè)試步驟,將會(huì)輸出到報(bào)告中

5.1.4 allure.attach

用于向測(cè)試報(bào)告中輸入一些附加的信息,通常是一些測(cè)試數(shù)據(jù),截圖等

案例
實(shí)現(xiàn)產(chǎn)品信息展示,車展中的各種車的品牌

import pytest,os,allure
class TestShop():
@allure.feature("購(gòu)物車")
@allure.story("產(chǎn)品展示")
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效果展示
image

作業(yè)
單元測(cè)試:通過(guò)讀取csv/xml數(shù)據(jù)并且結(jié)合使用allure展示測(cè)試報(bào)告,驗(yàn)證開發(fā)中的add()和reduct()操作(在@allure.story分別實(shí)現(xiàn)相加減)

作者:XiaoQu
鏈接:http://www.itdecent.cn/u/21209aff37c1
來(lái)源:簡(jiǎn)書
著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容