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进行数据写入操作的过程,本文我们再来介绍下 ...
随机推荐
- 用smarty模板做数据实现修改、分页等功能
先来看怎么把数据库的列表全都显示出来 还是要先建一个php文件,还有html文件,都存到相应的目录下 php文件中 <?php include("../init.inc.php&quo ...
- 用JavaScript实现图片剪切效果
学会如何获取鼠标的坐标位置以及监听鼠标的按下.拖动.松开等动作事件,从而实现拖动鼠标来改变图片大小. 还可以学习css中的clip属性. 一.CSS实现图片不透明及裁剪效果. 图片剪切三层结构 1.第 ...
- php 实现购物车功能,以大苹果购物网为例,上图上代码。。。。
首先是几个简单的登录页面 <body> <form action="chuli.php" method="post"> <div ...
- WebGIS中自定义互联网地图局部注记的一种方案
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1. 前言 实际项目中我们经常会遇到这样一种场景:地图底图可能是互 ...
- (读书笔记)第2章 TCP-IP的工作方式
第2章 TCP-IP的工作方式 TCP/IP协议系统 为了实现TCP的功能,TCP/IP的创建者使用了模块化的设计.TCP/IP协议系统被分为不同的组件,每个组件分别负责通信过程的一个步骤.这种模块化 ...
- 《Django By Example》第九章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag 注:哈哈哈,第九章终于来啦 ...
- javaList容器中容易忽略的知识点
在集合类框架中,List是使用比较多的一种 List |---Arraylist 内部维护的是一个数组,查找快增删慢 |---LinkedList 底层是链表,增删快查询慢. |---Vctor线程安 ...
- Android Weekly Notes Issue #249
Android Weekly Issue #249 March 19th, 2017 Android Weekly Issue #249 本期内容包括: 一个设计的实现Demo讨论; Kotlin的C ...
- windows系统下安装composer
使用安装程序安装 这是将 Composer 安装在你机器上的最简单的方法. 下载并且运行 Composer-Setup.exe,它将安装最新版本的 Composer 安装完成后,将composer的b ...
- 检测Windows程序的内存和资源泄漏之原生语言环境
最近接连收到大客户的反馈,我们开发的一个软件,姑且称之为App-E吧,在项目规模特别大的情况下,长时间使用会逐渐耗尽内存,运行越来越缓慢,软件最终崩溃.由于App-E是使用混合语言开发的,主界面使用C ...