什么是po模型呢?简单理解就是:把每个页面当成一个对象,给这些页面当成一个类,主要就是完成元素定位和业务操作;把它和测试脚本区分开来,需要什么取这些页面类去调用即可。这样的好处在于页面元素发生变化时,只需要去维护页面类即可,其他部分就不用管。


PO:指测试页面和测试脚本分离,即页面封装成类,供测试脚本进行调用

项目架构如下:

base基类(所有页面公共方法的二次封装)

'''
所有页面公共方法的二次封装
在脚本中加入太多的sleep后会影响脚本的执行速度
driver:返回浏览器的一个实例
timeout:超时的总时长
poll_frequency:循环去查询的间隙时间,默认0.5s '''
from selenium.webdriver.support.wait import WebDriverWait class BaseAction():
'''
基类
'''
def __init__(self,driver):
self.driver = driver def find_element(self,feature,timeout=10,poll=2):
'''方法内部去调用系统的定位元素'''
return WebDriverWait(self.driver, timeout, poll).until(lambda x: x.find_element(*feature)) def send_keyword(self,feature,text,timeout=10,poll=2):
'''输入内容'''
self.find_element(feature,timeout,poll).send_keys(text) def get_text(self,feature,timeout=10,poll=2):
'''获取元素的文本内容'''
return self.find_element(feature,timeout,poll).text def click_element(self,feature,timeout=10,poll=2):
'''点击元素'''
self.find_element(feature,timeout,poll).click() def clear_element(self,feature,timeout=10,poll=2):
'''清空元素'''
self.find_element(feature,timeout,poll).clear() def get_element(self,feature,timeout,poll):
'''返回定位到的元素'''
return self.find_element(feature,timeout,poll)

页面元素查找类 page

'''
By是selenium中内置的一个class,在这个class中有各种方法来定位元素 '''
from selenium.webdriver.common.by import By
from base.base_action import BaseAction class AssignworkPage(BaseAction):
#一个def是一个动作我们在case中调用这个方法即可对页面进行操作 #点击作业中心
center_work = By.LINK_TEXT,'作业中心'
#点击布置作业
bz_work = By.XPATH,'//*[@id="app"]/main/div/div[2]/div[1]/div[1]/div/button[1]'
def click_centerwork(self):
self.click_element(self.center_work) def work_bz(self):
self.click_element(self.bz_work)

测试case类

import unittest,json
from time import sleep
from selenium import webdriver
from page.assign_homeorkpage import AssignworkPage
from selenium.webdriver.common.action_chains import ActionChains class Work_Build(unittest.TestCase):
def setUp(self):
str = ''
with open('../common/bk.json', 'r', encoding='utf-8') as f:
listCookies = json.loads(f.read())
cookie = [item["name"] + "=" + item["value"] for item in listCookies]
cookiestr = '; '.join(item for item in cookie)
# print(listCookies)
self.driver = webdriver.Chrome('../common/chromedriver.exe')
self.driver.get('url')
# driver.get('https://hte.hexfuture.net/#/inCourse/hte/')
for cookie in listCookies:
if 'expiry' in cookie:
del cookie['expiry']
self.driver.add_cookie(cookie)
self.driver.get('url') self.assign_Homeworkpage = AssignworkPage(self.driver) def tearDown(self):
sleep(3)
self.driver.quit() def test_successbuildwork(self):
'''布置作业主流程'''
#点击作业中心
self.assign_Homeworkpage.click_centerwork() # assert self.indexPage.get_start_go_to_class_text() == "开始上课" if __name__ == '__main__':
unittest.main()

base文件夹下存放着最基础的页面元素方法,例如get_element,send_keys,clear,click等页面操作事件

page文件夹则存放着在我们需要操作页面的操作的xpath事件,一个def是一个事件。例如点击作业中心

scripts下则只存放测试用例

