Selenium自动化测试第一天(上)
2023-09-14 09:11:05 时间
Selenium是一款浏览器自动化框架,Webdriver是其核心,同过Webdriver将自动化脚本转化为浏览器操作指令。
一般操作逻辑为:
- 打开网页
- 定位页面元素(链接,按钮,输入框等)
- 操作页面元素(点击,输入)
- 定位并操作下一个页面元素
Webdriver的工作原理
Webdriver会在本地启动一套WebService服务并绑定一个动态端口,脚本运行时通过selenium将请求发送到Webdriver服务端,然后经过不同的浏览器驱动,转换为浏览器指令。
浏览器基本操作
- 方法
- get():打开网页
- forward():前进
- back(): 后退
- refresh(): 刷新页面
- maximize_window():最大化窗口
- set_window_size():设置窗口大小
- close(): 关闭当前页面
- quit(): 退出浏览器
- 属性
- title:标题
- current_url:当前网址
- page_source:网页源代码
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome() # 打开Chrome
# browser = webdriver.Firefox() # 打开Firefox
# browser = webdriver.Edge() # 打开Edge
# browser = webdriver.Ie() # 打开Ie
browser.get("http://www.baidu.com") # 打开网页
browser.maximize_window() # 窗口最大化
print(browser.title) # 当前页面的标题
print(browser.current_url) # 当前url
print(browser.page_source) # 网页源代码
sleep(1)
browser.get("http://115.28.108.130/control.html")
sleep(1)
browser.back() # 后退
sleep(1)
browser.forward() # 前进
browser.refresh() # 刷新
sleep(3)
browser.quit() # 退出
页面元素定位
8种基本定位方式
- 通过id定位: find_element_by_id()
- 通过name定位: find_element_by_name()
- 通过class定位: find_element_by_class_name()
- 通过tag定位: find_element_by_tag_name()
- 通过link定位: find_element_by_link_text()
- 通过partial link定位: find_element_by_partial_link_text()
- 通过xpath定位: find_element_by_xpath()
- 通过css定位: find_element_by_css_selector()
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
browser.find_element_by_id("accountID").send_keys("hello")
browser.find_element_by_name("password").send_keys("123456")
browser.find_element_by_class_name("stuname").send_keys("class")
div = browser.find_element_by_tag_name("div") # 重复较多,只能定位到第一个,不推荐使用
print(div.get_attribute("id"))
# browser.find_element_by_link_text("百度首页走起~").click()
link = browser.find_element_by_link_text("百度首页走起~")
print(link.text)
link.click()
sleep(1)
browser.back()
browser.find_element_by_partial_link_text("百度首页").click()
browser.back()
label2 = browserb.find_element_by_xpath('/html/body/div[4]/label[2]')
print(label2.text)
summer = browser.find_element_by_xpath('//input[@id="u"][@value="summer"]')
summer.click()
browser.find_element_by_css_selector('#input > input').send_keys("1111")
browser.find_element_by_css_selector("#accountID").send_keys("张三")
补充:用By定位元素:
- find_element(By.ID,"")
- find_element(By.NAME, "")
- find_element(By.CLASS_NAME, "")
- find_element(By.TAG_NAME, "")
- find_element(By.LINK_TEXT, "")
- find_element(By.PARTIAL_LINK_TEXT, "")
- find_element(By.XPATH, "")
- find_element(By.CSS_SELECTOR, "")
定位一组元素
当元素拥有相同的id/name/class_name/tag_name等时,可以定位到所有的元素,然后按顺序取得具体某个元素,这里使用find_elements_by_***
,注意对一个s
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
l = browser.find_elements_by_id("u")
for i in l:
i.click()
l[2].click()
lables = browser.find_elements_by_tag_name("label")
print(lables[2].text)
分层定位
当一个元素不好定位时,可以先定位到容易定位的父级/祖先级元素,然后使用父级/祖先级元素继续定位,如:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
fardiv = browser.find_element_by_class_name("fathdiv") # 先定位到父级元素
labels = fardiv.find_elements_by_tag_name("label") # 使用父级元素向下定位
print(labels[2].text)
页面元素操作
- link 链接
- click()
- input 输入框
- send_keys(): 输入
- clear(): 清空输入框
- get_attribute("value"): 获取输入框的值
- button 按钮
- click():
- isEnabled(): 是否可用
- submit():type=submit的按钮可以使用submit()同click()用于提交表单
- radio/checkbox 单选/复选框
- click(): 定位到选框可直接点击
- is_displayed(): 是否展示
- is_selected(): 是否选中状态
- select 下拉框(需要用Select)
- select_by_index(): 按索引选择选项
- select_by_value(): 按value值选择选项
- select_by_visiable_text(): 按选项名选择选项
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
area = Select(browser.find_element_by_id("areaID"))
area.select_by_visible_text("上海")
sleep(1)
area.select_by_index(1)
sleep(1)
area.select_by_value("1")
实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
如果对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。
如有不懂还要咨询下方小卡片,博主也希望和志同道合的测试人员一起学习进步
在适当的年龄,选择适当的岗位,尽量去发挥好自己的优势。
我的自动化测试开发之路,一路走来都离不每个阶段的计划,因为自己喜欢规划和总结,
测试开发视频教程、学习笔记领取传送门!!!
相关文章
- 我所知道的自动化测试模型
- 自动化测试与RPA的区别总结
- 小白学 Python 爬虫(28):自动化测试框架 Selenium 从入门到放弃(下)
- Python+selenium自动化测试基础和元素定位
- 〖Python WEB 自动化测试实战篇⑥〗- selenium元素定位之find-elements
- pytest接口自动化测试框架 | parametrize源码解析
- 从第1个脚本到全栈自动化测试工程师,那些吊死在一家公司呆了 10 年的程序员,最后都怎么样了?
- 手工测试对比自动化测试
- 来了解2020自动化测试岗位需求的7项必备技能(更新版)
- 那么多优秀的自动化测试工具,而你只知道Selenium?(工具对应的测试)
- Selenium自动化测试框架中使用Cookies绕过登录
- Selenium自动化测试-设置元素等待
- Selenium自动化测试-7.获取元素属性信息
- App自动化测试——定位工具和元素定位策略
- Selenium自动化测试——巡检脚本开发(上)
- Selenium Page Object 自动化测试框架-Page Object设计
- 【2023最新教程】5分钟学会接口自动化测试框架(超easy)
- 【2023最新教程】从0到1搭建pytest接口自动化测试框架(建议收藏)
- 【进阶自动化第一步】自动化测试基础(超详细~)
- 30天进阶Selenium3自动化测试(4):安装Selenium
- 涨薪5k!100多天从功能测试进阶自动化测试,我整理的超全学习指南!
- 2021年软件测试必看的2大知识点:如何转自动化测试?学习软件测试好还是开发好?
- selenium自动化爬虫测试
- 爬虫学习(15):selenium自动化测试(四):截屏、弹出框和下拉框
- Selenium自动化测试——巡检脚本开发(中)
- Selenium自动化测试——Xpath定位
- Selenium自动化测试——巡检脚本开发(下)