poium測試庫介紹
poium測試庫前身為selenium-page-objects測試庫,我在以前的文章中也有介紹過:這可能是最簡單的Page Object庫,項目的核心是基於Page Objects實現元素定位的封裝。該項目由我個人在維護,目前在公司項目中已經得到的應用。
poium的優勢
Page Objects設計模式大家都懂,以往我們對Page層的封裝大概是這樣的。
class BasePage(): def __init__(self, driver): self.dr =driver def by_id(self, elem): returnself.dr.find_element_by_id(elem) class BaiduIndexPage(BasePage): # 搜索框 @property def search_input(self): returnself.by_id("kw") # 搜索按鈕 @property def search_button(self): returnself.by_id("su")
大體上是每個操作元素封裝為一個方法,這樣並沒什麽不好的,只是不夠簡潔。而poium可以極大的簡化元素的定義,甚至接近,配置文件。
from poium import Page, PageElement
class BaiduIndexPage(Page):
search_input= PageElement(css="#kw", describe="搜索框")
search_button= PageElement(css="#su", describe="搜索按鈕")
幾百個元素的也只不過幾百行代碼,使用也遠比配置文件簡單。將元素寫到配置文件裏,你還要考慮如何讀取。
不管是前一種page層封裝,還是使用poium封裝在測試用例中的使用並無太大的差別。
from selenium import webdriver import unittest defbaiduTest(unittest.TestCase): defsetUp(self): self.driver =webdriver.Chrome() self.base_url ="https://www.baidu.com" deftearDown(self): self.driver.quit() deftest_search(self): page= BaiduIndexPage(driver) page.get(self.base_url) page.search_input.send_keys("poium") page.search_button.click() # .....
JavaScript API
在我們項目中,時常要用到JavaScript操作,比如日期控件不好操作,那會通過JS的removeAttribute() 刪除掉元素的某些屬性,使他可以通過輸入完成日期的“選擇”。比如,有些元素用Selenium點擊不了,但JS的click()卻可以,再比如有些彈窗不是必現的,就必須使用異常捕捉,但JS可以更輕松的處理彈窗。
於是,我封裝了一組由JS實現的API。
from poium import Page
class BaiduPage(Page):
# 元素定位只支持CSS語法
search_input ="#kw"
search_button ="#su"
deftest_attribute(self):
"""
元素屬性修改/獲取/刪除
:param browser: 瀏覽器驅動
"""
driver= webdriver.Chrome()
page =BaiduPage(browser)
page.get("https://www.baidu.com")
page.remove_attribute(page.search_input,"name")
page.set_attribute(page.search_input, "type", "password")
value =page.get_attribute(page.search_input, "type")
assert value =="password"
不過,JS實現的API中的只支持CSS定位。
強列推薦使用CSS定位,因為poium還可以將操作過的元素在自動化的運行過程中給你標記出來。
這樣當程序運行失敗需要截圖時就比較清晰了,但是,這個功能還不完善。
appium 支持
為什麽不是不叫selenium-page-objects了?因為poium也支持appium了呀,使用之前的名字如何表達對appium的支持呢?
from appium import webdriver
from poium import Page,PageElement
class CalculatorPage(Page):
number_1 = PageElement(id_="com.android.calculator2:id/digit_1")
number_2 = PageElement(id_="com.android.calculator2:id/digit_2")
add = PageElement(id_="com.android.calculator2:id/op_add")
eq = PageElement(id_="com.android.calculator2:id/eq")
# APP定義運行環境
desired_caps = {
'deviceName': 'AndroidEmulator',
'automationName': 'appium',
'platformName': 'Android',
'platformVersion': '7.0',
'appPackage': 'com.android.calculator2',
'appActivity': '.Calculator',
}
driver =webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
page =CalculatorPage(driver)
page.number_1.click()
page.add.click()
page.number_2.click()
page.eq.click()
driver.quit()
在appium中的使用與selenium是一致的!當然,appium擴展了更多的定位方法。
- ios_uiautomation
- ios_predicate
- ios_class_chain
- android_uiautomator
- android_viewtag
- android_datamatcher
- accessibility_id
- image
- custom
poium同樣支持這些定位,在appium中如何使用,那麽這裏也是一樣的。
最後,poium並不會對你的現有自動化產生太多的影響,它只是對元素操作的封裝,你可以在項目當中隨意的選擇是否要用它。
項目地址:poium
支持pip安裝:
pip install poium
poium測試庫介紹