selenium-web自动化(po模型)的更多相关文章

  1. Selenium Web 自动化 - 项目实战(三)

    Selenium Web 自动化 - 项目实战(三) 2016-08-10 目录 1 关键字驱动概述2 框架更改总览3 框架更改详解  3.1 解析新增页面目录  3.2 解析新增测试用例目录  3. ...

  2. Selenium Web 自动化 - 项目持续集成(进阶)

    Selenium Web 自动化 - 项目持续集成(进阶) 2017-03-09 目录 1 背景及目标2 环境配置  2.1 SVN的安装及使用  2.2 新建Jenkins任务3 过程分析 1 背景 ...

  3. Selenium Web 自动化 - 项目持续集成

    Selenium Web 自动化 - 项目持续集成 2017-02-13 目录 1环境准备  1.1 安装git  1.2 安装jenkins  1.3 安装jenkins插件  1.4 jekins ...

  4. Selenium Web 自动化

    1 Selenium Web 自动化 - Selenium(Java)环境搭建 2 Selenium Web 自动化 - 如何找到元素 3 Selenium Web 自动化 - Selenium常用A ...

  5. Selenium Web 自动化 - Selenium(Java)环境搭建

    Selenium Web 自动化 - Selenium(Java)环境搭建 2016-07-29 1 下载JDK JDK下载地址:http://www.oracle.com/technetwork/j ...

  6. Selenium Web 自动化 - 如何找到元素

    Selenium Web 自动化 - 如何找到元素 2016-07-29 1. 什么是元素? 元素:http://www.w3school.com.cn/html/html_elements.asp ...

  7. Selenium Web 自动化 - Selenium常用API

    Selenium Web 自动化 - Selenium常用API 2016-08-01 目录 1 对浏览器操作  1.1 用webdriver打开一个浏览器  1.2 最大化浏览器&关闭浏览器 ...

  8. Selenium Web 自动化 - 项目实战环境准备

    Selenium Web 自动化 - 项目实战环境准备 2016-08-29 目录 1 部署TestNG  1.1 安装TestNG  1.2 添加TestNG类库2 部署Maven  2.1 mav ...

  9. Selenium Web 自动化 - 项目实战(一)

    Selenium Web 自动化 - 测试框架(一) 2016-08-05 目录 1 框架结构雏形2 把Java项目转变成Maven项目3 加入TestNG配置文件4 Eclipse编码修改5 编写代 ...

  10. Selenium Web 自动化 - 项目实战(二)

    Selenium Web 自动化 - 项目实战(二) 2016-08-08 什么是数据驱动?简答的理解就是测试数据决定了测试结果,这就是所谓数据驱动.数据驱动包含了数据,他就是测试数据,在自动化领域里 ...

随机推荐

  1. JUC并发编程学习笔记(十七)彻底玩转单例模式

    彻底玩转单例模式 单例中最重要的思想------->构造器私有! 恶汉式.懒汉式(DCL懒汉式!) 恶汉式 package single; //饿汉式单例(问题:因为一上来就把对象加载了,所以可 ...

  2. JavaSript 数组

    添加数组 push是添加在数组的末位,unshift是添加在首位 let arr= ['a','b','c'] arr.push('d') arr.unshift('E')

  3. .NET8 Blazor新特性 流式渲染

    什么是SSR Blazor中的流式渲染结合了SSR(服务端渲染),服务端将HTML拼好返回给前端,有点像我们熟知的Razor Pages 或 MVC . 当已经有了 Razor Pages 或 MVC ...

  4. jmeter完成文件上传接口

    前提:测试项目中有一个上传本地文件(excel)测被测接口. 测试工具:jmeter 协议:http 测试项目如下图: 第一步:点击模板上传,选择本地excel文件 第二步:上传成功,系统识别exce ...

  5. C++ Qt开发:使用关联容器类

    当我们谈论编程中的数据结构时,顺序容器是不可忽视的一个重要概念.顺序容器是一种能够按照元素添加的顺序来存储和检索数据的数据结构.它们提供了简单而直观的方式来组织和管理数据,为程序员提供了灵活性和性能的 ...

  6. “古剑山”第一届全国大学生网络攻防大赛-Crtpto | Misc WP

    Crypto babyRSA 题目信息 p=105570604806073931560404187362816308950408774915960751676958845800335871518600 ...

  7. BASE和最终一致性

    四种性质: 基本可用性,软状态,强一致性,弱一致性 更据更新数据后各进程访问到数据的时间和方式不同: 如何实现各种类型的一致性: 对于HBase数据库来讲:

  8. Spring整合Quartz简单入门

    创建一个Web项目 导入相关jar包 <?xml version="1.0" encoding="UTF-8"?> <project xmln ...

  9. 【scikit-learn基础】--『预处理』之 正则化

    数据的预处理是数据分析,或者机器学习训练前的重要步骤.通过数据预处理,可以 提高数据质量,处理数据的缺失值.异常值和重复值等问题,增加数据的准确性和可靠性 整合不同数据,数据的来源和结构可能多种多样, ...

  10. 安装华企盾DSC防泄密软件:编辑文件不加密常见问题,运维工程师必看

    1.先查看客户端日志主进程是否是加密进程.日志中是不是勾选智能半透明.加密类型是否有添加 2.用procmon监控保存的文件找出writefile的进程是否有添加,进程树是否有父进程,加密类型是否正确 ...