メインコンテンツにスキップ

ダイアログ

導入

Playwright は、ウェブページのダイアログ(alertconfirmpromptbeforeunload 確認など)を操作できます。印刷ダイアログについては、印刷を参照してください。

alert(), confirm(), prompt() ダイアログ

デフォルトでは、ダイアログは Playwright によって自動的に閉じられるため、処理する必要はありません。ただし、ダイアログをトリガーするアクションの前にダイアログハンドラーを登録して、Dialog.accept() または Dialog.dismiss() を実行できます。

page.onDialog(dialog -> dialog.accept());
page.getByRole(AriaRole.BUTTON).click();

Page.onDialog(handler) リスナーは、**必ず**ダイアログを処理する必要があります。そうしないと、Locator.click() など、アクションが停止します。これは、Web のダイアログがモーダルであり、処理されるまでページ実行をブロックするためです。

その結果、次のスニペットは決して解決されません。

警告

間違い!

page.onDialog(dialog -> System.out.println(dialog.message()));
page.getByRole(AriaRole.BUTTON).click(); // Will hang here

Page.onDialog(handler) のリスナーがない場合、すべてのダイアログは自動的に閉じられます。

beforeunload ダイアログ

Page.close() が真の setRunBeforeUnload 値で呼び出されると、ページはそのunload ハンドラーを実行します。これは、Page.close() が実際にページが閉じるのを待たない唯一のケースです。なぜなら、操作の最後にページが開いたままになる可能性があるからです。

`beforeunload` ダイアログを自分で処理するために、ダイアログハンドラーを登録できます。

page.onDialog(dialog -> {
assertEquals("beforeunload", dialog.type());
dialog.dismiss();
});
page.close(new Page.CloseOptions().setRunBeforeUnload(true));

window.print 経由で印刷ダイアログがトリガーされたことをアサートするには、次のスニペットを使用できます。

page.navigate("<url>");

page.evaluate("(() => {window.waitForPrintDialog = new Promise(f => window.print = f);})()");
page.getByText("Print it!").click();

page.waitForFunction("window.waitForPrintDialog");

これは、ボタンがクリックされた後に印刷ダイアログが開かれるのを待ちます。ボタンをクリックする前、またはページがロードされた後に、スクリプトを評価してください。