Selenium自动化测试框架—简单了解

  • Selenium自动化测试框架
  • Selenium IDE
  • Selenium API基础
  • Selenium API高级
  • 案例


Selenium自动化测试框架

  1. 什么是框架?
    框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。是一个基本概念上的结构,用于去解决或者处理复杂的问题。
    框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。
    框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。
  2. 为什么使用框架?
    1)自己从头实现太复杂
    2)使用框架能够更专注于业务逻辑,加快开发速度
    3)框架的使用能够处理更多细节问题
    4)使用人数多,稳定性,扩展性好
  3. Selenium工作原理
    webdriver工作原理
  4. python selenium框架代码 selenium框架介绍_表单

Selenium IDE

IDE功能简介

1.文件:创建、打开和保存测试案例和测试案例集。编辑:复制、粘贴、删除、撤销和选择测试案例中的所有命令。Options : 用于设置seleniunm IDE。

2.用来填写被测网站的地址。

3.速度控制:控制案例的运行速度。

4.运行所有:运行一个测试案例集中的所有案例。

5.运行:运行当前选定的测试案例。

6.暂停/恢复:暂停和恢复测试案例执行。

7.单步:可以运行一个案例中的一行命令。

8.录制:点击之后,开始记录你对浏览器的操作。

9.案例集列表。

10.测试脚本;table标签:用表格形式展现命令及参数。source标签:用原始方式展现,默认是HTML语言格式,也可以用其他语言展示。

11.查看脚本运行通过/失败的个数。

12.当选中前命令对应参数。

13.日志/参考/UI元素/Rollup

python selenium框架代码 selenium框架介绍_Selenium_02

Selenium API基础

  1. 浏览器驱动对象
    1)库的导入
    from selenium import webdriver
    2)创建浏览器对象
driver = webdriver.xxx()

使用dir(driver)查看方法

3)浏览器尺寸相关操作

maximize_window()		最大化
 	
 get_window_size()		获取浏览器尺寸

 set_window_size()		设置浏览器尺寸

案例:
脚本操作打开一个测试浏览器,并调整其大小

from selenium import webdriver
import time
print("-------------")
# 创建一个驱动
drivers = webdriver.Chrome()
print(dir(drivers))
url = "http://www.baidu.com/"
# 获取url显示页面
drivers.get(url)
# 窗口最大化
# drivers.maximize_window()
# 获取窗口大小
# wind = drivers.get_window_size()
# print("窗口大小为:",wind)

python selenium框架代码 selenium框架介绍_Selenium_03

# 设置窗口大小
drivers.set_window_size(1000,1000)
weindd = drivers.get_window_size()
print("设置之后的窗口大小:",weindd)

python selenium框架代码 selenium框架介绍_python selenium框架代码_04

4)浏览器位置相关操作
			
	get_window_position()		获取浏览器位置

	set_window_position(x,y)		设置浏览器位置
	
注:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。
# 获取浏览器位置
pos = drivers.get_window_position()
print("浏览器的位置为:",pos)

python selenium框架代码 selenium框架介绍_Selenium_05

# 设置浏览器位置
drivers.set_window_position(50, 100)
pos = drivers.get_window_position()
print("更改后浏览器的位置:",pos)

python selenium框架代码 selenium框架介绍_python selenium框架代码_06

5)浏览器的关闭操作
	
	close()			关闭当前标签/窗口

	quit()			关闭所有标签/窗口

案例:
	打开浏览器,调整大小,调整位置,并关闭

6)页面请求操作

driver.get(url)				请求某个url对应的响应

refresh()				刷新页面操作

back()				回退到之前的页面

forward()				前进到之后的页面


案例:
		
1)访问 http://www.baidu.com
		
2)访问 https://zhuanlan.zhihu.com/
		
3)回退
  1. 获取断言信息
    1)什么是断言?
    断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。
    2)获取断言信息的操作
current_url				获取当前访问页面url

 title						获取当前浏览器标题

 get_screenshot_as_png()	保存图片

 get_screenshot_as_file(file)	直接保存
 
 page_source				网页源码
# 显示当前url
print("当前url:",drivers.current_url)
# 获取当前浏览器标题
print("当前标题:",drivers.title)
# 网页源码
print("页面源码:",drivers.page_source)

python selenium框架代码 selenium框架介绍_Selenium_07

  1. 元素的定位
    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)元素定位方法的分类(按定位方式):

python selenium框架代码 selenium框架介绍_表单_08


3)八种定位方式的示例:

