PO模式,全称PageObject模式,即页面对象模式。将页面定位与业务操作分离。

po模式有以下几个优点:

1.易读性好

2.扩展性高

3.复用性强

4.维护性好

5.代码冗余率低

了解了po模式及po模式的优点,可po模式在实际项目中到底该怎么做呢?接下来我们就来看看:

在本篇中我将po模式分为三层,分别是页面定位层,页面对象层,业务逻辑层;我将对每层逐一介绍。

一、页面定位层:每个页面作为一个模块,将页面元素定位表达式统一存放在该页面

例:登录页面模块部分代码如下

from selenium.webdriver.common.by import By

class LoginPageLoc:

    # 用户名输入框
user_loc = (By.XPATH, '//input[@name="phone"]')
# 密码输入框
passwd_loc = (By.XPATH, '//input[@name="password"]')
# 登陆按钮
login_button_loc = (By.TAG_NAME, "button")
# 错误提示框
form_error_loc = (By.XPATH, '//div[@class="form-error-info"]')
# 页面中dialog的提示
dialog_error_loc = (By.XPATH, '//div[@class="layui-layer-content"]')  

二、页面对象层:存放每个页面对象操作

例:登录页面的登录、获取错误信息等操作

from PageLocators.login_page_loc import LoginPageLoc as loc
from Common.basepage import BasePage
# 说明,本框架对selenium库中通用的元素行为方法做了二次封装(添加日志与截图),因此继承封装后的模块basepase class LoginPage(BasePage):
# 元素操作 # 登录操作
def login(self,username,passwd):
self.input_text(loc.user_loc,username,"登录页面_用户名输入")
self.input_text(loc.passwd_loc,passwd,"登录页面_密码输入")
self.click_element(loc.login_button_loc,"登录页面_点击登录按钮") # 获取提示信息
def get_error_msg(self):
return self.get_element_text(loc.form_error_loc,"登录页面_表单区域错误提示") # 获取页面中的错误提示信息
def get_error_msg_from_dialog(self):
return self.get_element_text(loc.dialog_error_loc,"登录页面_页面中间toast错误提示")

三、业务逻辑层:组合业务操作,即编写测试用例

例:登录功能,登录成功测试用例

@ddt.ddt
class TestLogin(unittest.TestCase): def setUp(self) -> None:
self.driver = webdriver.Chrome()
self.driver.get(CD.login_url)
self.lp = LoginPage(self.driver) def tearDown(self) -> None:
self.driver.quit() # 正常场景 - 登录成功。
def test_login_success(self):
logging.info("******* 登录功能 - 正常场景用例:登录成功 *******")
# 调用登录页面的登录行为。
self.lp.login(LD.success_data["user"], LD.success_data["passwd"])
# 断言 - 首页当中,应该存在 退出元素。
self.assertTrue(HomePage(self.driver).check_user_exist())
# 断言2 - 首页url地址
self.assertEqual(self.driver.current_url,LD.success_data["check_url"])

登录成功用例较简单,未涉及过多流程和元素操作,可以看看下面一个投资成功的测试用例:

@ddt.ddt
class TestInvest(unittest.TestCase): def setUp(self) -> None:
# 1、(前置)登陆页面登陆;
self.driver = webdriver.Chrome()
self.driver.get(CD.login_url)
LoginPage(self.driver).login(CD.user,CD.passwd)
# 2.首页选标,选择页面第一个标(默认此标符合此次用例投资标准)
HomePage(self.driver).click_first_bid()
self.bp = BidPage(self.driver) def tearDown(self) -> None:
self.driver.quit() # 正常场景 - 投资成功
def test_invest_success(self):
logging.info("******* 投资功能 - 正常场景用例:投资1000元成功。用户可用余额减少1000,标余额减少1000 *******")
# 3、标页面获取用户余额;
user_money_before_invest = self.bp.get_user_money()
# 4、标页面获取 标的余额;
bid_money_before_invest = self.bp.get_bid_left_money()
# 5、标页面:投标动作;
self.bp.invest(ID.success["money"])
# 6、点击投标成功提示框当中:查看并激活按钮
self.bp.click_activeButton_on_success_popup()
# 7、个人页面:获取用户余额
user_money_after_invest = UserPage(self.driver).get_user_left_money()
# 8、回退到标页面、刷新后:再次获取标的余额
self.driver.back()
self.driver.refresh()
bid_money_after_invest = self.bp.get_bid_left_money()
# 9、断言
self.assertEqual(ID.success["money"],int(float(user_money_before_invest) - float(user_money_after_invest)))
self.assertEqual(ID.success["money"],int((float(bid_money_before_invest) - float(bid_money_after_invest))*10000))

  

关于自动化中的PO模式,大概就讲这么多啦。。。O(∩_∩)O~

做一棵小草,谁也撼动不了………

