自动化po模型

1、po模型介绍

  • 在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象的特征相
    同),通常PO模型可以大大提高测试用例的维护效率
  • 优点:重用,业务和对象分离,代码结构清晰,方便代码维护

实现BasePage
BasePage代码实现

from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains  # 鼠标操作


class BasePage():
    '''BasePage封装所有界面都公用的方法。例如driver,find_element等'''
    '''实例化BasePage类时,事先执行的__init__方法,该方法需要传递参数'''

    def __init__(self, driver, url):
        self.driver = driver
        self.base_url = url

    # 进入网址
    def get(self):
        self.driver.get(self.base_url)

    # 元素定位,替代八大定位
    def get_element(self, *locator):
        return self.driver.find_element(*locator)

    # 点击
    def left_click(self, *locator):
        self.driver.find_element(*locator).click()
        # ActionChains(self.driver).click(self.get_element(*locator)).perform()

    # 输入
    def send_text(self, text, *locator):
        self.driver.find_element(*locator).send_keys(text)

    # 清除
    def clear_text(self, *locator):
        self.driver.find_element(*locator).clear()

    def switch_iframe(self, *locator):
        self.driver.switch_to.frame(self.driver.find_element(*locator))

    def switch_window(self, n):
        self.driver.switch_to.window(self.driver.window_handles[n])

    # 用于断言
    def get_title(self):
        return self.driver.title

实现dianjishijian
dianjishijian代码实现

po001.py

from Basepage.one import BasePage
from selenium.webdriver.common.by import By


class Search(BasePage):
    def __init__(self, driver, url):
        BasePage.__init__(self, driver, url)

    # 进入百度
    def get_bai(self):
        self.get()

    # 获取输入框id
    def shuru(self, test):
        self.send_text(test, By.ID, "kw")

    # 点击
    def dianji(self):
        self.left_click(By.ID, "su")

实现TestCase
TestCase代码

test_001.py

import unittest
from selenium import webdriver
from dianjishijian.po001 import  Search


class TeseClass(unittest.TestCase):
    def setUp(self) -> None:
        print("开始")
        self.driver = webdriver.Firefox()
        self.driver.implicitly_wait(10)
    def test001(self):
        url = "http://www.baidu.com"
        b = Search(self.driver,url)
        b.get_bai()
        b.shuru("123")
        b.dianji()
    def tearDown(self) -> None:
        print("结束")

if __name__ == '__main__':
    unittest.main()

多个po(界面操作)

po002.py

from Basepage.one import BasePage
from selenium.webdriver.common.by import By


class Search2(BasePage):
    def __init__(self, driver, url):
        BasePage.__init__(self, driver, url)

    # 点击
    def hao_123(self):
        self.left_click(By.XPATH, ".//*[@id='1']/h3/a[1]")
    def switch_windowss(self,n):
        self.switch_window(n)

po003.py

from Basepage.one import BasePage
from selenium.webdriver.common.by import By


class Search3(BasePage):
    def __init__(self, driver, url):
        BasePage.__init__(self, driver, url)

    # 点击
    def baidu(self):
        self.left_click(By.XPATH, ".//*[@id='userCommonSites']/ul/li[6]/div/a")

test_001.py

import unittest from selenium import webdriver from dianjishijian.po001 import Search from dianjishijian.po002 import Search2 from dianjishijian.po003 import Search3


class TeseClass(unittest.TestCase):
    @classmethod
    def setUpClass(cls) -> None:
        print("开始")
        cls.driver = webdriver.Firefox()
        cls.driver.implicitly_wait(10)

    def test001(self):
        url = "http://www.baidu.com"
        b = Search(self.driver, url)
        b.get_bai()
        b.shuru("123")
        b.dianji()

    def test002(self):
        url = ""
        c = Search2(self.driver, url)
        c.hao_123()
        c.switch_windowss(1)

    def test003(self):
        url = ""
        d = Search3(self.driver, url)
        d.baidu()

    @classmethod
    def tearDownClass(cls) -> None:
        print("结束")


if __name__ == '__main__':
    unittest.main()

运行结果图
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

学习Web自动化测试中的PO模型可以按照以下步骤进行: 1. 了解PO模型:首先,了解PO(Page Object)模型的基本概念和原则。PO模型是一种测试设计模式,它将每个Web页面抽象为一个对象,并封装页面的元素和操作,以便于测试代码的编写和维护。 2. 掌握基本的Web自动化测试技术:熟悉使用Selenium WebDriver或其他类似的工具进行Web自动化测试。了解如何定位页面元素,执行操作和断言结果。 3. 创建Page Objects:根据应用程序的页面结构和功能,创建相应的Page Objects。每个Page Object代表一个页面,并包含该页面上的元素和相关的操作方法。 4. 组织测试代码:根据测试场景,组织测试代码并使用Page Objects进行操作。将测试步骤分解为不同的Page Objects,并使用这些对象来执行操作和验证结果。 5. 编写可维护的测试代码:根据PO模型的原则,编写可重用和可维护的测试代码。尽量避免在测试代码中直接使用原始的页面元素定位,而是通过Page Objects提供的方法来操作页面。 6. 实践和反馈:通过实践不断改进和优化你的自动化测试代码。根据实际情况,反馈给开发团队和测试团队,以便进一步改进应用程序和测试设计。 7. 持续学习:保持学习和关注最新的Web自动化测试技术和最佳实践。参加培训课程、阅读相关书籍和博客,与其他测试人员交流经验。 总之,通过理解PO模型的概念和原则,并结合实际的测试项目,逐步学习和应用PO模型,可以提高Web自动化测试的效率和可维护性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值