详解Python多线程Selenium跨浏览器测试


Posted in Python onApril 01, 2017

前言

在web测试中,不可避免的一个测试就是浏览器兼容性测试,在没有自动化测试前,我们总是苦逼的在一台或多台机器上安装N种浏览器,然后手工在不同的浏览器上验证主业务流程和关键功能模块功能,以检测不同浏览器或不同版本浏览器上,我们的web应用是否可以正常工作。

详解Python多线程Selenium跨浏览器测试

下面我们看看怎么利用python selenium进行自动化的跨浏览器测试。

什么是跨浏览器测试

跨浏览器测试是功能测试的一个分支,用以验证web应用能在不同的浏览器上正常工作。

为什么需要跨浏览器测试

通常情况下,我们都期望web类应用能够被我们的用户在任何浏览器上使用。例如,有的人喜欢用IE来打开开源优测web站点http://www.testingunion.com,但有的人喜欢firefox或chrome。

我们期望我们的web系统能在任何浏览器上正常的工作,这样能吸引更多的用户来使用。

需要跨浏览器测试的根源是:

在不同浏览器字体大小不匹配

  1. javascrpit的实现不一样
  2. css、html的验证有所区别
  3. 有的浏览器或低版本不支持HTML5
  4. 页面对齐和div大小问题
  5. 图片位置或大小问题
  6. 浏览器和操作系统间的兼容问题

以上几个方面不仅仅对布局有影响,甚至会导致功能不可用,所以我们需要进行跨浏览器测试。

如何执行跨浏览器测试

如果我们使用selenium webdriver,那我们就能够自动的在IE、firefox、chrome、等不同浏览器上运行测试用例。

为了能在同一台机器上不同浏览器上同时执行测试用例,我们需要多线程技术。

下面我们基于python的多线程技术来尝试同时启动多个浏览器进行selenium自动化测试。

#-*- coding:utf-8 -*-

__author__ = u'苦叶子'

from selenium import webdriver
import sys
from time import sleep
from threading import Thread

reload(sys)
sys.setdefaultencoding("utf-8")

def test_baidu_search(browser, url):
  driver = None
  # 你可以自定义这里,添加更多浏览器支持进来
  if browser == "ie":
    driver = webdriver.Ie() 
  elif browser == "firefox":
    driver = webdriver.Firefox() 
  elif browser == "chrome":
    driver = webdriver.Chrome() 

  if driver == None:
    exit()

  print u"开始[case_0001]百度搜索"
  driver.get(url)

  print u"清除搜索中数据,输入搜索关键词"
  driver.find_element_by_id("kw").clear()
  driver.find_element_by_id("kw").send_keys(u"开源优测")

  print u"单击 百度一下 按钮 开始搜索"
  driver.find_element_by_id("su").click()
  sleep(3)

  print u"关闭浏览器,退出webdriver"
  driver.quit()


if __name__ == "__main__":
  # 浏览器和首页url
  data = {
    "ie":"http://www.baidu.com", 
    "firefox":"http://www.baidu.com", 
    "chrome":"http://www.baidu.com"
    }

  # 构建线程 
  threads = [] 
  for b, url in data.items(): 
    t = Thread(target=test_baidu_search,args=(b,url))
    threads.append(t) 

  # 启动所有线程
  for thr in threads:
    thr.start()

运行上述代码,你会发现三个浏览器都会启动开始进行百度搜索,是不是很有意思?当然上面只是简单的演示,更多更实用的能力有待挖掘。

总结

本文初始演示了利用python多线程技术来启动多个浏览器同时进行selenium自动化测试,通过这个示例你应该要去学习更深入的知识,和深入结合实际业务测试梳理出更合适的自动化测试业务场景。