说说UI自动化中的PO模式的更多相关文章

  1. UI自动化学习笔记- PO模型介绍和使用

    一.PO模型 1.PO介绍:page(页面) object(对象) 在自动化中,Selenium 自动化测试中有一个名字经常被提及 PageObject (思想与面向对象的特征相同),通常PO 模型可 ...

  2. UI自动化测试框架:PO模式+数据驱动

    1. PO 设计模式简介 2. 工程结构说明 3. 工程代码实现 page 包 action 包 business_process 包 util 包 conf 包 test_data 目录 log 目 ...

  3. web自动化测试中的PO模式(一)

    1.PO模式的思想 原理: 将页面的元素定位和元素行为封装成一个page类 类的属性:元素的定位 类的行为:元素的操作 页面对象和测试用例分离 测试用例: 调用所需要页面对象中的行为,组成测试用例 测 ...

  4. UI自动化实战进阶PO设计模式

    前言 经过前面的实战我们已经编写了几个测试用例,下面我们要用PO设计模式来调整我们的代码,让页面元素和测试业务进行分离,这样看起来直观而且后期的维护也方便. python有一个第三方的PO设计的库,既 ...

  5. UI自动化中无头浏览器的应用

    因为某次工作中写了个脚本要来回跑,还要在本机上做很多其他的事情,所以就上网找了个方法,无头浏览器,这样就不会浏览器来回弹出来,执行用例还会很快. 废话不多说,直接放代码: #coding=utf-8 ...

  6. 关于UI自动化中元素定位常用方法的个人总结

    1.如果目标元素有id属性,优先使用id定位: 2.元素locator尽可能保证简洁,考虑locator中路径的变化频率,尽量减少后期更新和维护成本: 3.使用xpath时,不要一味的使用‘/’逐层进 ...

  7. 小心!做 UI 自动化一定要跨过这些坑

    一 .引子 UI自动化,在移动互联网时代的今天,一直都是在各大测试社区最为火爆的一个TOPIC.甚至在测试同行面前一提起自动化,大家就会自然而然的问:“恩,你们是用的什么框架?appium?还是rob ...

  8. UI自动化之三种等待

    UI自动化中常用三种等待 目录 1.强制等待 2.隐式等待 3.显示等待 1.强制等待 执行到某一条语句后,然后sleep(3),等待3秒后,才会继续执行后面的语句 2.隐式等待 隐式等待只需要声明一 ...

  9. selenium(12)-web UI自动化项目实战(PO模式,代码封装)

    web UI自动化项目实战-项目 项目使用禅道,所以你需要搭建1个禅道,搭建禅道的方法和步骤见 https://www.cnblogs.com/xinhua19/p/13151296.html 搭建U ...

随机推荐

  1. 1Python运行Appium测试的例子

    电脑系统配置:Windows7的64位 1.Python sample(Python示例)下载 https://github.com/appium/sample-code/tree/master/sa ...

  2. 3.6 万颗星!开源 Web 服务器后起之秀,自带免费 HTTPS 开箱即用

    众所周知,Web 服务器是 Web 开发中不可或缺的基础服务,在开发中经常会用到.耳熟能详的开源 Web 服务器有久负盛名的 Apache.性能强劲的 Nginx.而我们今天要介绍的开源项目是采用 G ...

  3. JTAG 标准IEEE STD 1149.1-2013学习笔记(一·)Test logic architecture、Instruction register以及Test data registers

    我是 雪天鱼,一名FPGA爱好者,研究方向是FPGA架构探索和SOC设计. 关注公众号[集成电路设计教程],拉你进"IC设计交流群". 注:转载请注明出处 一.Test logic ...

  4. VS Code Java 2 月更新!教育特别版:单元测试、GUI开发支持、Gradle项目创建、以及更多!

    新春快乐!欢迎来到 Visual Studio Code Java 的 2 月更新,这个月我们给大家带来了一期教育特别版.每年的年初是许多学校开学的时间,为了给学生和教师提供在 Visual Stud ...

  5. netty介绍与构成

    什么是 Netty Netty 是一个利用 Java 的高级网络的能力,隐藏其背后的复杂性而提供一个易于使用的 API 的客户端/服务器框架.Netty 提供高性能和可扩展性,让你可以自由地专注于你真 ...

  6. Python 中线程和进程

    目录 线程和进程 一. 什么是进程 / 线程 1. 引论 2. 线程 3. 进程 4. 区别 5. 使用 二. 多线程使用 1. 常用方法 2. 常用参数 3. 多线程的应用 3.1 重写线程法 3. ...

  7. Burp intruder暴力攻击web口令

    实验目的 利用Burp intruder功能爆破出后台登陆密码admin. 实验原理 1)Burp Suite是Web应用程序测试的最佳工具之一,其多种功能可以帮我们执行各种任务.请求的拦截和修改,扫 ...

  8. 【windows 操作系统】进程间通信(IPC)简述|无名管道和命名管道 消息队列、信号量、共享存储、Socket、Streams等

    一.进程间通信简述 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进 ...

  9. python语法:注释

    Python语法:注释  python语言中的注释是来帮助程序员理解并读懂代码内容的文字.当然,注释不仅在python语言中是这个作用,在其他语言中也几乎一样. python注释的生成方式  所有演示 ...

  10. Java中读写锁的介绍

    读写锁的简单介绍 所谓的读写锁,就是将一个锁拆分为读锁和写锁两个锁,然后你加锁的时候,可以加读锁,也可以加写锁. ReentrantLock lock=new ReentrantLock(); loc ...