一、安装
1.前提
(1)mac系统自带python2.7,如果你要的是python3版本,需要自己下载安装。
(2)安装好IDE:pycharm
(3)安装好chrome浏览器
(4)下载chromedriver : http://npm.taobao.org/mirrors/chromedriver/2.36/
在命令行输入 open /usr/local/bin 打开文件夹,把驱动放入即可
2.安装selenium操作:
打开终端,输入:sudo pip3 install selenium(python2版本输入sudo pip install selenium)
安装完成后,以下命令可运行成功
如果提示sudo: pip: command not found,说明缺少pip,需要自行安装pip.
安装pip:打开终端,输入sudo pip3 install numpy(python2版本输入sudo pip install numpy)
卸载pip:打开终端,输入sudo pip3 uninstall numpy
3.pycharm中selenium环境配置
下载自己需要的版本就好
成功运行以上代码,则环境配置成功
3.安装火狐浏览器驱动
详见这里
二、介绍
1.是什么
Selenium是ThroughtWorks公司一个强大的开源Web功能测试工具系列,本系列现在主要包括以下4款:
1.Selenium Core:支持DHTML的测试案例(效果类似数据驱动测试),它是Selenium IDE和Selenium RC的引擎。
2.Selenium IDE:FireFox的一个插件,支持脚本录制。
3.Selenium RC:Selenium Remote Control。后续的系列文章我会主要针对Selenium RC展开介绍。
4.Selenium Grid:允许同时并行地、在不同的环境上运行多个测试任务,极大地加快Web应用的功能测试。
Selenium是ThroughtWorks公司一个强大的开源Web功能测试工具系列,支持多平台、多浏览器、多语言去实现 自动化测试,Selenium2将浏览器原生的API封装成WebDriver API,可以直接操作浏览器页面里的元素,甚至操作 浏览器本身(截屏,窗口大小,启动,关闭,安装插件,配置证书之类的),所以就像真正的用户在操作一样。
2.自动化测试工具和自动化测试框架的区别
自动化测试框架一般可以分为两个层次,上层是管理整个自动化测试的开发,执行以及维护,在比较庞大的项目
中,它体现重要的作用,它可以管理整个自动测试,包括自动化测试用例执行的次序、测试脚本的维护、以及集中
管理测试用例、测试报告和测试任务等。下层主要是测试脚本的开发,充分的使用相关的测试工具,构建测试驱动,并完成测试业务逻辑。
三、使用
1.slenium做回归测试和不同浏览器上的兼容性测试都可以用
webdrive就是一个驱动,让浏览器做脚本命令的一些事情
2.selenium IDE 安装及使用
- 安装:火狐浏览器点击右上角,附加组件,在搜索框搜索下载即可
- 使用
1.点击
2.选择Record a new test in a new project
3.按提示填写好,开始录制
4.录制结束,点击文件然后export导出
5.修改代码(后续会写到框架)
6.运行
3.webdriver常用的API
1.了解:一个简单的脚本
# coding = utf-8 可加可不加,开发人员喜欢加一下,防止乱码
from selenium import webdriver #要想使用selenium 的webdriver 里的函数,首先把包导进来
import time
browser = webdriver.Firefox() #我们需要操控哪个浏览器呢?Chrome ,当然也可以换成Ie 或Firefox。browser 可以随便取,但后面要用它操纵
各种函数执行。
time.sleep(3)
browser.get("http://www.baidu.com")
time.sleep(3)
browser.find_element_by_id("kw").send_keys("selenium") #一个控件有若干属性id 、name、(也可以用其它方式定位),百度输入框的id 叫kw ,我要在输入框里输入selenium 。
time.sleep(3)
browser.find_element_by_id("su").click() #搜索的按钮的id 叫su ,我需要点一下按钮( click() )。
browser.quit() #退出并关闭窗口的每一个相关的驱动程序,
browser.close() #关闭当前窗口。
#close方法关闭当前的浏览器窗口,quit方法不仅关闭窗口,还会彻底的退出webdriver,释放与driver server之间的连接。所以简单来说quit是更加彻底的close,quit会更好的释放资源
2.元素定位
对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。一个对象就是一个人一样,他
会有各种的特征(属性),如比我们可以通过一个人的身份证号,姓名,或者他住在哪个街道、楼层、门牌找到这
个人。
那么一个对象也有类似的属性,我们可以通过这个属性找到这对象。
注意:不管用那种方式,必须保证页面上该属性的唯一性
webdriver 提供了一系列的对象定位方法,常用的有以下几种:
id
name
class name
link text
partial link text
tag name
xpath
css selector
- 打开浏览器右击,检查元素,就可以看到对应ID、name(不是每个元素都有name,没有时用其他定位)、class(为多位时无法定位)
path和css定位,点击标签右击,检查元素,然后在右击,copy选择不同方式即可。
id 和name 定位:chrome的F12,找到了百度输入框的属性信息
tag name 和class name 定位:从上面的百度输入框的属性信息中,我们看到,不单单只有id 和name 两个属性, 比如class 和tag name(标签
名)
CSS 定位:CSS的获取可以用chrome的F12开发者模式中Element-右键-copy-copy selector来获取
link text定位:有时候不是一个输入框也不是一个按钮,而是一个文字链接,我们可以通过link(打开元素信息,发现前面有a)
XPath 定位:XPATH的获取可以用chrome的F12开发者模式中Element-右键-copy-copy xpath来获取(“//*[@唯一的一个属性=‘’]”) - 首选ID,没有ID时用xpath绝对可以定位
我们可以看到,一个百度的输入框,可以用这么用种方式去定位。
#coding=utf-8
from selenium import webdriver
import time
browser = webdriver.Chrome()
browser.get("http://www.baidu.com")
#########百度输入框的定位方式##########
#通过id 方式定位
browser.find_element_by_id("kw").send_keys("selenium")
#通过name 方式定位
browser.find_element_by_name("wd").send_keys("selenium")
#通过tag name 方式定位
browser.find_element_by_tag_name("input").send_keys("selenium") 不能成功,因为input太多了不唯一。 #通过class name 方式定位
browser.find_element_by_class_name("s_ipt").send_keys("selenium")
#通过CSS 方式定位
browser.find_element_by_css_selector("#kw").send_keys("selenium")
#通过xphan 方式定位
browser.find_element_by_xpath("//*[@id='kw']").send_keys("selenium")
############################################
browser.find_element_by_id("su").click()
time.sleep(3)
browser.quit