Webdriver API之操作(二)
一、窗口截图
dirver.get_screenshot_as_file("D:\\report\\image\\xxx.jpg")
二、关闭窗口
dirver.close() #关闭当前窗口
driver.quit() #退出浏览器
三、操作Cookie
有时候我们需要验证浏览器中是否存在某个 cookie,因为基于真实的 cookie 的测试是无法通过白盒和 集成测试完成的。WebDriver 提供了操作 Cookie 的相关方法可以读取、添加和删除 cookie 信息。
webdriver 操作 cookie 的方法有:
get_cookies() 获得所有 cookie 信息
get_cookie(name) 返回有特定 name 值有 cookie 信息
add_cookie(cookie_dict) 添加 cookie,必须有 name 和 value 值
delete_cookie(name) 删除特定(部分)的 cookie 信息
delete_all_cookies() 删除所有 cookie 信息 下面通过 get_cookies()来获取当前浏览器的 cookie 信息。
from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.youdao.com") # 获得cookie信息
cookie= driver.get_cookies()
#将获得cookie的信息打印
print cookie
driver.quit()
四、验证码处理
1. 让开发去掉验证码
2. 让开发设置万能验证码
3. 验证码识别技术(光学字符识别)
4. 记录cookie
#访问xx网站
driver.get("http://www.xx.cn") #将用户名密码写入浏览器cookie
#username 1@1.com
driver.add_cookie({'name':'Login_UserNumber', 'value':'username'})
#password 111111
driver.add_cookie({'name':'Login_Passwd', 'value':'password'}) #再次访问xx网站,将会自动登录 driver.get("http://www.xx.cn/")
time.sleep(3)
....
driver.quit()
五、调用JavaScript
调用js一般处理有:控制滚动条,富文本,把隐藏的元素显示出来
1. 控制滚动条
js = "window.scrollTo(100,450);"
browser.execute_script(js)
2. 用js写入富文本
js = "document.getElementById('content_ifr').contentWindow.document.body.innerHTML=''你好,我是富文本!"
browser.execute_script(js)
3. 把隐藏的元素显示出来
六、处理HTML5视频
。。。。
七、上传文件
1. send_keys实现上传
(1)普通上传:普通的附件上传都是将本地文件的路径作为一个值放 input 标签中,通过 form 表单提交的时候将这个值提交给服务器。即可以将其看作是一个输入框,通过send_keys()指定本地文件路径的方式实现上传。
#打开上传功能页面
file_path = 'file:///' + os.path.abspath('upfile.html') driver.get(file_path) #定位上传按钮,添加本地文件 driver.find_element_by_name("file").send_keys('D:\\upload_file.txt')
(2)插件上传:一般是指基于 Flash 与 JavaScript 或 Ajax 等技术所实现的上传功能或插件。
2. Autolt实现上传
它是一个类似BASIC脚本语言的免费软件,被设计用来进行Windows GUI(图形用户界面)的自动化测试。利用模拟键盘按键,鼠标移动和窗口/控件的组合来实现自动化任务。
AutoItWindows Info 用于帮助我们识 Windows 控件信息。
CompileScript to.exe 用于将 AutoIt 生成 exe 执行文件。
RunScript 用于执行 AutoIt 脚本。
SciTE Script Editor 用于编写 AutoIt 脚本。
1 #点击打开上传窗口
2 driver.find_element_by_name("file").click()
3
4 #调用upfile.exe上传程序
5 os.system("D:\\upfile.exe")
6 driver.quit()
八、下载文件
Webdriver允许我们设置默认的文件下载路径。
只针对Firefox,所以也可以参考使用Autoit工具(上看)
1 #coding=utf-8
2 from selenium import webdriver
3 import os
4
5 fp = webdriver.FirefoxProfile()
6 # browser.download.folderList设置成 0 代表下载到浏览器默认下载路径;设置成 2 则可以保存到指定目录
7 fp.set_preference("browser.download.folderList",2)
8
9 #browser.download.manager.showWhenStarting
10 是否显示开始,Ture 为显示,Flase 为不显示
11 fp.set_preference("browser.download.manager.showWhenStarting",False)
12
13 #browser.download.dir,用于指定你所下载文件的目录。os.getcwd() 该函数不需要传递参数,用于返回当前的目录。
14 fp.set_preference("browser.download.dir", os.getcwd())
15
16 # browser.helperApps.neverAsk.saveToDisk
17 指定要下载页面的 Content-type 值,“application/octet-stream”为文件的类型。HTTP Content-type 常 用对照表:http://tool.oschina.net/commons
18
19 fp.set_preference("browser.helperApps.neverAsk.saveToDisk", "application/octet-stream")
20
21 #下载文件的类型
22 driver = webdriver.Firefox(firefox_profile=fp)
driver.get("http://pypi.Python.org/pypi/selenium")
driver.find_element_by_partial_link_text("selenium-2").click()
Webdriver API之操作(二)的更多相关文章
- Webdriver API之操作(一)
一. 控制浏览器 1. 控制浏览器大小 driver.set_window_size(480,800) #浏览器宽480,高800显示 dirver.maximize_window() #浏览器最大化 ...
- WebDriver API——延时操作及元素等待
在自动化测试过程当中,受网络.测试设备等诸多因素的影响,我们经常需要在自动化测试脚本中添加一些延时来更好的定位元素来进行一系列的操作. 一般有这么几种方式: 1.implicitlyWait.识别对象 ...
- Webdriver API (二)
(转载) 1.3 打开测试页面 对页面对测试,首先要打开被测试页面的地址(如:http://www.google.com),web driver 提供的get方法可以打开一个页面: // And no ...
- selenium初识(二)——之webdriver API
配置完的环境之后,我们先来写一个小脚本: # __Author__:"Jim_xie" from selenium import webdriver from time impor ...
- WebDriver API——javascript的相关操作
有些时候webdriver是没法操作元素或浏览器的,这时候我们可以通过javascript来进行相关的操作,昨天在群里一个朋友定位一个显示框,总是无法定位点击,或者是点击无效,这个时候就可以用java ...
- Selenium2+Python:Webdriver API速记手册
由于web自动化常常需要控制浏览器行为和操作页面元素,相关函数又比较多,于是再此记下一份Webdriver API查阅文档以备不时之需. 参考:虫师<Selenium2自动化测试实战>,和 ...
- python+selenium自动化软件测试(第2章):WebDriver API
2.1 操作元素基本方法 前言前面已经把环境搭建好了,从这篇开始,正式学习selenium的webdriver框架.我们平常说的 selenium自动化,其实它并不是类似于QTP之类的有GUI界面的可 ...
- Selenium WebDriver Api 知识梳理
之前一直没有系统的梳理WebDriver Api的相关知识,今天借此机会整理一下. 1.页面元素定位 1.1.8种常用定位方法 # id定位 driver.find_element_by_id() # ...
- InfluxDB学习之InfluxDB的HTTP API查询操作
在 InfluxDB学习 的上一篇文章:InfluxDB学习之InfluxDB的HTTP API写入操作 中,我们介绍了使用InfluxDB的HTTP API进行数据写入操作的过程,本文我们再来介绍下 ...
随机推荐
- C#中获取不同的日期时间格式
通过调用类中的各种方法我们可以获取不同的时间: 如:日期(2008-09-04).时间(12:12:12).日期+时间(2008-09-04 12:11:10)等. //获取日期+时间 DateTim ...
- Linux CentOS下MySQL的安装配置之浅谈
前期必备安装:VMware虚拟机,CentOS镜像[注意:Linux下使用CentOS MySQL是不用在官网下载的,只需要配置就OK了] 下面开始正式操作: //CentOS安装MySQL之浅谈 ...
- 在Vue中通过自定义指令获取元素
vue.js 是数据绑定的框架,大部分情况下我们都不需要直接操作 DOM Element,但在某些时候,我们还是有获取DOM Element的需求的: 在 vue.js 中,获取某个DOM Eleme ...
- WinSCP 中普通用户以 root 身份登录 Linux
版本说明: Windows 10 CentOS 7 WinSCP 5.7.7 (Build 6257) 问题背景 使用 WinSCP 登录 CentOS 上传文件,使用的是普通用户,且已加入 sudo ...
- [BNUZOJ1261][ACM][2016北理校赛]方块消除(栈,字符串)
玩过方块消除游戏吗?现在规定当有两个或两个以上相邻且颜色相同的方块在一起的时候,它们就会产生消除反应.当存在多个消除反应同时产生时,最下的反应先执行.现在只给你其中一列,求最后剩下的方块结果. 输入要 ...
- js原生Ajax 的封装和原理
原理及概念 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是一种用于创建快速动态网页的技术. 动态网页:是指可以通过服务器语言结合数 ...
- Android 启动模式--任务(Task)--桟 的误区
Android 启动模式--任务(Task)--桟 的误区 写这篇文章是因为前几天的一次面试,面试官说SingleInstance模式会新建一个桟,而SingleTask不会.首先不说这个对不对(非要 ...
- 记 suds 模块循环依赖的坑-RuntimeError: maximum recursion depth exceeded
下面是soa接口调用的核心代码 #! /usr/bin/python # coding:utf-8 from suds.client import Clientdef SoaRequest(wsdl, ...
- 详解< meta http-equiv = "X-UA-Compatible" content = "IE=edge,chrome=1" />
< meta http-equiv = "X-UA-Compatible" content = "IE=edge,chrome=1" /> 这是个是 ...
- 对Vue.js $watch方法的理解
博主最近对着vue.js的官方教程在自学vue.js,博主自幼愚钝,在教程中真的是好多点都不太理解,接下来要说的这个$watch方法就是其中一个不太理解的点了.咱们先来看一下对于$watch方法在vu ...