selenium-web自动化(po模型)
什么是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模型)的更多相关文章
- Selenium Web 自动化 - 项目实战(三)
Selenium Web 自动化 - 项目实战(三) 2016-08-10 目录 1 关键字驱动概述2 框架更改总览3 框架更改详解 3.1 解析新增页面目录 3.2 解析新增测试用例目录 3. ...
- Selenium Web 自动化 - 项目持续集成(进阶)
Selenium Web 自动化 - 项目持续集成(进阶) 2017-03-09 目录 1 背景及目标2 环境配置 2.1 SVN的安装及使用 2.2 新建Jenkins任务3 过程分析 1 背景 ...
- Selenium Web 自动化 - 项目持续集成
Selenium Web 自动化 - 项目持续集成 2017-02-13 目录 1环境准备 1.1 安装git 1.2 安装jenkins 1.3 安装jenkins插件 1.4 jekins ...
- Selenium Web 自动化
1 Selenium Web 自动化 - Selenium(Java)环境搭建 2 Selenium Web 自动化 - 如何找到元素 3 Selenium Web 自动化 - Selenium常用A ...
- Selenium Web 自动化 - Selenium(Java)环境搭建
Selenium Web 自动化 - Selenium(Java)环境搭建 2016-07-29 1 下载JDK JDK下载地址:http://www.oracle.com/technetwork/j ...
- Selenium Web 自动化 - 如何找到元素
Selenium Web 自动化 - 如何找到元素 2016-07-29 1. 什么是元素? 元素:http://www.w3school.com.cn/html/html_elements.asp ...
- Selenium Web 自动化 - Selenium常用API
Selenium Web 自动化 - Selenium常用API 2016-08-01 目录 1 对浏览器操作 1.1 用webdriver打开一个浏览器 1.2 最大化浏览器&关闭浏览器 ...
- Selenium Web 自动化 - 项目实战环境准备
Selenium Web 自动化 - 项目实战环境准备 2016-08-29 目录 1 部署TestNG 1.1 安装TestNG 1.2 添加TestNG类库2 部署Maven 2.1 mav ...
- Selenium Web 自动化 - 项目实战(一)
Selenium Web 自动化 - 测试框架(一) 2016-08-05 目录 1 框架结构雏形2 把Java项目转变成Maven项目3 加入TestNG配置文件4 Eclipse编码修改5 编写代 ...
- Selenium Web 自动化 - 项目实战(二)
Selenium Web 自动化 - 项目实战(二) 2016-08-08 什么是数据驱动?简答的理解就是测试数据决定了测试结果,这就是所谓数据驱动.数据驱动包含了数据,他就是测试数据,在自动化领域里 ...
随机推荐
- 一篇文章让你理解:什么是Spring???
背景 市场上,随便一个Java工程师的招牌要求上,都可以看到SSM.Spring.SpringMVC...类似字样.这玩意到底是个啥? 这是中邮消费招聘的岗位要求,可以看到第3点: 3.熟悉Strut ...
- C语言编写两个函数,分别求两个整数的最大公约数和最小公倍数,并用主函数调用这两个函数,然后输出结果。两个整数由键盘输入。约定最大公约数为正整数,两数里有负的则最小公倍数就为负的。
/* 开发者:慢蜗牛 开发时间:2020.5.28 程序功能:计算最大公约数和最小公倍数 */ #include<stdio.h> #include<math.h> int m ...
- Serializable是什么?为什么在Entity层要实现Serializable接口
我在做房产信息管理系统时用到了Serializable接口 Serializable含义: 一个对象序列化的接口,一个类只有实现了Serializable接口,它的对象才能被序列化. Serializ ...
- AutoCAD ObjectARX 二次开发(2020版)--1,下载和部署开发环境--
教程说明: 本教程为2019年10月开始编撰,使用CAD官方最新版本的软件和库.对旧版本仍有参考价值. 本教程中使用的各种软件版本为官方指定匹配版本. 本教程需要你拥有编程基础,对于普通编程常识不再敷 ...
- ES到底是个什么东西
概念:全文检索服务器(是基于Lucene开发的全文检索服务器),它可以近乎实时存储.检索数据,底层仍然是Lucene来实现的所以索引和搜索功能,他的目的是通过的简单的RESTFul API 来隐藏Lu ...
- 聊聊大数据框架的数据更新策略: COW,MOR,MOW
大数据框架下,常用的数据更新策略有三种: COW: copy-on-write, 写时复制; MOR: merge-on-read, 读时合并; MOW: merge-on-write, 写时合并; ...
- VO、DTO、Entity的区别
只能说从实际用法的一般习惯上进行区分: 1.entity 里的每一个字段,与数据库相对应,注意:entity与对应的实际数据库表的字段 没有强制要求但是一般建议保持一致(包括字段数据类型),当然,从实 ...
- zookeeper JavaApi 修改节点
*修改数据 * 1.修改数据 * 2.根据版本修改 * * * */ @Test public void testSet() throws Exception{ Stat stat = new Sta ...
- 聊聊GLM基座模型的理论知识
概述 大模型有两个流程:预训练和推理. 预训练是在某种神经网络模型架构上,导入大规模语料数据,通过一系列的神经网络隐藏层的矩阵计算.微分计算等,输出权重,学习率,模型参数等超参数信息. 推理是在预训练 ...
- 【UniApp】-uni-app-路由
前言 好,经过上个章节的介绍完毕之后,了解了一下 uni-app-CompositionAPI应用生命周期和页面生命周期 那么了解完了uni-app-CompositionAPI应用生命周期和页面生命 ...