1. 程式人生 > >poium測試庫介紹

poium測試庫介紹

case scrip web ack keys rdo appium 簡單 activity

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測試庫介紹