selenium基础框架的封装(Python版)
一、常用函数的封装
在使用selenium做web自动化测试的过程中,经常会碰到各种各样的问题,比如:
1、页面加载比较慢时,selenium查找元素抛出异常,导致脚本运行中止
2、写完脚本后发现代码逻辑不够清晰,维护困难,降低测试效率
所以很有必要对selenium进行封装使框架更适合公司的需求,下面是基类的封装,主要使用单例模式,可以将业务逻辑代码存放在不同的Python文件中
注:BASE_URL为博客园的登录地址
# -*- coding:utf-8 -*-
from selenium import webdriver
import time OVER_TIME = 5
BASE_URL = "https://passport.cnblogs.com/user/signin?ReturnUrl=https%3A%2F%2Fwww.cnblogs.com%2F" class Driver(object): def __new__(cls, *args, **kw):
"""
使用单例模式将类设置为运行时只有一个实例,在其他Python类中使用基类时,
可以创建多个对象,保证所有的对象都是基于一个浏览器
"""
if not hasattr(cls, '_instance'):
orig = super(Driver, cls)
cls._instance = orig.__new__(cls, *args, **kw)
return cls._instance def start(self, url=BASE_URL, driver_name="Chrome"):
"""
启动浏览器
:param url: 测试地址
:param driver_name: 在启动时设置浏览器的类型
:return:
"""
if driver_name == "Firefox":
self.driver = webdriver.Firefox()
elif driver_name == "Ie":
self.driver = webdriver.Ie()
else:
self.driver = webdriver.Chrome()
self.driver.implicitly_wait(OVER_TIME)
self.driver.get(url)
self.driver.maximize_window() def get_url(self):
"""返回浏览器的地址"""
return BASE_URL def find_element(self, by, value):
"""
这里添加了一个OVER_TIME作为查找元素的超时次数,根据系统的实际情况设置OVER_TIME的大小
"""
for i in range(OVER_TIME):
try:
return self.driver.find_element(by=by, value=value)
except Exception, e:
print e def find_elements(self, by, value):
"""与find_element一致"""
for i in range(OVER_TIME):
try:
return self.driver.find_elements(by=by, value=value)
except Exception, e:
print e def find_display_elements(self, by, value):
"""
查找状态为displayed的元素集合,当查找一类元素时,
经常出现有些元素是不可见的情况,此函数屏蔽那些不可见的元素
"""
for i in range(OVER_TIME):
try:
elements = self.driver.find_elements(by=by, value=value)
num = elements.__len__()
except Exception, e:
print e
time.sleep(1)
if num >= 1:
break
display_element = []
# 将可见的元素放到列表中, 并返回
for j in range(num):
element = elements.__getitem__(j)
if element.is_displayed():
display_element.append(element)
return display_element def is_element_present(self, By, Value):
"""判断元素是否存在"""
try:
self.driver.find_element(by=By, value=Value)
return True
except Exception, e:
print e
return False def close(self):
self.driver.close() def quit(self):
u"""退出浏览器"""
self.driver.quit() if __name__ == "__main__":
page = Driver()
page.start()
二、使用封装过的框架和pageobject模式设计登录脚本
# -*- coding:utf-8 -*-
from webdriver import Driver
from selenium.webdriver.common.by import By class Login(object): def __init__(self, user_name="xxx", pwd="xxx"):
self.page = Driver()
page = self.page
page.start(url=page.get_url())
self.user_name = page.find_element(By.ID, "input1")
self.pwd = page.find_element(By.ID, "input2")
self.login_btn = page.find_element(By.ID, "signin")
self.login(user_name, pwd) def login(self, user_name, pwd):
self.user_name.clear()
self.user_name.send_keys(user_name)
self.pwd.clear()
self.pwd.send_keys(pwd)
self.login_btn.click() if __name__ == "__main__":
Login("xxx", "xxx")
三、打开博客园新闻、博问等子页面脚本设计
# -*- coding:utf-8 -*-
from webdriver import Driver
from login import Login
from selenium.webdriver.common.by import By class SubPage(object): def __init__(self):
self.page = Driver()
page = self.page
self.home_page = page.find_element(By.LINK_TEXT, u"园子")
self.news_page = page.find_element(By.LINK_TEXT, u"新闻")
self.q_page = page.find_element(By.LINK_TEXT, u"博问")
self.ing_page = page.find_element(By.LINK_TEXT, u"闪存") def open_home_page(self):
self.home_page.click() def open_news_page(self):
self.news_page.click() def open_q_page(self):
self.q_page.click() def open_ing_page(self):
self.ing_page.click() if __name__ == '__main__':
Login("xxx", "xxx")
sub = SubPage()
sub.open_q_page()
四、其他
按照此模式博友可根据公司具体的业务来实现自动化测试脚本,本文抛砖引玉,如有其他更好的想法可以一起探讨
Thanks!
selenium基础框架的封装(Python版)的更多相关文章
- selenium基础框架的封装(Python版)这篇帖子在百度关键词搜索的第一位了,有图为证,开心!
百度搜索结果页地址:https://www.baidu.com/s?ie=utf-8&f=3&rsv_bp=1&rsv_idx=1&tn=baidu&wd=se ...
- python selenium 基础框架
base_page.py # coding=utf-8 import time from selenium.common.exceptions import NoSuchElementExceptio ...
- selenium截取具体元素图片(python版)
原理: 1.截图(整个窗口) 2.获取此元素坐标 element = driver.find_element_by_id("xx") element.location) 3.获取此 ...
- 数论基础算法总结(python版)
/* Author: wsnpyo Update Date: 2014-11-16 Algorithm: 快速幂/Fermat, Solovay_Stassen, Miller-Rabin素性检验/E ...
- 『心善渊』Selenium3.0基础 — 2、Selenium测试框架环境搭建(Windows)
目录 1.浏览器安装 2.浏览器驱动下载 (1)ChromeDriver for Chrome (2)Geckodriver for Firefox (3)IEDriverServer for IE ...
- 《手把手教你》系列基础篇(九十七)-java+ selenium自动化测试-框架设计篇-Selenium方法的二次封装和页面基类(详解教程)
1.简介 上一篇宏哥介绍了如何设计支持不同浏览器测试,宏哥的方法就是通过来切换配置文件设置的浏览器名称的值,来确定启动什么浏览器进行脚本测试.宏哥将这个叫做浏览器引擎类.这个类负责获取浏览器类型和启动 ...
- Python+Selenium基础入门及实践
Python+Selenium基础入门及实践 32018.08.29 11:21:52字数 3220阅读 23422 一.Selenium+Python环境搭建及配置 1.1 selenium 介绍 ...
- Python基础教程(第3版)PDF高清完整版免费下载|百度云盘
百度云盘:Python基础教程(第3版)PDF高清完整版免费下载 提取码:gkiy 内容简介 本书包括Python程序设计的方方面面:首先从Python的安装开始,随后介绍了Python的基础知识和基 ...
- python+selenium之框架设计
一.自动化测试框架 1.什么是自动化测试框架 简单来说,自动化测试框架就是由一些标准,协议,规则组成,提供脚本运行的环境.自动化测试框架能够提供很多便利给用户高效完成一些事情,例如,结构清晰开发脚本, ...
随机推荐
- pygame加载中文名mp3文件出现error
好一阵子没有写东西了,最近几天在做一个基于Python pygame的音乐播放器,本来想做完了,再来发篇文章的,可越做越深,框架大致出来了,考虑周期比较长,也可能是我个人问题,做得比较慢,最近.下面来 ...
- 【转】AS3多种天气预报调用代码分享
今天我们来介绍利用weather.com.cn上的天气预报功能,这里介绍了大家常用的,其它的大家可以自己去下载. 我们这里的天气预览不需要js来调用,只要用iframe就可以了,更不需要ASP/' t ...
- 老李分享:pep8 python代码规范
老李分享:pep8 python代码规范 什么是PEPPEP是 Python Enhancement Proposal 的缩写,翻译过来就是 Python增强建议书 . PEP8 译者:本文基于 20 ...
- 10 分钟学会Linux常用 bash命令
目录 基本操作 1.1. 文件操作 1.2. 文本操作 1.3. 目录操作 1.4. SSH, 系统信息 & 网络操作 基本 Shell 编程 2.1. 变量 2.2. 字符串替换 2.3. ...
- Alamofire源码解读系列(十二)之时间轴(Timeline)
本篇带来Alamofire中关于Timeline的一些思路 前言 Timeline翻译后的意思是时间轴,可以表示一个事件从开始到结束的时间节点.时间轴的概念能够应用在很多地方,比如说微博的主页就是一个 ...
- (转)Java并发编程:并发容器之CopyOnWriteArrayList
原文链接:http://ifeve.com/java-copy-on-write/ Copy-On-Write简称COW,是一种用于程序设计中的优化策略.其基本思路是,从一开始大家都在共享同一个内容, ...
- 移动开发中使用的一些meta头部标签整理
<!DOCTYPE html> <!-- 使用 HTML5 doctype,不区分大小写 --> <html lang="zh-cmn-Hans"&g ...
- css form表单样式清除
开发项目中表单常用的清楚样式: 1.改变placeholder默认字体颜色 ::-webkit-input-placeholder{color: #333;} :-moz-placeholder{co ...
- iOS关于JSONKit解析Unicode字符内容出错,问题出在\u0000
JSONKit虽然很强大,但是一些特殊的Unicode,比如\u0000是无法解析的. 在github上作者解释了这个问题,说这个是内容提供的错误,不符合标准的内容,所以他不认为这个是自己的错误,这个 ...
- 为已有表快速创建自动分区和Long类型like 的方法-Oracle 11G
对上一篇文章进行实际的运用.在工作中遇到有一张大表(五千万条数据),在开始的时候忘记了创建自动分区,导致现在使用非常不方便,查询的速度非常的满,所以就准备重新的分区表,最原始方法是先创建新的分区表,然 ...