至于如何更深入的利用selenium把兼容性测试做好,还有待深入研究挖掘,真正的把selenium的特性用好。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中用Descriptor实现类级属性(Property)详解
Sep 18 Python
Python中几个比较常见的名词解释
Jul 04 Python
使用python实现rsa算法代码
Feb 17 Python
Python编程生成随机用户名及密码的方法示例
May 05 Python
python爬取微信公众号文章
Aug 31 Python
详解python中__name__的意义以及作用
Aug 07 Python
python sklearn常用分类算法模型的调用
Oct 16 Python
基于python的列表list和集合set操作
Nov 24 Python
解决python中的幂函数、指数函数问题
Nov 25 Python
python查找特定名称文件并按序号、文件名分行打印输出的方法
Apr 24 Python
pandas针对excel处理的实现
Jan 15 Python
Django数据库(SQlite)基本入门使用教程
Jul 07 Python
Python 基础之字符串string详解及实例
Apr 01 #Python
Python中格式化format()方法详解
Apr 01 #Python
Python 中开发pattern的string模板(template) 实例详解
Apr 01 #Python
Python新手们容易犯的几个错误总结
Apr 01 #Python
深入解答关于Python的11道基本面试题
Apr 01 #Python
教大家玩转Python字符串处理的七种技巧
Mar 31 #Python
Python中你应该知道的一些内置函数
Mar 31 #Python
You might like
为指定元素增加样式的js代码
2009/12/09 Javascript
查询绑定数据岛的表格中的文本并修改显示方式的js代码
2009/12/15 Javascript
扩展jQuery对象时如何扩展成员变量具体怎么实现
2014/04/25 Javascript
js获取字符串最后一位方法汇总
2014/11/13 Javascript
jquery判断复选框选中状态以及区分attr和prop
2015/12/18 Javascript
jQuery复制节点用法示例(clone方法)
2016/09/08 Javascript
js html css实现复选框全选与反选
2016/10/09 Javascript
移动端点击态处理的三种实现方式
2017/01/12 Javascript
JS ES6多行字符串与连接字符串的表示方法
2017/04/26 Javascript
学习使用Bootstrap页面排版样式
2017/05/11 Javascript
nodejs开发微信小程序实现密码加密
2017/07/11 NodeJs
基于vue2.x的电商图片放大镜插件的使用
2018/01/22 Javascript
vue同步父子组件和异步父子组件的生命周期顺序问题
2018/10/07 Javascript
vue设置导航栏、侧边栏为公共页面的例子
2019/11/01 Javascript
JS桶排序的简单理解与实现方法示例
2019/11/25 Javascript
vue 输入电话号码自动按3-4-4分割功能的实现代码
2020/04/30 Javascript
在vue中实现某一些路由页面隐藏导航栏的功能操作
2020/09/21 Javascript
Vue.js桌面端自定义滚动条组件之美化滚动条VScroll
2020/12/01 Vue.js
jQuery实现电梯导航模块
2020/12/22 jQuery
Python3安装Pymongo详细步骤
2017/05/26 Python
深入浅析python 协程与go协程的区别
2019/05/09 Python
python中的函数递归和迭代原理解析
2019/11/14 Python
python自动下载图片的方法示例
2020/03/25 Python
基于python3.7利用Motor来异步读写Mongodb提高效率(推荐)
2020/04/29 Python
Django如何重置migration的几种情景
2021/02/24 Python
css3 旋转按钮 使用CSS3创建一个旋转可变色按钮
2012/12/31 HTML / CSS
Grow Gorgeous美国官网:只要八天,体验唤醒毛囊后新生的茂密秀发
2018/06/04 全球购物
土木工程专业自荐信
2013/10/04 职场文书
项目经理的岗位职责
2013/11/23 职场文书
爷爷追悼会答谢词
2014/01/24 职场文书
护士节演讲稿开场白
2014/08/25 职场文书
单位租房协议范本
2014/12/03 职场文书
大学学生个人总结
2015/02/15 职场文书
调解协议书范本
2016/03/21 职场文书
SpringBoot2 参数管理实践之入参出参与校验的方式
2021/06/16 Java/Android
Vue组件更新数据v-model不生效的解决
2022/04/02 Vue.js