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):
       return self.by_id("kw")

   # 搜索按钮
   @property
   def search_button(self):
       return self.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"
    
    def tearDown(self):
        self.driver.quit()
    
    def test_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"

def test_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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值