1. 程式人生 > 程式設計 >基於python+selenium的二次封裝的實現

基於python+selenium的二次封裝的實現

這是個人對selenium.webdriver寫的一些常用操作的二次封裝,也就相當於重寫了,不再使用自帶的框架,用自己寫的框架完成。這樣的話使程式碼更簡潔,用自己的思想完成程式碼的編寫。

在這裡插入圖片描述

首先在根目錄下建立子目錄名為Common作為公用資料,名字隨自己取,在Common目錄下建立basepage.py和dir_config檔案。(關於這兩個py檔案要用來做什麼,後面有說到)

首先我們開啟dir_config檔案

在這裡插入圖片描述

看名字就可以很清楚的看到這是要幹什麼。
logs_dir = os.path.join(base_dir,“OutPuts/logs”)
(至於為什麼要這麼寫,我不做介紹了,這篇文章是針對於有基礎來講的)

用這一行來講,就是日誌存放的目錄=我箭頭指向的目錄,每個都一樣。
先把所需要存放的目錄路徑配置好,根據自己所需來配。

接下來我們來到basepage檔案下

在這裡插入圖片描述

先把所需要的模組、包匯入好,至於我們為什麼要用到這些模組,後面就曉得了,嘻嘻嘻

在這裡插入圖片描述

建立一個類名為 BasePage
寫一個初始化函式加上driver形參。self.driver = driver

在這裡插入圖片描述

在這裡插入圖片描述

這是等待元素操作的重寫,就是WebdriverWait().until(expected_conditions.visibility_of_element_located())的重寫
我後面還加了一個doc這個引數,上面我寫了註釋就是模組名_頁面名稱_操作名稱,這樣的話 如果報錯的話 我可以在日誌、截圖、報告很清楚的看到是哪個模組,哪個頁面,哪個操作出錯了。還有其他的引數我都帶了註釋、以及每一行程式碼我都帶了註釋,我就不一一講了。

在這裡插入圖片描述

這是查詢元素的重寫
為什麼要寫一個查詢的元素,請看下方

在這裡插入圖片描述

這是點選操作的重寫,我直接呼叫了查詢,這個函式就是找到元素並點選。一遍而過。

比如send_keys()等等

在這裡插入圖片描述

並且在每次操作之前都加了日誌
如logging.info(f"{doc}:元素:{locator}輸入內容:{text}")
他這裡如果是正確獲取的話,日誌會顯示在哪個模組哪個元素中輸入什麼內容,寫的一清二楚,如果錯了,相反我也打了錯誤的日誌。(doc就是哪個模組哪個頁面哪個操作下)
還有很多其他的操作,都是一樣的套路,如果覺得我這個重寫寫的不錯的可以按照我的套路去寫其他的操作

在這裡插入圖片描述

獲取元素內容操作等等,我就不一一截圖了

比如哪裡出錯了,會在指定的路徑下存在報錯日誌,截圖等等

在這裡插入圖片描述

而且每個錯誤都會帶上doc方便自己排查錯誤。

好了,我們來實操,用下這個框架
首先建立一個登陸頁面的py檔案LoginPage

在這裡插入圖片描述

匯入BasePage並建立一個類來繼承BasePage
from PageLocators.LoginLocators.login_locators import LoginLocators as loc
這個模組是我存放login頁面的定位元素

在這裡插入圖片描述

在這裡插入圖片描述

由於我們在BasePage寫了初始化函式,所以這裡不需要寫了
然後我們定義一個login的函式帶上username,password引數,這是代表輸入使用者名稱和密碼的形參
再定義一個doc
直接用我們剛才重寫的二次封裝來用
首先我們是要找到使用者名稱輸入框這個元素,在這個元素中輸入我們的使用者名稱
就可以直接用input_text()
self.input_text(loc.name_text,username,doc)
loc.name_text就是我們所定義的使用者名稱輸入框的定位表示式以及定位元素,我用元祖的形式括起來的。看上面的圖片
後面username就是使用者名稱的形參,等你測試用例呼叫登陸頁面操作的時候再傳使用者名稱資料就好了,我每一個都帶了doc,所以doc必傳。
所有的操作都是一樣的,理解一個就可以理解全部了。
樓主考慮到為什麼元組的形式也可以傳進去,這裡我給個特寫。

在這裡插入圖片描述

看我在locator前面加了這個符號,這個符號是解包的意思
self.driver.find_element(By.XPATH,‘//*[contains(@name,“username”)]')
實際上就是這個意思。
然後我傳個元祖直接引用就OK了

好了,然後我們再用pytest單元測試框架寫測試用例,然後引用LoginPage

在這裡插入圖片描述

這紅框內就是username和password的實參啦,我這是呼叫登陸的測試資料。這麼理解就好了。
好了,這篇文章介紹完了。是不是很簡潔、很實用、也方便後續修改,實際上就是為操作頁面用自己的思想做了優化。
如果你覺得還不錯的話 也可以按照我寫的這種去修改,當然有自己的想法也更好。
然後這邊我還放了pytest的一些內容,有些小夥伴沒看懂的先不要管,後續我會單獨寫一篇關於pytest單元測試框架的使用。
當然有不懂的可以留言,想進群一起學習的可以私聊我
一起加油呀—呼呼呼!!!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。