一、Selenium简介
1、定义:
Selenium是一款web应用的自动化测试工具,主要用于UI测试;
它的特点有如下几点:
1).支持多语言:java,python,ruby,PHP
2).多浏览器支持:IE、Chrome、Mozila-FireFox
3).开源,免费
4).多平台支持:windows、MAC、Linux
2、框架
框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。是一个基本概念上的结构,用于去解决或者处理复杂的问题。
框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。
框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。
3、使用框架原因
1)自己从头实现太复杂
2)使用框架能够更专注于业务逻辑,加快开发速度
3)框架的使用能够处理更多细节问题
4)使用人数多,稳定性,扩展性好
4、Selenium工作原理
5、selenium环境搭建
1)python3.7 2)Firefox35(大于43) 3)selenium2框架 稳定版 2.48.0 (pip install selenium==2.48.0)
4)浏览器驱动 chrome ie
二、Selenium IDE
1、Selenium-IDE:Selenium的IDE(集成开发环境)是一个易于使用的Firefox插件,用于开发Selenium测试案例。它提供了一个图形用户界面,用于记录使用Firefox浏览器,用来学习和使用Selenium用户操作,但它只能用于只用Firefox浏览器不支持其它浏览器。
2、IDE功能简介
1).文件:创建、打开和保存测试案例和测试案例集。编辑:复制、粘贴、删除、撤销和选择测试案例中的所有命令。Options : 用于设置seleniunm IDE。
2).用来填写被测网站的地址。
3).速度控制:控制案例的运行速度。
4).运行所有:运行一个测试案例集中的所有案例。
5).运行:运行当前选定的测试案例。
6).暂停/恢复:暂停和恢复测试案例执行。
7).单步:可以运行一个案例中的一行命令。
8).录制:点击之后,开始记录你对浏览器的操作。
9).案例集列表。
10).测试脚本;table标签:用表格形式展现命令及参数。source标签:用原始方式展现,默认是HTML语言格式,也可以用其他语言展示。
11).查看脚本运行通过/失败的个数。
12).当选中前命令对应参数。
13).日志/参考/UI元素/Rollup
三、Selenium IDE使用基础
1.浏览器驱动对象
1)库的导入 from selenium import webdriver
2)创建浏览器对象
driver = webdriver.xxx() 使用dir(driver)查看方法
案例:
from selenium import webdriver
driver=webdriver.Firefox()
# 使用dir(driver)查看方法
print(dir(driver))
结果:
3)浏览器尺寸相关操作
maximize_window() 最大化
get_window_size() 获取浏览器尺寸
set_window_size() 设置浏览器尺寸
案例:
from selenium import webdriver
driver=webdriver.Firefox()
# 最大
driver.maximize_window()
# 获取界面尺寸
print(driver.get_window_size())
# 设置尺寸
driver.set_window_size(200,100)
print(driver.get_window_size())
结果:
4)浏览器位置相关操作
get_window_position() 获取浏览器位置
set_window_position(x,y) 设置浏览器位置
案例:
from selenium import webdriver
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
print(driver.get_window_position())
driver.set_window_position(200,100)
print(driver.get_window_position())
结果:
注:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。
5)浏览器的关闭操作
close() 关闭当前标签/窗口
quit() 关闭所有标签/窗口
6)页面请求操作
driver.get(url) 请求某个url对应的响应
refresh() 刷新页面操作
back() 回退到之前的页面
forward() 前进到之后的页面
2、获取断言信息
定义:断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。
获取断言信息的操作
current_url 获取当前访问页面url
title 获取当前浏览器标题
get_screenshot_as_png() 保存图片
get_screenshot_as_file(file) 直接保存
page_source 网页源码
案例:
from selenium import webdriver
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# 获取当前访问页面url
print(driver.current_url)
# 获取当前浏览器标题
print(driver.title)
#保存图片
data=driver.get_screenshot_as_png()
with open("123.png","wb")as f:
f.write(data)
结果:
四、元素定位
1、元素定位方法的分类(调用方式):
1).直接调用型(推荐方式) driver.find_element_by_xxx(value)
2).使用By类型(需要导入By) from selenium.webdriver.common.by import By driver.find_element(By.xxx,value)
2、元素定位方法的分类(按定位方式):
3、八种定位方式的示例:
案例1:driver.find_element_by_xpath(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# xpath
ss=driver.find_element_by_xpath("//*[@id='kw']")
ss.send_keys("java")
或
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# xpath
ss=driver.find_element(By.XPATH,"//*[@id='kw']")
ss.send_keys("java")
结果:
案例2:driver.find_element_by_css_selector(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# css
ss=driver.find_element_by_css_selector("#kw")
ss.send_keys("sql")
或
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# css
ss=driver.find_element(By.CSS_SELECTOR,"#kw")
ss.send_keys("sql")
结果:
案例3:driver.find_element_by_id(value)
from selenium import webdriver
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# id
ss=driver.find_element_by_id("kw")
ss.send_keys("python")
或:
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# id
ss=driver.find_element(By.ID,"kw")
ss.send_keys("python")
结果:
案例4:driver.find_element_by_name(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# name
ss=driver.find_element_by_name("wd")
ss.send_keys("html")
或:
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# name
ss=driver.find_element(By.NAME,"wd")
ss.send_keys("html")
结果:
案例5: driver.find_element_by_class_name(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# 伪类名定位
ss=driver.find_element_by_class_name("s_ipt")
ss.send_keys("天天音乐")
或
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
driver.get(url)
# 伪类名定位
ss=driver.find_element(By.CLASS_NAME,"s_ipt")
ss.send_keys("天天音乐")
结果:
案例6:driver.find_element_by_tag_name(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
# url="https://www.baidu.com"
# 必应搜索
url="https://cn.bing.com/"
driver.get(url)
# 标签名定位
ss=driver.find_element_by_tag_name("input")
ss.send_keys("python")
或
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
# url="https://www.baidu.com"
# 必应搜索
url="https://cn.bing.com/"
driver.get(url)
# 标签名定位
ss=driver.find_element(By.TAG_NAME,"input")
ss.send_keys("python")
结果:
案例7:driver.find_element_by_link_text(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
# 必应搜索
# url="https://cn.bing.com/"
driver.get(url)
# 链接文本定位
ss=driver.find_element_by_link_text("hao123")
ss.click()
或
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
# 必应搜索
# url="https://cn.bing.com/"
driver.get(url)
# 链接文本定位
ss=driver.find_element(By.LINK_TEXT,"hao123")
ss.click()
结果:
案例8:driver.find_element_by_partial_link_text(value)
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
# 必应搜索
# url="https://cn.bing.com/"
driver.get(url)
# 部分链接文本
ss=driver.find_element_by_partial_link_text("hao")
ss.click()
或:
from selenium import webdriver
from selenium.webdriver.common.by import By
driver=webdriver.Firefox()
url="https://www.baidu.com"
# 必应搜索
# url="https://cn.bing.com/"
driver.get(url)
# 部分链接文本
ss=driver.find_element(By.PARTIAL_LINK_TEXT,"123")
ss.click()
结果:
五、元素的操作
1、对元素的相关操作,一般要先获取到元素,再调用相关方法
element = driver.find_element_by_xxx(value)
2、点击和输入
点击操作 element.click()
清空/输入操作(只能操作可以输入文本的元素)
element.clear() 清空输入框
element.send_keys(data) 输入数据