下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第Playwright元素截圖并保存至allure的實現示例目錄引言問題分析快速截圖:代碼示例(以Playwright為例)
引言
在UI自動化測試中,我們經常需要獲取屏幕截圖,尤其是在CI環(huán)境中,一般是使用瀏覽器的無頭模式執(zhí)行測試,此時對關鍵步驟進行頁面截圖就很重要了。通常自動化框架都提供了頁面截圖功能,但是基本都是只提供了頁面整體的截圖或者對頁面元素單獨截圖,無法做到在頁面整體截圖中將我想要的元素標記出來(比如紅框標出),而這種截圖在某些預期結果的場景下需要經常用到,比如人工輔助結果判斷,或者在結果判斷不正確時標記出不正確的元素以幫助錯誤排查。因此,在項目中單獨封裝了標記元素的截圖方法。
問題分析
獲取屏幕截圖:這個很簡單,直接通過page.screenshot方法就可以獲得
獲取元素位置:通過ElementHandle.bounding_box獲得元素的邊界信息
在截圖中標記出元素:通過PIL(python3使用pillow庫)和獲取到的元素位置將元素標記出來
在報告中展示:這里選用的是allure作為測試報告框架,將最終結果保存至allure報告即可
需要注意的是,由截圖生成PIL.Image對象,和編輯之后保存至allure,都需要通過io.BytesIO進行中轉
快速截圖:
screenshot方法可以進行截圖,參數如下:
timeout:以毫秒為單位的超時時間,0為禁用超時
path:設置截圖的路徑
type:圖片類型,默認jpg
quality:像素,不適用于jpg
omit_background:隱藏默認白色背景,并允許捕獲具有透明度的屏幕截圖。不適用于“jpeg”圖像。
full_page:如果為true,則獲取完整可滾動頁面的屏幕截圖,而不是當前可見的視口。默認為`假`。
clip:指定結果圖像剪裁的對象clip={'x':10,'y':10,'width':10,'height':10}
代碼示例(以Playwright為例)
fromioimportBytesIO
importallure
fromPILimportImage,ImageDraw
fromplaywright.sync_apiimportsync_playwright
defhighlight_screenshot(page,element,tips='高亮截圖'):
#滾動頁面將元素移動到視野中
element.scroll_into_view_if_needed()
#獲取元素的位置信息
box=element.bounding_box()
x,y,width,height=box['x'],box['y'],box['width'],box['height']
#獲取頁面截圖,并讀取為PIL.Image對象
png=page.screenshot(type='png')
img=Image.open(BytesIO(png))
#利用元素的位置信息在頁面截圖中標記出元素
draw=ImageDraw.Draw(img)
draw.rectangle((x,y,x+width,y+height),outline='red',width=3)
#將標記后的截圖保存至allure報告中
withBytesIO()asoutput:
img.save(output,format='png')
allure.attach(output.getvalue(),tips,allure.attachment_type.PNG)
deftest_screenshot():
withsync_playwright()aspw:
#打開百度進行搜索
browser=pw.chromium.launch()
page=browser.new_page()
page.goto('')#跳轉至百度頁面
page.fill('#kw','playwright選擇器')#搜索框中輸入內容
page.click('#su')#點擊搜索按鈕
#等待搜索結果加載
page.wait_for_load_state('networkidle')
#判斷當前頁面顯示10條搜索結果
results=page.query_selector_all('h3')
assertlen(results)==10
#將當前頁面的搜索結果分別進行截圖
fori,resulti
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 安全標準化生產責任制度
- 生產安全考核與獎勵制度
- 生產車輛全過程管理制度
- 生產場所巡檢制度范本
- 企業(yè)生產檔案管理制度
- 生產副班長生產管理制度
- 2026重慶市涪陵區(qū)武陵山鎮(zhèn)人民政府招聘公益性崗位1人參考考試題庫附答案解析
- 生產車間防蠅蟲制度
- 生產函數與科學制度
- 先進生產班組管理制度
- 腎囊腫護理查房要點
- 2025年掛面制造行業(yè)研究報告及未來發(fā)展趨勢預測
- 7.1《集體生活成就我》課件 2025-2026道德與法治七年級上冊 統(tǒng)編版
- 艾媒咨詢2025年中國新式茶飲大數據研究及消費行為調查數據
- 遼寧省錦州市2024-2025學年八年級下學期期末物理試題(含答案)
- 頂管施工臨時用電方案
- 廣東省惠州市高三上學期第一次調研考英語試題-1
- 瀘州老窖釀酒有限責任公司釀酒廢棄物熱化學能源化與資源化耦合利用技術環(huán)評報告
- 單位微信群規(guī)定管理制度
- 公司人員服從管理制度
- 床上護理洗頭課件
評論
0/150
提交評論