偵錯測試
Playwright Inspector
Playwright Inspector 是一個 GUI 工具,可以幫助您偵錯 Playwright 測試。它讓您可以逐步執行測試、即時編輯定位器、挑選定位器並查看可操作性記錄。

在偵錯模式中執行
設定 PWDEBUG
環境變數以在偵錯模式下執行您的 Playwright 測試。這會設定 Playwright 進行偵錯並開啟檢查器。當設定 PWDEBUG=1
時,會設定額外的實用預設值:
- 瀏覽器以有頭模式啟動
- 預設逾時設定為 0(= 無逾時)
- Bash
- PowerShell
- Batch
PWDEBUG=1 pytest -s
$env:PWDEBUG=1
pytest -s
set PWDEBUG=1
pytest -s
逐步執行您的測試
您可以使用檢查器頂部的工具列來播放、暫停或逐步執行測試的每個動作。您可以在測試程式碼中看到當前動作被突出顯示,匹配的元素也會在瀏覽器視窗中被突出顯示。

從特定斷點執行測試
為了加速偵錯過程,您可以在測試中加入 page.pause() 方法。這樣您就不必逐步執行測試的每個動作來到達您想要偵錯的點。
- Sync
- Async
page.pause()
await page.pause()
一旦您新增了 page.pause()
呼叫,在偵錯模式下執行您的測試。點選檢查器中的「Resume」按鈕會執行測試,並且只會在 page.pause()
處停止。

即時編輯定位器
在偵錯模式下執行時,您可以即時編輯定位器。在 'Pick Locator' 按鈕旁邊有一個欄位顯示測試暫停處的定位器。您可以直接在 Pick Locator 欄位中編輯此定位器,匹配的元素會在瀏覽器視窗中被突出顯示。

挑選定位器
在偵錯時,您可能需要選擇更具彈性的定位器。您可以透過點選 Pick Locator 按鈕並在瀏覽器視窗中滑鼠游標停留在任何元素上來實現。當滑鼠游標停留在元素上時,您會看到下方突出顯示的定位此元素所需的程式碼。在瀏覽器中點選元素會將定位器新增到欄位中,然後您可以調整它或將其複製到程式碼中。

Playwright 會檢視您的頁面並找出最佳的定位器,優先使用角色、文字和測試 ID 定位器。如果 Playwright 找到多個符合該定位器的元素,它會改進定位器使其具有彈性並唯一識別目標元素,因此您不必擔心因定位器導致測試失敗。
可操作性記錄
當 Playwright 在點選動作上暫停時,它已經執行了可在記錄中找到的可操作性檢查。這可以幫助您了解測試期間發生了什麼,以及 Playwright 做了什麼或嘗試做什麼。記錄會告訴您元素是否可見、已啟用且穩定、定位器是否解析為元素、是否捲動到檢視區等等。如果無法達到可操作性,它會將動作顯示為待處理。

Trace Viewer
Playwright Trace Viewer 是一個 GUI 工具,讓您可以探索測試的錄製 Playwright 追蹤。您可以在左側前後瀏覽每個動作,並在動作期間直觀地看到發生了什麼。在螢幕中央,您可以看到動作的 DOM 快照。在右側,您可以看到動作詳細資訊,例如時間、參數、返回值和記錄。您也可以探索主控台訊息、網路請求和原始碼。
若要了解更多關於如何錄製追蹤和使用 Trace Viewer 的資訊,請查看 Trace Viewer 指南。
瀏覽器開發者工具
當使用 PWDEBUG=console
在偵錯模式下執行時,開發者工具主控台中會有一個 playwright
物件可用。開發者工具可以幫助您:
- 檢視 DOM 樹並尋找元素選擇器
- 查看主控台記錄執行期間(或學習如何透過 API 讀取記錄)
- 檢查網路活動和其他開發者工具功能
這也會將 Playwright 的預設逾時設定為 0(= 無逾時)。

要使用瀏覽器開發者工具偵錯測試,首先使用 page.pause() 方法在測試中設定斷點來暫停執行。
- Sync
- Async
page.pause()
await page.pause()
一旦您在測試中設定了斷點,您就可以使用 PWDEBUG=console
執行測試。
- Bash
- PowerShell
- Batch
PWDEBUG=console pytest -s
$env:PWDEBUG=console
pytest -s
set PWDEBUG=console
pytest -s
一旦 Playwright 啟動瀏覽器視窗,您就可以開啟開發者工具。playwright
物件將在主控台面板中可用。
playwright.$(selector)
使用實際的 Playwright 查詢引擎查詢 Playwright 選擇器,例如:
playwright.$('.auth-form >> text=Log in');
<button>Log in</button>
playwright.$$(selector)
與 playwright.$
相同,但返回所有匹配的元素。
playwright.$$('li >> text=John')
[<li>, <li>, <li>, <li>]
playwright.inspect(selector)
在元素面板中顯示元素。
playwright.inspect('text=Log in')
playwright.locator(selector)
建立定位器並查詢匹配的元素,例如:
playwright.locator('.auth-form', { hasText: 'Log in' });
Locator ()
- element: button
- elements: [button]
playwright.selector(element)
為給定元素生成選擇器。例如,在元素面板中選擇一個元素並傳遞 $0
:
playwright.selector($0)
"div[id="glow-ingress-block"] >> text=/.*Hello.*/"
冗長的 API 記錄
Playwright 支援使用 DEBUG
環境變數進行冗長記錄。
- Bash
- PowerShell
- Batch
DEBUG=pw:api pytest -s
$env:DEBUG="pw:api"
pytest -s
set DEBUG=pw:api
pytest -s
對於 WebKit:在執行期間啟動 WebKit Inspector 會阻止 Playwright 腳本進一步執行,並會重設預先設定的使用者代理和裝置模擬。
Headed mode
Playwright 預設在無頭模式下執行瀏覽器。要改變此行為,請使用 headless: false
作為啟動選項。
您也可以使用 slow_mo 選項來減慢執行速度(每次操作 N 毫秒)並在偵錯時跟隨。
- Sync
- Async
# Chromium, Firefox, or WebKit
chromium.launch(headless=False, slow_mo=100)
# Chromium, Firefox, or WebKit
await chromium.launch(headless=False, slow_mo=100)