Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)

目录

一、Selenium自动化测试框架

1.1什么是框架?

1.2为什么使用框架?

1.3Selenium-webdriver工作原理

1.4selenium环境搭建(详情查阅讲义)

1.5什么是Selenium-IDE?

1.6IDE功能简介

二、安装Selenium

2.1.环境安装 (先下载火狐浏览器,在火狐里使用)

2.2配置selenium_ide-2.9.1-fx.xpi

打开火狐浏览器点击打开菜单---点击附加组件

2.3点击从文件安装附加组件

2.4勾选这个selenium组件并打开

2.5上传完组件要重启浏览器!!!!!然后点击打开菜单---附加组件---扩展

三、在Pycharm的py文件中导入from selenium import webdriver

四、Selenium API基础

4.1获取断言信息

4.2元素的定位

4.2.1元素定位方法的分类(调用方式):

4.2.2元素定位方法的分类(按定位方式):

4.2.3八种定位方式的示例:

五、元素的操作

六、多标签之间的切换

6.1 场景:

6.2操作

七、多表单切换

7.1什么是多表单?

7.2处理方法

八、案例Demo1:

1.打开百度

2.然后搜索123

3.然后打开hao123网址

4.并关闭

九、某宝登录案例Demo2:

十、案例Demo3:

十一、案例Demo4

1.搜索设置

2.保存50条

3.保存搜索设置



一、Selenium自动化测试框架

1.1什么是框架?

框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。

**是一个基本概念上的结构,用于去解决或者处理复杂的问题。 **

框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;

**另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。 **

框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。

简单说就是使用别人搭好的舞台,你来做表演。

1.2为什么使用框架?

**1)自己从头实现太复杂 **

**2)使用框架能够更专注于业务逻辑,加快开发速度 **

**3)框架的使用能够处理更多细节问题 **

4)使用人数多,稳定性,扩展性好

1.3Selenium-webdriver工作原理

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第1张图片
image

1.4selenium环境搭建(详情查阅讲义)

**1.材料: **

**1)python3.7 **

**2)Firefox35(大于43) **

**3)selenium2框架 稳定版 2.48.0 安装指令:(pip install selenium==2.48.0) **

**4)浏览器驱动 chrome ie **

1.5什么是Selenium-IDE?

Selenium的IDE(集成开发环境)

是一个易于使用的Firefox插件,用于开发Selenium测试案例。它提供了一个图形用户界面,用于记录使用Firefox浏览器,用来学习和使用Selenium用户操作,但它只能用于只用Firefox浏览器不支持其它浏览器。

1.6IDE功能简介

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

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

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

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

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

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

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

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

9.案例集列表。

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

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

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

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

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第2张图片
image

二、安装Selenium

2.1.环境安装 (先下载火狐浏览器,在火狐里使用)

firefox官网: http://www.firefox.com.cn/

2.2配置selenium_ide-2.9.1-fx.xpi

打开火狐浏览器点击打开菜单---点击附加组件

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第3张图片
image

2.3点击从文件安装附加组件

image

2.4勾选这个selenium组件并打开

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第4张图片
image

2.5上传完组件要重启浏览器!!!!!然后点击打开菜单---附加组件---扩展

image

三、在Pycharm的py文件中导入from selenium import webdriver

from selenium import  webdriver

**1.浏览器驱动对象 **

**1)库的导入 **

**from selenium import webdriver **

**2)创建浏览器对象 **

**driver = webdriver.xxx() **

**使用dir(driver)查看方法 **

**3)浏览器尺寸相关操作 **

**maximize_window() 最大化 **

**get_window_size() 获取浏览器尺寸 **

**set_window_size() 设置浏览器尺寸 **

**3)浏览器位置相关操作 **

**get_window_position() 获取浏览器位置 **

**set_window_position(x,y) 设置浏览器位置 **

**注:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。 **

**4)浏览器的关闭操作 **

**close() 关闭当前标签/窗口 **

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

**4)页面请求操作 **

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

**refresh() 刷新页面操作 **

**back() 回退到之前的页面 **

forward() 前进到之后的页面

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第5张图片
image

image

四、Selenium API基础

4.1获取断言信息

**什么是断言? **

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

**1)获取断言信息的操作 **

**current_url 获取当前访问页面url **

**title 获取当前浏览器标题 **

**get_screenshot_as_png() 保存图片 **

**get_screenshot_as_file(file) 直接保存 **

