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.什么是自动化测试框架 简单来说,自动化测试框架就是由一些标准,协议,规则组成,提供脚本运行的环境.自动化测试框架能够提供很多便利给用户高效完成一些事情,例如,结构清晰开发脚本, ...
随机推荐
- C语言 动态数组实现
一.概述 C语言是不能直接定义动态数组的,数组必须在初始化时确定长度. 如果要在程序运行时才确定数组的长度,就需要在运行的时候,自己去向系统申请一块内存用动态内存分配实现动态数组. 二.动态内存分配函 ...
- Luogu1074靶形数独【启发式搜索】
Luogu1074靶形数独 题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他 们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教, ...
- 【转】flash air中读取本地文件的三种方法
actionscript中读取本地文件操作有两种代码如下 1.使用File和FileStream两个类,FileStream负责读取数据的所以操作:(同步操作) var stream:FileStre ...
- Framework7+vue demo
最近看了下f7+vue做了几个测试页面,商品图片来自淘宝,代码等有时间了再传,
- mysql 分析5语句的优化--索引添加删除
查看表的索引 show create table 表名; show index from 表名; show keys from表名; 添加索引 alter table 表名 add index 索 ...
- 最小函数值 洛谷P2085
题目描述: 有n个函数,分别为F1,F2,...,Fn.定义Fi(x)=Ai*x^2+Bi*x+Ci (x∈N*).给定这些Ai.Bi和Ci,请求出所有函数的所有函数值中最小的m个( ...
- JavaWeb项目实现文件上传动态显示进度
很久没有更新博客了,这段时间实在的忙的不可开交,项目马上就要上线了,要修补的东西太多了.当我在学习JavaWeb文件上传的时候,我就一直有一个疑问,网站上那些博客的图片是怎么上传的,因为当提交了表单之 ...
- 数据源C3P0配置
1.导入jar包(dbutil->QueryRunner) 2.C3P0Util工具类 package com.learning.utils; import java.beans.Propert ...
- Spark源码分析之分区器的作用
最近因为手抖,在Spark中给自己挖了一个数据倾斜的坑.为了解决这个问题,顺便研究了下Spark分区器的原理,趁着周末加班总结一下~ 先说说数据倾斜 数据倾斜是指Spark中的RDD在计算的时候,每个 ...
- 文本处理sed常用操作
文本处理sed常用操作 linux sed (stream editor) is a Unix utility that parses and transforms text, using a sim ...