Seleniumの動作(入力時例外/3:Firefox)
Firefox
data:image/s3,"s3://crabby-images/e8b7a/e8b7a59a95ef43a8635d001decbad36544e387e2" alt="77.0.1"
ブラウザのズーム倍率
「Cntl」+「-」キーで表示倍率を90%にします。
Button
submitボタン
クリックできます。
data:image/s3,"s3://crabby-images/dc761/dc7612dcdee6c9cdadd0af1ff9a2a849a232891b" alt="クリックイベント発生"
<button>タグ
クリック可能です。
data:image/s3,"s3://crabby-images/530a4/530a427d15ca449ec7299bd70964415860750a27" alt="クリックイベント発生"
imageボタン
クリック可能です。
data:image/s3,"s3://crabby-images/4354d/4354dd5c3cf6a6c4ba26c47ae35323fc9f36816d" alt="クリックイベント発生"
Link
クリック可能です。
data:image/s3,"s3://crabby-images/0045a/0045a085e10846c514608c830bbb6b6a6379fea5" alt="クリックイベント発生"
Text
3種類とも文字入力可能です。
data:image/s3,"s3://crabby-images/2bda8/2bda86bc97f5fa1f8205cd034187fd90f9c988dd" alt="文字入力"
data:image/s3,"s3://crabby-images/6c172/6c1724366034a776d800125adabb6671566807ee" alt="文字入力"
data:image/s3,"s3://crabby-images/d763f/d763f285d90f09cb50294494ed1bc1a30ed8441e" alt="文字入力"
Select
選択できます。
data:image/s3,"s3://crabby-images/1cde7/1cde787616128d2e90ee05e4658681a266fb4beb" alt="option2選択"
Radio
クリック可能です。
data:image/s3,"s3://crabby-images/d11a3/d11a3d91561cd598999551e4c8154b0c8772d0af" alt="クリックイベント発生"
data:image/s3,"s3://crabby-images/3d6db/3d6db11ccb8359a46e9d0b1f8bae8074591a54f4" alt="クリックイベント発生"
CheckBox
クリック可能です。
data:image/s3,"s3://crabby-images/d345b/d345b859b805b2155a6182096cd1ce06a503aa2b" alt="クリックイベント発生"
data:image/s3,"s3://crabby-images/4e466/4e466b7e2fcc8e84a9da78c9d04264dbca1d5384" alt="クリックイベント発生"
実行結果
コントロール | 要素 | 操作 | 結果 |
---|---|---|---|
Button | submit | click | OK |
button | click | OK | |
image | click | OK | |
Link | normal | click | OK |
img | click | OK | |
css | click | OK | |
Text | textbox | send_key | OK |
password | send_key | OK | |
textarea | send_key | OK | |
Select | select | select | OK |
Radio | radio | click | OK |
label | click | OK | |
CheckBox | checkbox | click | OK |
label | click | OK |
非表示要素
プルダウンメニューがクリックできるかを確認します。
data:image/s3,"s3://crabby-images/04d3a/04d3adccb20fd5444d4547f5aa7d9e5c5e1e4cf7" alt="プルダウンメニュー"
Menu
「Menu3」の「child2」をクリックします。
例外が発生しました。
data:image/s3,"s3://crabby-images/f3908/f3908790066290e627b263a6b2922a37790afdb0" alt="例外発生"
ElementNotInteractableExceptionMessage: Element <a id="child2" href="#nav_sample"> could not be scrolled into view
<traceback object at 0x0000015C4712C708>
“is_displayed()"は「False(非表示)」でした。
data:image/s3,"s3://crabby-images/28f65/28f65754f23cc63251ecdaf96aed042ad777fe9d" alt="is_displayed()=False"
要素の上に、別の要素が重なっている
ダイアログ表示(モーダル)
「Menu1」をクリックすると、JavaScriptのAlertダイアログ(モーダル)が表示されます。
data:image/s3,"s3://crabby-images/2cf47/2cf470bd23ab7d621d459c8f37e791118c22aee6" alt="alertダイアログ表示"
Button
submitボタン
Alertダイアログが表示された状態で、submitボタンをクリックすると、ダイアログが閉じて例外が発生します。
data:image/s3,"s3://crabby-images/bc902/bc90289eca74de10fd12f8ba5f73b0f10420467a" alt="例外発生"
UnexpectedAlertPresentExceptionAlert Text: None
Message: Dismissed user prompt dialog: Menu1!
<traceback object at 0x0000015C47122748>
手動操作ではクリック不可でダイアログも閉じません。
data:image/s3,"s3://crabby-images/0e370/0e37087c623fcda43af92905925b82fd0149ea0e" alt="反応なし"
Alertダイアログを表示した状態で、「id」ボタンを押します。
Chormeと同じく、要素の取得ができません。
data:image/s3,"s3://crabby-images/04197/0419732c9e9a13efbe88e856be3380e248bec930" alt=""
なお、Firefoxでは、同じAlertダイアログを表示すると、2回目からチェックボックス付きのダイアログが表示されますが、同じ結果となります。(IEでは動作が異なります)
data:image/s3,"s3://crabby-images/930fd/930fdbdddb544e995b10f8b9210d376b04813123" alt="チェックボックス付きダイアログ表示"
data:image/s3,"s3://crabby-images/a7052/a7052e2fa4de054bb05d714b9436aca30644eb02" alt="例外発生"
Link
normal_link, img_link, css_linkとも例外が発生しました。
Text
Alertダイアログを表示した状態で、send_keys()を実行します。
textbox
Alertダイアログが閉じ、例外が発生しました。
data:image/s3,"s3://crabby-images/320f5/320f5f20c1269a304c3a0eb9a1e43cbcdcdbea60" alt="例外発生"
UnexpectedAlertPresentExceptionAlert Text: None
Message: Dismissed user prompt dialog: Menu1!
<traceback object at 0x0000015C471226C8>
Select
Alertダイアログが閉じ、例外が発生しました。
data:image/s3,"s3://crabby-images/303c7/303c7c20270e371c77c784152b00c0ce30fdabe1" alt=""
UnexpectedAlertPresentExceptionAlert Text: None
Message: Dismissed user prompt dialog: Menu1!
<traceback object at 0x0000015C47045908>
Radio / CheckBox
ボタンクリック、ラベルクリックとも、Alertダイアログが閉じ、例外が発生しました。
実行結果
どちらのダイアログでも動作に差異はありません。
data:image/s3,"s3://crabby-images/92ebb/92ebbe3d74d727e0f716f38f48b73cb1db5c848c" alt="alertダイアログ(ノーマル)"
data:image/s3,"s3://crabby-images/0ad9a/0ad9af1589c1e531bf63210fdf3808f0b891b7b9" alt="alertダイアログ(チェックボックス付)"
コントロール | 要素 | 操作 | 結果 |
---|---|---|---|
Button | submit | click | Ex |
button | click | Ex | |
image | click | Ex | |
Link | normal | click | Ex |
img | click | Ex | |
css | click | Ex | |
Text | textbox | send_key | Ex |
password | send_key | Ex | |
textarea | send_key | Ex | |
Select | select | select | Ex |
Radio | radio | click | Ex |
label | click | Ex | |
CheckBox | checkbox | click | Ex |
label | click | Ex |
要素の取得もエラーになる。
SeleniumではAlertダイアログが閉じるが、手動では閉じない
ダイアログ表示(モードレス)
「Menu2」をクリックすると、jQueryのモードレスダイアログが表示されます。
data:image/s3,"s3://crabby-images/03094/0309493182e9ab6da887877937982d022d4d0d6a" alt="ダイアログ表示"
Button
submitボタン
ダイアログが重なっている状態で、submitボタンをクリックします。
例外が発生します。
data:image/s3,"s3://crabby-images/94aed/94aedc19bd3e533fc2e1322008a3e459ec6a55de" alt="例外発生"
ElementClickInterceptedExceptionMessage: Element <input id="submit" class="btn-submit" type="submit"> is not clickable at point (831,372) because another element <div id="dialog" class="ui-dialog-content ui-widget-content"> obscures it
<traceback object at 0x00000231DA71EA08>
ダイアログを移動させて、submitボタンを表示すれば、クリック可能です。
data:image/s3,"s3://crabby-images/00f92/00f92d163df1b319a6b8d989c200bc2eebbd13a9" alt="クリックイベント発生"
手動の場合もクリック可能です。
data:image/s3,"s3://crabby-images/c3358/c33582d999077a5d0ec355b6f78e6fb0e9cd72d2" alt="クリックイベント発生"
is_displayed()は「True(表示)」です。
data:image/s3,"s3://crabby-images/4ccf7/4ccf76c961577f56dc029961790ce579d53e3cb1" alt="is_displayed()=True"
Link
要素が隠れていると例外が発生します。
data:image/s3,"s3://crabby-images/50af2/50af28fdf989ff0a2f79917bda63f12fa4f75a1c" alt="例外発生"
Text
ダイアログで要素が隠れている場合でも、文字入力可能です。
data:image/s3,"s3://crabby-images/5e6f4/5e6f41f4a6390ae33e54c89eebc534b2588ea20b" alt="文字入力"
data:image/s3,"s3://crabby-images/00bd3/00bd341c7cb473300b7f07e8ccf4f59c1b6f2302" alt="hoge"
Select
要素が隠れていると、例外が発生します。
data:image/s3,"s3://crabby-images/89e1b/89e1b2fe470b4dab173303edfba5175bc3b5a648" alt="例外発生"
ElementClickInterceptedExceptionMessage: Element <select id="select"> is not clickable at point (831,483) because another element <p> obscures it
<traceback object at 0x00000231DBDCD4C8>
Radio / CheckBox
ButtonやLinkと同じく、隠れているとクリックできません。
data:image/s3,"s3://crabby-images/c5bc6/c5bc6abab7b28450e8fac381594db13a09b39e12" alt="例外発生"
実行結果
コントロール | 要素 | 操作 | 結果 |
---|---|---|---|
Button | submit | click | Ex |
button | click | Ex | |
image | click | Ex | |
Link | normal | click | Ex |
img | click | Ex | |
css | click | Ex | |
Text | textbox | send_key | OK |
password | send_key | OK | |
textarea | send_key | OK | |
Select | select | select | Ex |
Radio | radio | click | Ex |
label | click | Ex | |
CheckBox | checkbox | click | Ex |
label | click | Ex |
例外が起きるのは、ダイアログで要素が隠れている場合
ヘッダー/フッター
スクロール追従型のヘッダー/フッターで要素が隠れている場合を考えます。
Button
submitボタン
submitボタンをヘッダーに隠した状態でclickボタンを押します。
例外が発生しました。
data:image/s3,"s3://crabby-images/6224e/6224e1f94c796f1f306863cdad17b1aa36d87085" alt="例外発生"
Link
Linkをフッターに隠した状態でclickボタンを押します。
例外が発生しました。
data:image/s3,"s3://crabby-images/1c637/1c637bff5d5dda252d39c7e0373f4372b247985a" alt="例外発生"
Text
textbox
ヘッダー/フッターで要素が隠れていても、文字入力可能です。
data:image/s3,"s3://crabby-images/7543e/7543e1dba2308887c1626d966f8b855a93f0fd40" alt="文字入力"
Select
例外が発生しました。
data:image/s3,"s3://crabby-images/711a9/711a949979fa20340bee975b5217bd33c3c5ebc5" alt="例外発生"
lementClickInterceptedExceptionMessage: Element <select id="select"> is not clickable at point (831,922) because another element <div id="footer"> obscures it
<traceback object at 0x00000231DA78A108>
エラーメッセージに “not clickable" とあることからも、Firefoxのselect_by_index()メソッドは、クリックで実現しているように思います。
Radio / CheckBox
Radioボタンをフッターに隠して、click()メソッドを発行。
例外が発生します。
data:image/s3,"s3://crabby-images/6ae09/6ae097ba4176ee4b46fdab20930463f7c375c120" alt="例外発生"
実行結果
コントロール | 要素 | 操作 | 結果 |
---|---|---|---|
Button | submit | click | Ex |
button | click | Ex | |
image | click | Ex | |
Link | normal | click | Ex |
img | click | Ex | |
css | click | Ex | |
Text | textbox | send_key | OK |
password | send_key | OK | |
textarea | send_key | OK | |
Select | select | select | Ex |
Radio | radio | click | Ex |
label | click | Ex | |
CheckBox | checkbox | click | Ex |
label | click | Ex |
ディスカッション
コメント一覧
まだ、コメントがありません