セレンの一般的に使用されるアサーションには、
- ページ属性アサーション:タイトル、URL、またはページのソースコードに特定の文字が含まれているかどうかをアサーションします
- 要素存在アサーション:指定された要素が存在することを表明します
- 画像とリンクのアサーション:画像が正常に表示され、リンクを正常に開くことができることを表明します
ページ属性アサーション
これは最も一般的に使用されるアサーション方法であり、ページが正常に開かれているかどうか、および指定されたウィンドウとページ上にあるかどうかをアサーションするために使用できます。例は次のとおりです。
from selenium import webdriver
dr = webdriver.Chrome()
dr.get('https://www.baidu.com')
dr.find_element('link text', '新闻').click()
dr.switch_to.window(dr.window_handles[-1]) # 切换到最后一个窗口
assert '百度新闻' in dr.title # 断言标题包含
assert 'http://news.baidu.com/' == dr.current_url # 断言为指定url
assert 'not found' not in dr.page_source # 断言页面源码不包含not found(一般Nginx找不到页面时返回404页面,显示Not Found)
dr.quit()
ページ要素のアサーション
操作を続行するために、指定された要素がページに存在するかどうかを判断したり、要素が存在するかどうかによって指定されたページにあるかどうかを表明したりする必要がある場合があります。
要素が存在するかどうかをアサートします。try... exceptを使用して、要素が見つからないという異常をキャッチして抑制するか、find_elements +を使用して、返された要素リストが空かどうかを判断し、要素を見つけることができるかどうかを判断します。
一定期間待機する必要のある要素については、スマート待機またはアクティブ待機を使用して、要素がタイムアウトするまでポーリングおよびチェックできます。例は次のとおりです。
from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.wait import WebDriverWait, TimeoutException
dr = webdriver.Chrome()
dr.get('https://www.baidu.com')
dr.maximize_window()
try:
settings = dr.find_element('id', 's-usersetting-top')
except NoSuchElementException:
print('未定位到"设置"')
# raise AssertionError('设置链接不存在') # 测试时,需抛出标准的断言异常, 对于偶现元素,则无需抛出异常
else:
print('"设置"存在')
ActionChains(dr).move_to_element(settings).perform() # 鼠标移动到设置
# 或 使用 find_elements + 列表长度判断
elms = dr.find_elements('id', 's-usersetting-top')
if len(elms) > 0:
settings = elms[0]
print('"设置"存在')
ActionChains(dr).move_to_element(settings).perform()
else:
print('未定位到"设置"')
raise AssertionError('设置链接不存在')
# 对需要等待的元素,使用主动等待轮询
try:
WebDriverWait(dr, 10, 0.5).until(
lambda dr: dr.find_element('link text', '高级搜索')
).click()
except TimeoutException:
print('未定位到"高级搜索"')
# raise AssertionError('高级搜索不存在')
dr.quit()
画像とリンクのアサーション
画像が表示されているかどうか、リンクを正常に開くことができるかどうか、dr.get( '画像またはリンクアドレス')を使用して、404ページが返されるかどうかを確認し、画像を正常に開くことができるかどうかを判断できます。例は次のとおりです。続きます。
from selenium import webdriver
dr = webdriver.Chrome()
dr.get('https://www.baidu.com')
baidu_logo_url = dr.find_element('id', 's_lg_img').get_attribute('src')
print('百度Logo图片链接', baidu_logo_url)
dr.get(baidu_logo_url) # 尝试打开图片
assert 'Not Found' not in dr.page_source # 假设不存在报错页面包含Not Found字样
dr.back()
hao123_link_url = dr.find_element('link text', 'hao123').get_attribute('href')
print('hao123链接', hao123_link_url)
dr.get(hao123_link_url) # 尝试打开页面
assert 'Not Found' not in dr.page_source
dr.back()
dr.quit()
画像とリンクは、インターフェース要求を使用して、または特別な404チェックツールを使用して、より高速にチェックできます。
その他
- カラーアサーション:Seleniumのサポート
- スタイル配置アサーション:たとえば、タイトルが改行、ボタンのオーバーラップ、位置ずれなどであるかどうかは、python-opencv画像比較などの一連のアルゴリズムを使用して、ページ(または一部)のスクリーンショットを保存することで実現できます。 。
- 画像が画像を指定しているかどうかを確認します。画像の比較を通じて、いくつかの画像アルゴリズムが含まれます
記事がお役に立てば幸いですので、よろしくお願いします。ご支援ありがとうございます。よろしくお願いします。継続的に更新していきます。
最後に:メリット
テクノロジー業界では、技術スキルを向上させ、自動化プロジェクトでの実践的な経験を充実させる必要があります。これは、今後数年間のキャリア計画とテストテクノロジーの深さに非常に役立ちます。
ゴールデン9日とシルバー10日の面接シーズン、転職シーズンでは、面接の質問を整理することが長年の私の習慣になっています!以下は、近年の私のコレクションと並べ替えです。全体は[ソフトウェアテスト]を中心に構成されています。メインコンテンツには、Python自動化テストの独占ビデオ、Python自動化の詳細、インタビューの質問のフルセット、その他の知識コンテンツが含まれます。
ソフトウェアテストの友人にとっては、最も包括的で完全な面接準備ウェアハウスである必要があります。各モジュールをより適切に整理するために、インターネット上の多くの高品質のブログ投稿やプロジェクトも参照し、すべての知識ポイントを見逃さないように努めています。友人はこれらのコンテンツを利用してレビューを行い、BATJなどの大規模な工場からオファーを受け取りました。この倉庫はソフトウェアテストの多くの学習者にも役立ちました。あなたにも役立つことを願っています。
あなたと私が会い、あなたが何かを見つけることができますように!WeChatパブリックアカウントをフォローすることを歓迎します:[Sad Spicy Article] 216ページのソフトウェアテストエンジニアのインタビューブックを無料で受け取ります。そして、対応するビデオ学習チュートリアルは無料で共有できます!