page_source 网页源码

4.2元素的定位

4.2.1**元素定位方法的分类(调用方式): **

**1.直接调用型(推荐方式) **

**driver.find_element_by_xxx(value) **

**2.使用By类型(需要导入By) **

**from selenium.webdriver.common.by import By **

**driver.find_element(By.xxx,value) **

4.2.2元素定位方法的分类(按定位方式):

image

4.2.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)

五、元素的操作

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

**element = driver.find_element_by_xxx(value) **

**1)点击和输入 **

**点击操作 **

**element.click() 清空/输入操作(只能操作可以输入文本的元素) **

**element.clear() 清空输入框 **

**element.send_keys(data) 输入数据 **

**2)提交操作 **

**element.submit() **

**案例: 1.打开百度搜索 2.搜索关键字 selenium 3.清空 4.搜索python **

六、多标签之间的切换

6.1 场景:

有的时候点击一个链接,新页面并非由当前页面跳转过去,而是新开一个页面打开,这种情况下,计算机需要识别多标签或窗口的情况。

6.2操作

**1)获取所有窗口的句柄 **

**handles = driver.window_handlers() **

**调用该方法会得到一个列表,在selenium运行过程中的每一个窗口都有一个对应的值存放在里面。 **

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

**driver.switch_to_window(handles[n]) **

**driver.switch_to.window(handles[n]) 通过窗口句柄激活进入某一窗口 **

七、多表单切换

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

7.1什么是多表单?

**实际上就是使用iframe/frame,引用了其他页面的链接,真正的页面数据并没有出现在当前源码中,但是在浏览器中我们看到,简单理解可以使页面中开了一个窗口显示另一个页面 **

7.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) **

八、案例Demo1:

1.打开百度

2.然后搜索123

3.然后打开hao123网址

4.并关闭

from selenium import webdriverimport timewebdriver = webdriver.Firefox()webdriver.get("http://www.baidu.com")webdriver.find_element_by_id("kw").click()webdriver.find_element_by_id("kw").send_keys("hao123")webdriver.find_element_by_id("su").click()time.sleep(2)webdriver.find_element_by_link_text(u"hao123_上网从这里开始").click()webdriver.switch_to.window(webdriver.window_handles[1])webdriver.close()
Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第6张图片
image

九、某宝登录案例Demo2:

from selenium import webdriverimport time driver = webdriver.Firefox()url = 'https://login.taobao.com/member/login.jhtml?redirectURL=http%3A%2F%2Fi.taobao.com%2Fuser%2FbaseInfoSet.htm%3Fspm%3Da1z02.1.972272805.d4912005.7iMnyb'driver.get(url)time.sleep(2)driver.find_element_by_id("fm-login-id").click()driver.find_element_by_id("fm-login-id").clear()driver.find_element_by_id("fm-login-id").send_keys("[email protected]")driver.find_element_by_id("fm-login-password").click()driver.find_element_by_id("fm-login-password").clear()driver.find_element_by_id("fm-login-password").send_keys("hhhhhhh")time.sleep(2)driver.find_element_by_class_name("fm-btn").click()
image
Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第7张图片
image

十、案例Demo3:

1:使用游览器登录http://www.baidu.com

2:搜索淘宝官网

3:登录用户名和密码

4:搜索商品(手机,电脑,,,,),给定约束条件(价格,包邮,发货地址。。。)

5:将商品添加到购物车

6:在购物中游览该商品

**7:根据自己的喜好进行下面的操作 **

from selenium import webdriver
import time

# 1:使用游览器登录http://www.baidu.com
webdriver = webdriver.Firefox()
# url ="Http://www.baidu.com"
url ="https://www.taobao.com/"
# url ="https://s.taobao.com/search?q=电脑&imgfile=&commend=all&ssid=s5-e&search_type=item&sourceId=tb.index&spm=&ie=utf8&initiative_id=tbindexz_20170306"
webdriver.get(url)
time.sleep(2)
# 2:搜索淘宝官网
# webdriver.find_element_by_id("kw").send_keys("淘宝网官网")
# webdriver.find_element_by_id("su").click()
# time.sleep(2)
# 进入淘宝网官网
# webdriver.find_element_by_link_text("淘宝网 - 淘!我喜欢").click()
# time.sleep(2)
# 搜索框===========================================================================
webdriver.find_element_by_class_name("search-combobox").click()
time.sleep(2)
# #输入框输入电脑
webdriver.find_element_by_id("q").send_keys("电脑")
time.sleep(2)
# #点击搜索按钮
webdriver.find_element_by_class_name("search-button").click()
time.sleep(2)
# #淘宝登录框
webdriver.find_element_by_id("fm-login-id").click()
webdriver.find_element_by_id("fm-login-id").clear()
webdriver.find_element_by_id("fm-login-id").send_keys("[email protected]")#改成自己的用户名
webdriver.find_element_by_id("fm-login-password").click()
webdriver.find_element_by_id("fm-login-password").clear()
webdriver.find_element_by_id("fm-login-password").send_keys("改成自己的密码..")#记得改密码
time.sleep(2)
webdriver.find_element_by_class_name("fm-btn").click()
time.sleep(2)
webdriver.find_element_by_css_selector('#J_Itemlist_Pic_604170141439').click()
time.sleep(2)

