本文節(jié)選自霍格沃玆測試學(xué)院測試開發(fā)內(nèi)部教材逊朽,進階學(xué)習(xí)文末加群!
測試報告在項目中是至關(guān)重要的角色砰逻,一個好的測試報告:
- 可以體現(xiàn)測試人員的工作量旋恼;
- 開發(fā)人員可以從測試報告中了解缺陷的情況;
- 測試經(jīng)理可以從測試報告中看到測試人員的執(zhí)行情況及測試用例的覆蓋率统台;
- 項目負責人可以通過測試報告查看整個項目還余留多少問題雕擂,此次版本是否測試通過;
所以打造一個美觀贱勃、一目了然的測試報告井赌,清晰的反應(yīng)質(zhì)量問題谤逼,并提供給相關(guān)人員了解項目的整體狀態(tài),是非常必要的仇穗。
Pytest 結(jié)合 Allure 生成測試報告
Allure 框架是一種靈活的流部、輕量級、支持多語言測試報告工具纹坐,它不僅能夠以簡潔的 Web 報告形式顯示已測試的內(nèi)容枝冀,而且允許參與開發(fā)過程的每個人從測試的日常執(zhí)行中提取最大限度的有用信息。同時支持多種語言包括 Java耘子、Python果漾、JavaScript、Ruby谷誓、Groovy绒障、PHP、.Net片林、 Scala端盆。
安裝
Mac 可以使用 brew 安裝 allure,安裝命令如下:
brew install allure
其他操作系統(tǒng)請參考:
https://docs.qameta.io/allure/#_installing_a_commandline
與 pytest 結(jié)合需要安裝 allure-pytest 插件:
pip install allure-pytest
查看 Allure 版本:
allure --version
運行
第一步:在 pytest 執(zhí)行測試的時候费封,指定參數(shù) --alluredir 選項及結(jié)果數(shù)據(jù)保存的目錄焕妙,代碼如下:
pytest --alluredir=tmp/my_allure_results
tmp/my_allure_results 中保存了本次測試的結(jié)果數(shù)據(jù)。
第二步:打開報告弓摘,需要啟動 allure 服務(wù)焚鹊,在 terminal 中輸入 allure serve [path/to/allure_results],代碼如下:
allure serve path/to/allure_results
也可以使用 allure generate 生成 HTML 格式的測試結(jié)果報告韧献,并使用 allure open 來打開報告末患。
allure generate ./result/ -o ./report/ --clean
上面的命令將 ./result/ 目錄下的測試數(shù)據(jù)生成HTML測試報告到 ./report 路徑下,-–clean 選項目的是先清空測試報告目錄锤窑,再生成新的測試報告璧针,然后使用下面的命令打開報告。
allure open -h 127.0.0.1 -p 8883 ./report/
上面這個命令則會啟動一個 Web 服務(wù)將已經(jīng)生成的測試報告打開渊啰。打開生成的測試報告探橱,在默認的瀏覽器打開測試報告,報告如下:
上面的測試報告首頁中展示了此次測試的測試用例數(shù)量以及成功用例绘证、失敗用例隧膏、跳過用例的比例、測試環(huán)境嚷那、SUITES胞枕、FEATURES BY STORIES 等基本信息。當與 Jenkins 做了持續(xù)置成后魏宽,TREND 區(qū)域還將顯示腐泻,歷次測試的通過情況决乎。
首頁的左邊欄,還從不同的維度展示測試報告的其他信息贫悄。重點頁面介紹:
- Behaviors 頁面瑞驱,按照 FEATURES 和 STORIES 展示測試用例的執(zhí)行結(jié)果;
- Suites 頁面窄坦,Allure 測試報告將每一個測試腳本唤反,作為一個 Suite。在首頁里點擊 Suites 區(qū)域內(nèi)的任何一條 Suite鸭津,都會進入 Suites 頁面彤侍;
- Graphs 頁面,展示了此次測試結(jié)果的統(tǒng)計信息逆趋,比如測試用例執(zhí)行結(jié)果狀態(tài)盏阶、測試用例重要等級分布、測試用例執(zhí)行時間分布等闻书;
- 測試用例詳情頁面名斟,在 Suites 頁面上點擊任何一條測試用例,Suites 頁面的右側(cè)將展示這條用例的詳細執(zhí)行情況魄眉。在這個頁面可以看到測試用例的每個步驟砰盐,以及每個步驟的執(zhí)行結(jié)果,包括步驟里面添加的鏈接坑律、圖片岩梳、網(wǎng)頁片段或者視頻作為重要信息的補充。在這里可以一目了在的看到用例失敗的原因晃择。
實戰(zhàn)案例|百度搜索功能自動化測試
在實際項目中冀值,一旦用例報錯,我們希望能夠?qū)敃r應(yīng)用的狀態(tài)記錄下來,記錄這些狀態(tài)的方式可以是日志、截圖裆悄、視頻等手段,并將這些記錄在測試報告中抵栈,方便相關(guān)人員定位問題。我們基于 Pytest 與 Allure 結(jié)合生成測試報告來實現(xiàn)這個目標乌逐。
以百度 Web 網(wǎng)頁版本測試為例竭讳,百度首頁呈現(xiàn)的功能:新聞创葡、網(wǎng)頁浙踢、貼吧、知道灿渴、音樂洛波、圖片胰舆、視頻、地圖等蹬挤,我們以百度網(wǎng)頁的搜索功能為例缚窿,使用 Allure、pytest 結(jié)合 Selenium 自動化測試框架焰扳,完成一個搜索功能的測試倦零。
為了模擬百度搜索功能場景,這里需要創(chuàng)建兩個文件吨悍,數(shù)據(jù)文件與用例文件扫茅。首先創(chuàng)建數(shù)據(jù)管理文件 data/data.yml,代碼如下:
- allure
- pytest
- unittest
然后育瓜,創(chuàng)建用例文件名為 test_baidudemo.py葫隙,代碼如下:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import allure
import pytest
import yaml
from selenium import webdriver
import time
@allure.testcase("http://www.github.com")
@allure.feature("百度搜索")
@pytest.mark.parametrize('test_data1', yaml.safe_load(\
open("data/data.yml")))
def test_steps_demo(test_data1):
with allure.step("打開百度網(wǎng)頁"):
driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
driver.maximize_window()
with allure.step(f"輸入搜索詞:{test_data1}"):
driver.find_element_by_id("kw").send_keys(test_data1)
time.sleep(2)
driver.find_element_by_id("su").click()
time.sleep(2)
with allure.step("保存圖片"):
driver.save_screenshot("./result/b.png")
allure.attach.file("./result/b.png", \
attachment_type=allure.attachment_type.PNG)
with allure.step("關(guān)閉瀏覽器"):
driver.quit()
代碼解析:
- allure.testcase 用例標識,給定用例的鏈接躏仇,可以與用例的管理地址關(guān)聯(lián)恋脚。
- allure.feature 功能模塊劃分,方便管理和運行測試用例焰手。
- pytest.mark.parametrize 用來參數(shù)化測試用例糟描。
- allure.step 用來添加測試步驟,在測試報告里面會展示出來這個步驟說明册倒。
執(zhí)行:
pytest test_baidudemo.py -s -q --alluredir=./result/
allure serve ./result/
測試結(jié)果圖:
上面的測試報告展示運行時間蚓挤,時長,用例數(shù)驻子,通過率灿意,以及測試套件 SUITES,環(huán)境等信息崇呵。
點擊左側(cè)欄最下方的 Package 可以看到所有的測試用例以及測試數(shù)據(jù)缤剧,點擊一條用例右側(cè)會展示出用例的優(yōu)先級,數(shù)據(jù)域慷,測試步驟以及每個步驟的的名稱及附加的圖片等信息荒辕。這里添加了一個測試用例的鏈接,可以與測試用例的管理鏈接關(guān)聯(lián)起來犹褒,方便后期統(tǒng)計覆蓋率抵窒。
另外,pytest 與 Allure 也可以與 Jenkins 集成叠骑,實現(xiàn)自動化測試的持續(xù)集成李皇。
獲取更多相關(guān)資料:請?zhí)砑觱x,ceshiren001
https://qrcode.ceba.ceshiren.com/link?name=article&project_id=qrcode&from=jianshu×tamp=1652947920&author=MM
點擊查看