web自动化进阶

一、什么是框架

1.框架

框架(framework)是一个框子 -- 指其约束性,也是一个架子 -- 指其支撑性,是一个基本概念上的结构,用于去解决或者处理复杂的问题。

框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。

框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。

2.为什么使用框架?

1)自己从头实现太复杂。
2)使用框架能够更专注于业务逻辑,加速开发速度。
3)框架的使用能够处理更多细节问题。
4)使用人数多,稳定性,扩展性好</pre>

3.selenium工作原理

1)运行脚本
2)启动驱动器
3)驱动器打开浏览器
4)访问网页</pre>

4.selenium环境搭建

1)python3.7
2)Firefox35(大于43)
3)selenium2框架
稳定版本2.48.0:pip install selenium==2.48.0
4)浏览器驱动</pre>

5.selenium对浏览器操作

1)库的导入
from selenium import webdriver</pre>

2)创建浏览器对象

driver = webdriver.xxx():必须大写且加括号

使用dir(driver)查看方法

3)浏览器尺寸相关操作

maximize_window() # 最大化
get_window_size() # 获取浏览器尺寸,打印查看
set_window_size() # 设置浏览器尺寸,400*400</pre>

4)浏览器位置相关操作

get_window_position() # 获取浏览器位置
set_window_position(x,y) # 设置浏览器位置</pre>

5)浏览器的关闭操作

close() # 关闭当前标签/窗口
quit() # 关闭所有标签/窗口</pre>

6)页面请求操作

driver.get(url) # 请求某个url对应的响应
refresh() # 刷新页面操作
back() # 回退到之前的页面
forward() # 前进到之后的页面</pre>

6.selenium获取断言信息
  1. 什么是断言

断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。

  1. 获取断言信息的操作
  • current_url 获取当前访问页面url

  • title获取当前浏览器标题

  • page_source获取网页源码

  • get_screenshot_as_png() 保存图片

  • get_screenshot_as_file(file) 直接保存

7.selenium八大元素

八大元素定位

第一种 id

kw = driver.find_element_by_id('kw')
kw.send_keys('坦克')
kw = driver.find_element(By.ID,'kw')

第二种 标签名字

kw = driver.find_element_by_name('wd')
kw = driver.find_element(By.NAME,'wd')

第三种 class

kw = driver.find_element_by_class_name('s_ipt')
kw = driver.find_element(By.CLASS_NAME,'s_ipt')

第四种 Xpath

kw = driver.find_element_by_xpath(".//[@id='kw']")
kw = driver.find_element(By.XPATH,".//
[@id='kw']")

第五种 css class

kw = driver.find_element_by_css_selector('#kw')
kw = driver.find_element(By.CSS_SELECTOR,'#kw')

第六种 test

kw = driver.find_element_by_link_text('新闻')
kw = driver.find_element(By.LINK_TEXT,'新闻')

第七种 类似于模糊查询

kw = driver.find_element_by_partial_link_text('新')
kw = driver.find_element(By.PARTIAL_LINK_TEXT,'新')

第八种:标签名定位,必须得保证一个这种名字的标签,使用下面这个搜索

kw = driver.find_element_by_tag_name('input')</pre>

8.元素的操作

对元素的相关操作,一般要先获取到元素,在调用相关方法

element = driver.find_element_by_xxx(value)

1)点击和输入

点击操作→element.click()

清空、输入操作:

element.clear()→清空输入框 element.send_keys(data)→输入数据

2)提交操作

element.submit()

9.多标签之间的切换

1)获取所有窗口的句柄

handles = driver.window_handlers

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

driver.switch_to_window(handles[n])→方法过时了

driver.switch_to.window(handles[n])

10.多表单切换

在网页中,表单嵌套是很常见的情况,尤其是在登录的场景

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)

11.弹出框操作

1)进入到弹出框中:driver.switch_to.alert

2)接收警告:accept()

3)解散警告:dismiss()

4)发送文本到警告框:send_keys(data) 用法:driver.switch_to.alert.accept()

12.下拉框
13.鼠标和键盘操作

1)鼠标操作

  • 导入动作链类,动作链可以存储鼠标的动作,并一起执行

from selenium.webdriver import ActionChains
ActionChains(driver)

  • 鼠标右击

el = driver.find_element_by_xxx(value)
context_click(el)

对el执行右击

  • 执行ActionChains中存储的所有操作

perform()

  • 常用鼠标动作

ActionChains(driver).context_click(ele).perform() # 点击鼠标右键
ActionChains(driver). double_click(ele).perform() # 点击鼠标左键
ActionChains(driver).move_to_element(el).perform() # 鼠标悬停

2)键盘操作

键盘操作使用的是keys类,一般配合snd_keys使用

  • 导入

from selenium.webdriver.common.keys import Keys

  • 常用键盘操作

send_keys(Keys.BACK_SPACE) # 删除键(BackSpace)
send_keys(Keys.SPACE) # 空格键(Space)
send_keys(Keys.TAB) # 制表键(Tab)
send_keys(Keys.ESCAPE) # 回退键(Esc)
send_keys(Keys.ENTER) # 回车键(Enter)
send_keys(Keys.CONTROL,‘a’) # 全选(Ctrl+A)
send_keys(Keys.CONTROL,‘a’) # 全选(Ctrl+A)
send_keys(Keys.CONTROL,‘x’) # 剪切(Ctrl+X)
send_keys(Keys.CONTROL,‘v’) # 粘贴(Ctrl+V)
send_keys(Keys.F1) # 键盘 F1
send_keys(Keys.F12) # 键盘 F12

14.浏览器等待

1)为什么要进行等待?

  1. 网速慢

  2. 网站内容过多

  3. 如果不进行等待而直接定位元素,可能会抛出异常

2)selenium中等待的分类

  1. 显示等待

    显示等待是根据条件进行等待,等待条件出现

from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)

  1. 隐示等待

    隐示等待是根据事件进行等待,等待特定事件

driver.implicitly_wait(n)

15.IDE功能介绍

[图片上传失败...(image-80f956-1646306144796)]

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

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

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

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

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

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

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

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

  9. 案例集列表。

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

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

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

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

16.代码案例
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容