#跳转页面
webdriver.switch_to.window(webdriver.window_handles[1])
print(webdriver.window_handles[1])
#数量
webdriver.find_element_by_xpath('//span[@class="mui-amount-increase"]').click()
time.sleep(2)
#服务
webdriver.find_element_by_xpath('//ul[@class="tm-clear serviceList"]/li').click()
time.sleep(2)
#花呗
webdriver.find_element_by_xpath('//ul[@class="tm-clear"]/li').click()
time.sleep(2)
#加入购物车
webdriver.find_element_by_xpath('//a[@id="J_LinkBasket"]').click()
time.sleep(2)
#添加到购物车
webdriver.find_element_by_xpath('//a[@class="sn-cart-link"]').click()
time.sleep(2)
#跳转页面
# webdriver.switch_to.window(webdriver.window_handles[2])
# print(webdriver.window_handles[2])
#查看购物车
webdriver.find_element_by_xpath('//div[@id="J_OrderHolder_s_3429520129_1"]').click()
time.sleep(2)
webdriver.find_element_by_xpath('//label[@for="J_CheckShop_s_3429520129_1"]').click()
time.sleep(2)
#删除
webdriver.find_element_by_xpath('//a[@class="J_Del J_MakePoint"]').click()
time.sleep(2)
#弹框确定删除
webdriver.find_element_by_xpath('//a[@class="dialog-btn J_DialogConfirmBtn"]').click()
time.sleep(2)

#包邮,,发货地址=======================================================
# webdriver.find_element_by_xpath('//span[@class="icon icon-btn-check-big"]').click()
# # webdriver.find_element_by_xpath('.//*[@id="J_relative"]/div[2]/div[1]/div/div[1]/a[2]/span[1]').click()
# time.sleep(2)
#价格
# webdriver.find_element_by_xpath('//input[@class="J_SortbarPriceInput input"]').send_keys("5000")
# time.sleep(2)
# webdriver.find_element_by_xpath('.//*[@id="J_relative"]/div[1]/div/div[1]/div[1]/div/ul/li[3]/input').send_keys("10000")
# time.sleep(2)
# webdriver.find_element_by_xpath('//button[@class="J_SortbarPriceSubmit btn"]').click()
# time.sleep(2)
# webdriver.find_element_by_xpath('//a[@id="J_Itemlist_TLink_608535005996"]').click()
# time.sleep(2)
# webdriver.find_element_by_xpath('//li[@date-value="1627207:9214316079"]').click()
# time.sleep(2)
# webdriver.find_element_by_xpath('//span[@class="mui-amount-increase"]').click()
# time.sleep(2)
# webdriver.find_element_by_xpath('.//*[@id="J_Progressive"]/dd/ul/li[1]/a').click()
# time.sleep(2)
# webdriver.find_element_by_xpath('//a[@id="J_LinkBasket"]').click()
# time.sleep(2)
image.gif

十一、案例Demo4

1.搜索设置

2.保存50条

3.保存搜索设置

from selenium import webdriverimport time webdriver = webdriver.Firefox()url ="Http://www.baidu.com"webdriver.get(url)webdriver.find_element_by_id("s-usersetting-top").click()time.sleep(2)webdriver.find_element_by_class_name("setpref").click()time.sleep(2)webdriver.find_element_by_id("nr_3").click()time.sleep(2)webdriver.find_element_by_class_name("prefpanelgo").click()

Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例)_第8张图片
image

你可能感兴趣的:(Selenium自动化测试框架基础学习(元素表单操作)(Selenium安装操作)(自动化web案例))