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. 读源码【读mybatis的源码的思路】

    ✿ 需要掌握的编译器知识 ★ 编译器为eclipse为例子 调试准备工作(步骤:Window -> Show View ->...): □ 打开调试断点Breakpoint: □ 打开变量 ...

  2. Spring-BeanFactory体系介绍

    1 BeanFactory介绍 BeanFactory是Spring中的根容器接口,所有的容器都从从它继承而来,ApplicationContext中对于BeanDefinition的注册,bean实 ...

  3. python数据分析入门笔记[1]

    1.Numpy: Numpy是python科学计算的基础包,它提供以下功能(不限于此): (1)快速高效的多维数组对象naarray (2)用于对数组执行元素级计算以及直接对数组执行数学运算的函数 ( ...

  4. HGAME-week2-web-wp

    hgame第二周总结 1.webpack-engine 我不懂,但是真的刚打开就出来了,一脸懵逼(wp说是sourcemap没关 hgame{D0nt_f0r9et_2_ClOs3_S0urce_m@ ...

  5. Redis 中常见的集群部署方案

    Redis 的高可用集群 前言 几种常用的集群方案 主从集群模式 全量同步 增量同步 哨兵机制 什么是哨兵机制 如何保证选主的准确性 如何选主 选举主节点的规则 哨兵进行主节点切换 切片集群 Redi ...

  6. log4j的替换方案

    去年12月份,随着log4j暴露出高危漏洞,对于 Java 开发人员来说不是一个好消息,对于 Ops 来说更是如此.前者必须使用固定的 Log4J 版本重新打包他们的应用程序,而后者必须重新部署.但对 ...

  7. ensp练习:防火墙安全策略配置

    一.实验目的:1. 了解华为防火墙安全策略.2. 掌握华为防火墙安全策略的配置.二.实验仪器:计算机.华为ensp模拟器.华为防火墙三.实验内容:在这里插入图片描述根据网络拓扑图如上(交换机不需要配置 ...

  8. Springboot基于Redisson实现Redis分布式可重入锁【案例到源码分析】

    一.前言 我们在实现使用Redis实现分布式锁,最开始一般使用SET resource-name anystring NX EX max-lock-time进行加锁,使用Lua脚本保证原子性进行实现释 ...

  9. 【C# IO 操作 】IFormatProvider接口|IFormattable 接口 格式化接口

    IFormatProvider接口获取一个满足要求的个格式化器. 方法 object? GetFormat(Type? formatType);GetFormat方法主要提供一个满足指定要求的对象,该 ...

  10. 第九周shell脚本编程练习

    转至:http://www.178linux.com/88838 1.写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin):分别这两 ...