1. driver.find_element_by_xpath(value)
		

	2. driver.find_element_by_css_selector(value)


	3. driver.find_element_by_id(value)
			

	4. driver.find_element_by_name(value)
		
			
	5. driver.find_element_by_class_name(value)
		

	6. driver.find_element_by_tag_name(value)
		案例:	必应搜索

	7. driver.find_element_by_link_text(value)
		

	8. driver.find_element_by_partial_link_text(value)

Selenium API高级

  1. 多标签之间的切换
    场景:有的时候点击一个链接,新页面并非由当前页面跳转过去,而是新开一个页面打开,这种情况下,计算机需要识别多标签或窗口的情况。
    1)获取所有窗口的句柄
handles = driver.window_handlers()
 调用该方法会得到一个列表,在selenium运行过程中的每一个窗口都有一个对应的值存放在里面。

2)通过窗口的句柄进入的窗口

driver.switch_to_window(handles[n])
 
 driver.switch_to.window(handles[n])

 通过窗口句柄激活进入某一窗口

案例:
58同城租房信息

  1. 多表单切换
    在网页中,表单嵌套是很常见的情况,尤其是在登录的场景
    1)什么是多表单?
    实际上就是使用iframe/frame,引用了其他页面的链接,真正的页面数据并没有出现在当前源码中,但是在浏览器中我们看到,简单理解可以使页面中开了一个窗口显示另一个页面
    2)处理方法
直接使用id值切换进表单
 	driver.switch_to.frame(value)/driver.switch_to_frame(value)

 定位到表单元素,再切换进入
 	el = driver.find_element_by_xxx(value)
 	driver.switch_to.frame(el)	/driver.switch_to_frame(el)

案例:
126网站登录

案例

# 淘宝添加裤子到购物车
# 里面可以看到我添加了很多睡眠2秒的代码,是为了防止在网络不好的情况下保证代码可以正常运行
from selenium import webdriver
import time
# 创建一个驱动
drivers = webdriver.Chrome()
# print(dir(drivers))
url = "http://www.baidu.com/"
# 获取url显示页面
drivers.get(url)
# 输入框输入淘宝
drivers.find_element_by_id("kw").send_keys("淘宝")
# 点击搜索淘宝
drivers.find_element_by_xpath(".//*[@id='su']").click()
time.sleep(2)
# 点击淘宝页面
drivers.find_element_by_partial_link_text('淘!我喜欢').click()
# 跳转到淘宝页面
drivers.switch_to.window(drivers.window_handles[1])
time.sleep(2)
# 点击到登录页面
drivers.find_element_by_partial_link_text('亲,请登录').click()
time.sleep(2)
# 输入账号
drivers.find_element_by_id("fm-login-id").send_keys("淘宝账号")
time.sleep(2)
# 输入密码
drivers.find_element_by_id("fm-login-password").send_keys("淘宝密码")
time.sleep(2)
# 点击登录
drivers.find_element_by_xpath(".//*[@id='login-form']/div[4]/button").click()
time.sleep(2)
# 请输入搜索文字
drivers.find_element_by_xpath(".//*[@id='q']").send_keys("裤子女宽松 直筒")
drivers.find_element_by_xpath(".//*[@id='J_TSearchForm']/div[1]/button").click()
time.sleep(2)
# 跳转到详情页面
drivers.find_element_by_xpath(".//*[@id='J_Itemlist_Pic_627649701626']").click()
# 跳转页面
drivers.switch_to.window(drivers.window_handles[2])
time.sleep(2)
# 选择裤子尺码
drivers.find_element_by_xpath(".//*[@id='J_DetailMeta']/div[1]/div[1]/div/div[4]/div/div/dl[1]/dd/ul/li[1]/a/span").click()
time.sleep(2)
# 裤子颜色
drivers.find_element_by_xpath(".//*[@id='J_DetailMeta']/div[1]/div[1]/div/div[4]/div/div/dl[2]/dd/ul/li/a/span").click()
time.sleep(2)
# 裤子数量
drivers.find_element_by_xpath(".//*[@id='J_Amount']/span[1]/span[1]/span[1]").click()
time.sleep(2)
# 加入购物车
drivers.find_element_by_xpath(".//*[@id='J_LinkBasket']").click()
time.sleep(2)
# 进入购物车查看
drivers.find_element_by_xpath(".//*[@id='sn-bd']/div/ul/li[3]/a").click()

python selenium框架代码 selenium框架介绍_python selenium框架代码_09