Python Selenium UI自动化测试
Python Selenium UI自动化测试
1、自动化测试基础
1.1 自动化测试的定义
- 将人为的测试行为转化为机器自动执行的过程
1.2 自动化测试的目的
- 减少成本,提高测试效率
- 减少人为因素对测试的影响
1.3 什么项目适合做自动化测试
- 项目界面稳定
- 需求明确
- 项目周期长
- 测试脚本可以重复使用
- 需要频繁地进行回归测试
1.4 难点
- 对比手工UI测试,UI自动化测试有如下的难点:
1)UI本身的变化性,要想达到和手工测试相同的覆盖率,单纯的UI自动化测试往往很难 证明自己的投资回报; 2)UI控件元素本身识别的复杂性;
3)UI自动化测试出现问题时,恢复到下一条测试case执行的场景是复杂的。因为出现 这种问题的意外,是非“预期”的;
2、搭建自动化测试环境
2.1 安装python
略
2.2 安装selenium
# 安装Selenium的最新版本
pip install selenium
# 安装Selenium指定版本
pip install selenium==2.53.0
2.3 下载webdriver驱动
以chrome浏览器为例
- 查看chrome浏览器版本:在地址栏输入 chrome://version
- chromedriver下载地址:http://chromedriver.storage.googleapis.com/index.html
- 下载与浏览器版本对应的chrome driver
- 将下载好的chrome driver 解压,并放至到Python安装路径的根目录 (安装路径随意一个都行)
2.4 第一个自动化测试脚本
- 打开浏览器
- 访问百度首页
from selenium import webdriver # 导入webdriver
d = webdriver.Chrome() # 创建浏览器对象,此方法需要提前将webdriver驱动添加到系统环境变量
d.get('https://www.baidu.com') # 调用get方法访问百度首页
d.close() # 关闭浏览器
3、webdriver API
3.1 浏览器操作
3.1.1 浏览器最大化
- driver.maximize_window()
3.1.2 设置浏览器的宽和高
- driver.set_window_size(480,800)
3.1.3 控制浏览器前进、后退
- 前进: driver.forward()
- 后退: driver.back()
3.1.4 关闭浏览器
- 关闭当前窗口: driver.close()
- 关闭浏览器: driver.quit()
3.1.5 浏览器刷新
- driver.refresh()
3.1.6 获取当前URL
- driver.current_url
3.1.7 获取当前title
- driver.title
3.1.8 浏览器截图
- driver.save_screenshot(图片路径)
--路径参数必填
--图片格式必须为png
3.2 元素定位
3.2.1 常见的属性
- class:元素的类名
- id:元素的唯一id
- name:元素名,大部分情况唯一
3.2.2 八大元素定位方法
- 元素定位和操作是自动化测试的核心部分
- 一个元素就像一个人,有自己的特征(属性)
- webdriver提供了一系列的元素定位方法,常用的有下面几种:
- id:根据元素id值
- name:根据元素name值
- class name:根据元素class值
- tag name:根据元素标签名字
- link text:根据超链接的文本内容
- partial link text:根据超链接的部分文本内容
- xpath:根据xpath
- css selector:通过css定位
xpath定位
语法
/ :从根节点选取(绝对路径)
// :从当前节点选取,不考虑节点的位置(相对路径)
.. :选取当前节点的父节点 搜索框的上两级父节点: //*[@id='kw']/../..
@ :选取属性
举例:
相对路径: //div[@class='entry-sider-panel']/section[@class='entry-sider-panel__bd']/div/div[1]
CSS定位
语法
#:选取id属性,#kw
.:选取class属性
[]:选取其他属性,如:[id='xx']
> :层级选取,如:#form>span>input
举例:div.entry-sider-panel>section.entry-sider-panel__bd>div>div:nth-child(1)
3.3 元素操作
3.3.1 输入内容
send_keys()
3.3.2 点击元素
click()
3.3.3 清空元素文本内容
clear()
3.3.4 获取元素文本
text
- 返回的是字符串
3.3.5 获取元素尺寸
size
- 返回的是字典
3.3.6 获取元素的属性值
get_attribute('属性值') --如id,class
4、设置等待时间
4.1 强制等待
sleep()
- 需要先导包,import time
4.2 隐式等待
driver.implicitly_wait(秒)
- 智能等待是在等待周期内一直等待元素是否出现,如果元素出现则继续,元素在等待周期内没有出现则报错
- 推荐等待时间:10-30秒
- 隐式等待只需设置一次就可以对整个脚本文件生效
4.3 显式等待
显式等待使WebdDriver等待某个条件成立时继续执行,否则在达到最大时长时抛出超时异常
示例代码:
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
driver = webdriver.Chrome()
driver.get("http://www.baidu.com") # 每隔 0.5s 检查一次(默认就是 0.5s), 最多等待 5 秒
element = WebDriverWait(driver, 5, 0.5).until( EC.visibility_of_element_located( (By.ID, "kw")
) )
element.send_keys('selenium')
driver.quit()
5、滚动条操作、下拉框操作
5.1 操作滚动条
注意:操作滚动天是通过js操作的,不是通过selenium操作的
方法一:
from selenium import webdriver
from time import sleep
driver = webdriver.Chrome()
driver.get('https://www.baidu.com')
driver.set_window_size(688,476)
sleep(1)
js = 'window.scrollTo(0,10000)' # 拖动到底部
driver.execute_script(js) # 执行js命令
sleep(1)
js2 = 'window.scrollTo(10000,0)' # 从左拖到右
driver.execute_script(js2)
sleep(1)
js3 = 'window.scrollTo(10000,10000)' # 拖到右下角
driver.execute_script(js3)
sleep(2)
driver.quit()
方法二(推荐):
target = self.element(self.locators['product_des']) # 定位到目标元素
self._driver.execute_script("arguments[0].scrollIntoView();", target) # 滚动条滑动到目标元素
5.2 操作下拉框
方法一:二次定位,先定位到下拉框,然后通过里面的值进行定位
方法二:通过select库进行操作
示例代码:
from selenium import webdriver
from time import sleep
from selenium.webdriver.support.select import Select
driver = webdriver.Chrome()
driver.get('file:///C:/Users/Eccang/Desktop/test.html')
sleep(1)
# 方法一
# 二次定位
m = driver.find_element_by_id('abc') # 先定位到下拉框
# m.find_element_by_xpath("//*[@value='p1']").click() # 再定位一次选择里面的选项
# 方法二
Select(m).select_by_index(1) # 根据索引值选择
sleep(1)
Select(m).select_by_value('p2') # 根据值选择
sleep(1)
Select(m).select_by_visible_text('深圳') # 根据可见文本选择
6、多窗口处理、弹框处理
6.1 多窗口处理
根据窗口的handle值进行切换
获取当前窗口handle值:driver.current_window_handle
获取所有窗口handle值:driver.window_handles
根据handle值切换窗口:driver.switch_to.window(窗口handle值)
6.2 弹框处理
点击确定:driver.switch_to.alert.accept()
点击取消:driver.switch_to.alert.dismiss()
弹框中输入文本:driver.switch_to.alert.send_keys()
获取弹框中的文本内容:driver.switch_to.alert.text
7、框架切换、文件上传
7.1 框架切换
切换框架:driver.switch_to.frame(id/name)
返回默认框架:driver.switch_to.default_content()
7.2 文件上传
对于通过input标签实现的上传功能,可以将其看作是一个输入框,即通过 send_keys()指定本地文件路径的方式实现文件上传
对于非 input 标签实现的上传功能,我们可以通过模拟键盘敲击的方式实现,代码如下:
import win32com.client # 导入Windows API模块
driver.find_element_by_css_selector("#top .icon").click()
sh = win32com.client.Dispatch("WScript.shell")
time.sleep(3)
sh.Sendkeys("C:\\Users\Downloads\f89860fb73c0ba14c9b88845eb10b928.jpeg\n")
8、浏览器无头模式
chrome_options = Options() # 开发者模式,防止被各大网站识别出来用了selenium
chrome_options.add_argument('--headless') # 添加谷歌无头浏览器模式
driver=webdriver.Chrome(options=chrome_options) # 谷歌无头浏览器模式
9、单例模式
单例模式:单例模式就是确保一个类只有一个实例.当你希望整个系统中,某个类只有一个实例时,单例模式就派上了用场
由于在做web UI测试的时候需要浏览器对象,在实际写脚本的过程中可能会遇到只要调用一次webdriver就会生成一个浏览器对象,此时我们可以用到单例模式来处理(或者自己写一个判断语句也是可以处理的)。具体实现代码如下:
后续有时间会补充一些写自动化测试用例过程中需要用到的分层思想,已经一些测试用例、脚本关联、数据处理方面的东西。。。
Python Selenium UI自动化测试的更多相关文章
- Python+Selenium UI自动化测试环境搭建及使用
一什么是Selenium ? Selenium 是一个浏览器自动化测试框架,它主要用于web应用程序的自动化测试,其主要特点如下:开源.免费:多平台.浏览器.多语言支持:对web页面有良好的支持:AP ...
- Selenium UI自动化测试 Selenium Automatic Testing
https://www.cnblogs.com/sunada2005/archive/2013/12/22/3486314.html UI Automatic Testing 1. 什么样的项目适合自 ...
- python selenium web自动化测试完整项目实例
问题: 好多想不到的地方,中间经历了一次重构,好蛋疼: xpath定位使用的不够熟练,好多定位问题,只能靠强制等待解决: 存在功能重复的方法,因为xpath定位不同,只能分开写,有时间可以继续优化: ...
- Python+Selenium学习--自动化测试模型
前言 一个自动化测试框架就是一个集成体系,在这一体系中包含测试功能的函数库.测试数据源.测试对象识别标准,以及种可重用的模块.自动化测试框架在发展的过程中经历了几个阶段,模块驱动测试.数据驱动测试.对 ...
- Python&selenium&tesseract自动化测试随机码、验证码(Captcha)的OCR识别解决方案参考
在自动化测试或者安全渗透测试中,Captcha验证码的问题经常困扰我们,还好现在OCR和AI逐渐发展起来,在这块解决上越来越支撑到位. 我推荐的几种方式,一种是对于简单的验证码,用开源的一些OCR图片 ...
- 配置Python+selenium+firefox自动化测试
1.安装python.默认安装 2.安装pip.下载pip-1.5.4包,解压pip-1.5.4,放在C盘,进入pip目录-->键入命令:python setup.py install 再进入 ...
- python selenium+phantomJS自动化测试环境
0x00配置phantomJS 1. 在windows平台下 此种方法是弹浏览器进行自动化测试的. 1.下载谷歌的驱动 https://chromedriver.storage.googleapis. ...
- python + selenium webdriver 自动化测试 之 环境异常处理 (持续更新)
1.webdriver版本与浏览器版本不匹配,在执行的时候会抛出如下错误提示 selenium.common.exceptions.WebDriverException: Message: unkno ...
- python + selenium + unittest 自动化测试框架 -- 入门篇
. 预置条件: 1. python已安装 2. pycharm已安装 3. selenium已安装 4. chrome.driver 驱动已下载 二.工程建立 1. New Project:建立自己的 ...
- Python+Selenium - Web自动化测试(一):环境搭建
清单列表: Python 3x Selenium Chrome Pycharm 一.Python的安装: Python官网下载地址:https://www.python.org/ 1. 进入官网地址 ...
随机推荐
- nginx重启和操作
在linux操作系统中,重启nginx 1.当不知道nginx所在目录时,需要先查找到nginx的位置 查看ngnix位置(master process 后面的就是 nginx的目录): ps -e ...
- 电商AARRR模型分析(一)——R语言
在2010年,互联网创业者增长黑客之父肖恩·埃利斯(Sean Ellis)就创造了增长黑客(Growth hacker)这样一个概念.2015年,范冰撰写的一本新书<增长黑客>确立了Gro ...
- golang pprof 监控系列(4) —— goroutine thread 统计原理
golang pprof 监控系列(4) -- goroutine thread 统计原理 大家好,我是蓝胖子. 在之前 golang pprof监控 系列文章里我分别介绍了go trace以及go ...
- python实现关闭usb功能
禁用usb和启用usb 一禁用usb自动加载功能 公司内部有时候需要禁用usb接口的文件拷贝,但是打印机,扫描枪等待其他设备的使用,我们应该怎么做呢,很简单,可以通过修改BIOS,注册表和第三方软件实 ...
- etcd/raft选举源码解读
ETCD-raft笔记 0. 引言 该篇博客基于etcd v3.5.7版本,首先会简单介绍etcd/raft对Raft选举部分的算法优化,然后通过源码分析etcd/raft的选举实现. 1. etcd ...
- 在 Rainbond 上使用在线知识库系统zyplayer-doc
zyplayer-doc 是一款适合企业和个人使用的WIKI知识库管理工具,提供在线化的知识库管理功能,专为私有化部署而设计,最大程度上保证企业或个人的数据安全,可以完全以内网的方式来部署使用它. 当 ...
- mongoDB操作指南
目录 1. docker安装mongoDB 2. 库-database 3. 集合-collection 3.1 命名规范 3.2 增-createCollection 3.3 删-drop 4. 文 ...
- scikit-learn 中 Boston Housing 数据集问题解决方案
scikit-learn 中 Boston Housing 数据集问题解决方案 在部分旧教程或教材中是 sklearn,现在[2023]已经变更为 scikit-learn 作用:开源机器学习库,支持 ...
- Android刷机日记
0x01 工具准备(镜像之类的注意下载的版本要与手机一致) 1)SDK工具 https://developer.android.com/studio/releases/platform-tools?h ...
- 从原理聊JVM(三):详解现代垃圾回收器Shenandoah和ZGC
作者:京东科技 康志兴 Shenandoah Shenandoah一词来自于印第安语,十九世纪四十年代有一首著名的航海歌曲在水手中广为流传,讲述一位年轻富商爱上印第安酋长Shenandoah的女儿的故 ...