Python自动化测试PO模型封装过程详解

作者:.客. 时间:2023-08-23 18:59:49 

在自动化中, Selenium 自动化测试中有一个名字经常被提及 PageObject( 思想与面向对象的特征相 同 ) ,通常 PO 模型可以大大提高测试用例的维护效率

优点:可重用,业务和对象分离,代码结构清晰,方便代码维护

Python自动化测试PO模型封装过程详解

核心要素

1. 在 PO 模式中抽离封装集成一个BasePage 类,该基类应该拥有一个只实现 webdriver 实例的属性

2. 每一个 page 都继承 BasePage ,通过 driver 来管理本 page 中元素,将 page 中的操作封装成一个个方法

3.TestCase 继承 unittest.Testcase 类,并依赖 page 类,从而实现相应的测试步骤

PO 实现进入百度页面输入数据后进入下一个页面

组织代码

Python自动化测试PO模型封装过程详解

1 :实现 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):
       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])

2 :实现 SearchPage


from selenium.webdriver.common.by import By
from base.base_page import BasePage
class SearchOne(BasePage):
   def __init__(self,driver,url):
       BasePage.__init__(self,driver,url)
   #进入百度
   def open_baidu(self):
       self.get()
   #输入数据
   def input_search_content(self,text):
       self.send_text(text,By.ID,"kw")
   # 点击按钮
   def click_baidu_search(self):
       self.left_click(By.ID, "su")
   def click_open_hao(self):
       self.left_click(By.XPATH,".//*[@id='1']/h3/a[1]")

3 :实现 TestCase


import unittest
from selenium import webdriver
from page.page_one import SearchOne
from page.page_two import SearchTwo
class BaiBu(unittest.TestCase):
   @classmethod
   def setUpClass(cls) -> None:
       cls.driver = webdriver.Firefox()
       cls.driver.implicitly_wait(10)
   def test001(self):
       url="http://www.baidu.com"
       s = SearchOne(self.driver,url)
       s.open_baidu()
       s.input_search_content("123")
       s.click_baidu_search()
       s.click_open_hao()
       self.driver.switch_to.window(self.driver.window_handles[1])
   def test002(self):
       s=SearchTwo(self.driver,"")
       s.open_baidu_map()
   def tearDown(self) -> None:
   #      self.driver.quit()
       pass
if __name__ == '__main__':
   unittest.main()

PO 模式的优点

1:PO 提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰

2 :页面对象与用例分离,使得我们更好的复用对象

3 :可复用的页面方法代码会变得更加优化

4 :更加有效的命令方式使得我们更加清晰的知道方法所操作的 UI 元素

来源:https://blog.csdn.net/weixin_45835679/article/details/117931919

标签:Python,自动化测试,PO模型
0
投稿

猜你喜欢

  • django 修改server端口号的方法

    2022-05-08 15:49:10
  • 如何使用 SQL Server 数据库查询累计值

    2008-12-03 15:27:00
  • ASP中如何判断一个字符是不是汉字

    2008-05-04 12:47:00
  • 推荐9款很棒的网页绘制图表JavaScript框架脚本

    2009-04-15 12:13:00
  • python使用requests实现发送带文件请求功能

    2023-11-03 14:23:13
  • asp使用shotgraph组件生成数字和字母验证码

    2007-09-26 12:26:00
  • 打印出python 当前全局变量和入口参数的所有属性

    2022-09-01 07:06:51
  • MSSQL数据加密解密代码

    2024-01-18 05:22:34
  • python 执行终端/控制台命令的例子

    2022-11-16 20:41:29
  • mysql 索引使用及优化详情

    2024-01-24 16:06:56
  • Django1.11自带分页器paginator的使用方法

    2021-07-04 12:44:23
  • python绘制直方图的方法

    2021-08-20 14:59:32
  • ChatGPT 帮我自动编写 Python 爬虫脚本的详细过程

    2021-09-09 09:13:50
  • OpenCV清除小面积连通域的实现方法

    2023-11-16 03:58:25
  • 详解PHP结构型设计模式之桥接模式Bridge Pattern

    2023-05-25 06:58:55
  • go自动下载所有的依赖包go module使用详解

    2024-04-28 10:49:48
  • MySQL优化方案之开启慢查询日志

    2024-01-23 09:30:23
  • python爬虫实例之获取动漫截图

    2023-08-17 22:13:57
  • Django文件存储 自己定制存储系统解析

    2023-09-17 13:06:25
  • 一篇文章带你学习python的函数与类

    2023-10-15 05:04:18
  • asp之家 网络编程 m.aspxhome.com