摘要:一前言上篇文章我們學習了頁面操作原理及如何高效的進行元素定位那的工作原理又是什么是如何驅動瀏覽器的呢這篇文章為你講解工作原理及對瀏覽器的配置和操作。基于該運行瀏覽器所產生的緩存等數據都會被記錄。
上篇文章我們學習了Selenium頁面操作原理及如何高效的進行元素定位
那Selenium的工作原理又是什么?是如何驅動瀏覽器的呢?這篇文章為你講解Selenium工作原理及Webdriver對瀏覽器的配置和操作。
(PS:個人在用的人工智能學習網站推薦給大家:captainai,覺得不錯請三連支持一下)
Selenium進行自動化測試主要依賴三項:
其中核心部分就是Webdriver,它提供了一系列的API來供我們使用,以至于驅動瀏覽器做一些操作。
它的工作原理有時也會作為面試題,不少小伙伴Selenium用的很熟練,但因為答不出它的工作原理而被Pass!
所以我簡單總結了一下,為了面試不被pass的標準答案
Webdriver工作原理:
webdriver用于通信用戶編寫的代碼和瀏覽器。
當使用類似webdriver.Chrome()
啟動瀏覽器后,webdriver會將啟動的瀏覽器綁定到特定的端口,并作為服務端 (類似前后端分離項目的后端)
客戶端 (用戶編寫的代碼),通過ComandExecutor發送HTTP請求給服務端
服務端通過WebService將其翻譯為瀏覽器讀的懂的腳本傳給瀏覽器進行執行,執行完成后,瀏覽器把執行結果返回給WebService,WebService再把返回的結果做一些封裝,然后返回給客戶端。
通過查看Selnium->webdriver文件夾,發現Selnium支持6種瀏覽器:
chrome
、edge
、firefox
、ie
、opera
、safari
這里用谷歌、火狐的啟動來舉例
from selenium import webdriverbrowser = webdriver.Chrome()
from selenium import webdriverbrowser = webdriver.Firefox()
webdriver有很多配置項,例如設置請求頭、隱藏瀏覽器運行、配置Webdriver路徑等;下面為你介紹常用的配置項:
chrome_options = webdriver.ChromeOptions()
chrome_options.add_argument("--start-maximized")
chrome_options.add_argument("--headless")
chrome_options.add_argument("--no-sandbox")
chrome_options.add_argument("blink-settings=imagesEnabled=false")
以chrome瀏覽器舉例,我們可以通過【cmd】在chrome所在目錄執行命令:
chrome.exe --remote-debugging-port=9222 --user-data-dir="C:/selenum/AutomationProfile"
-remote-debugging-port
:用于配置瀏覽器啟動占用的端口,可以指定任何未被占用的端口
-user-data-dir
:指定創建新Chrome配置文件的目錄;它是為了確保在多帶帶的配置文件中啟動chrome,不會污染你的默認配置文件。
然后在代碼中加入下面的配置即可使用剛剛打開的瀏覽器了
chrome_options.add_experimental_option("debuggerAddress", "127.0.0.1:9222")
這樣做的好處是:
當存在多個谷歌瀏覽器或谷歌瀏覽器環境異常時,可以指定其瀏覽器文件路徑進行驅動
chrome_options.binary_location = r"C:/Program Files (x86)/Google/Chrome/Application/chrome.exe"
通過該配置項可以隱藏上圖的提示
chrome_options.add_experimental_option("excludeSwitches", ["enable-automation"])
下面的代碼會啟動一個寬100
,長1000
的瀏覽器
chrome_options.add_argument(f"--window-size={100},{1000}")
下面的代碼會啟動一個左邊距為100
,上邊距為200
的瀏覽器
chrome_options.add_argument(f"--window-position={100},{200}")
有時候開啟瀏覽器需要特別的語言版本,如果未進行配置則啟動的是系統語言對應的瀏覽器,我們的被測網站如果是英文的,但系統是中文的,開啟的瀏覽器就是中文的,提交的某些數據按照zh_CN.UTF-8
的格式提交了,導致數據報錯,那么我們就需要設置瀏覽器啟動語言。
chrome_options.add_argument("lang=en-us")
有時候需要模擬手機訪問某些頁面的時候,可以通過配置user-agent
項來實現
下面的代碼會將瀏覽器模擬為安卓手機訪問
user_ag = "MQQBrowser/26 Mozilla/5.0 (Linux; U; Android 7.3.7; zh-cn; MB200 Build/GRJ22;CyanogenMod-7) " / "AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1 "chrome_options.add_argument("user-agent=%s" % user_agent)
執行效果
chrome_options.add_argument("--proxy-server=你的代理ip地址")
下面的代碼會【最大化窗口】且【不加載圖片】的啟動一個瀏覽器:
from selenium import webdriverchrome_options = webdriver.ChromeOptions()chrome_options.add_argument("--start-maximized")chrome_options.add_argument("blink-settings=imagesEnabled=false")browser = webdriver.Chrome(options=chrome_options)
browser.name
browser.maximize_window()
browser.minimize_window()
類似瀏覽器中按下【F11】
browser.fullscreen_window()
browser.get("https://www.baidu.com") #訪問百度
browser.current_url
browser.title
browser.current_window_handle
browser.save_screenshot("test.png") #截取當前窗口并命名為`test.png`保存
browser.refresh()
browser.forward()
browser.back()
設置瀏覽器寬為480
,高為800
browser.set_window_size(480, 800)
設置瀏覽器寬為480
,高為800
browser.set_window_position(480, 800)
設置瀏覽器寬為480
,高為800
browser.get_window_size(480, 800)
設置瀏覽器寬為480
,高為800
browser.get_window_position(480, 800)
如果需要進行頁面滑動(模擬鼠標滾輪操作)可以通過執行js
腳本實現
例如滑動到"http://*[@id="asideHotArticle"]/h3"
元素:
target = browser.find_element(By.XPATH, "http://*[@id="asideHotArticle"]/h3")browser.execute_script("arguments[0].scrollIntoView();", target)
有多個窗口時,可以通過下面的方法進行切換才能夠順利的進行定位
browser.switch_to.window(browser.window_handles[1])
頁面中的iframe彈窗,需要使用下面的代碼切換才能夠順利的進行定位
iframe = browser.find_element(By.CSS_SELECTOR, "#modal > iframe")# 切換到iframebrowser.switch_to.frame(iframe)
離開iframe,回到默認頁面
browser.switch_to.default_content()
有多個頁面的時候,只會關閉當前所在頁面
browser.close()
會直接關閉瀏覽器,所有頁面都將關閉
browser.quit()
實際上webdriver的操作還有很多,比如遠程控制項的配置,cookie相關配置等,但都不常用,掌握這些些已經足夠了!
下一篇文章會對selenium的鍵盤鼠標事件進行詳解,歡迎訂閱本專欄!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/122436.html
摘要:一前言本專欄將結合元素定位和前沿的圖像識別定位兩種方法,從到的構建一個企業級自動化測試框架。 一、前言 本專欄將結合元素定位(selenium/appium)和前沿...
摘要:那是怎樣知道我們想要操作哪個元素的呢這篇文章將為你講解的頁面操作原理和高效的元素定位方法。它的含義為匹配名稱包含的元素。 一、前言 上篇文章中我們成功編寫并啟動了第...
摘要:我們將用集成測試來結束我們的測試部分。作為對集成測試的一個提醒它是自動化我們的實際用戶在使用我們的應用時體驗到的體驗的過程。出于我們的目的我們將只使用上面的基本配置因為它已經足夠讓集成測試繼續進行。 本文轉載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3808原文:https://www.fullstackreact.com/30-d...
閱讀 2930·2023-04-25 19:08
閱讀 1421·2021-11-16 11:45
閱讀 1980·2021-10-13 09:40
閱讀 4147·2021-09-30 09:47
閱讀 2420·2019-08-30 15:44
閱讀 2286·2019-08-30 13:03
閱讀 1393·2019-08-30 12:56
閱讀 1896·2019-08-26 14:04