WebUI自动化测试

主要是selenium+pytest+POM

一、selenium

初始框架:

# 导入模块
from selenium import webdriver
from time import sleep

# 实例化浏览器对象
driver = webdriver.Chrome()

# 打开网页
driver.get('***.html')

# 展示效果
sleep(3)
# 关闭页面
driver.quit()

元素定位

# 使用id定位
element = driver.find_element_by_id('xx')
# 使用name定位
element = driver.find_element_by_name('xx')
# class_name根据元素class属性定位元素
element = driver.find_element_by_class_name('xx')
# tag_name:标签名
element = driver.find_element_by_tag_name('xx')
# 使用link_text定位访问超链接
l = driver.find_element_by_link_text('xx')
# 只需要超链接的部分文本信息

pl = driver.find_element_by_partial_link_text('xx')

除了id唯一外,其他都有重复的可能,所以其他要保证唯一性

元素信息

element.size, element.text, element.get_attribute('class'), element.is_displayed(),element.is_enabled(), element.is_selected()

元素操作方法

element.send_keys('xx')、element.click()

driver操作

driver.back()
driver.forward()
driver.refresh()
driver.close()
driver.quit()
driver.title
driver.current_url

定位一组元素

usernames = driver.find_elements_by_name('xxx')
for username in usernames:
    username.send_keys('xxx')
    sleep(3)

XPath

# XPath
# 路径:定位
# 利用元素属性:定位
# 属性与逻辑结合:定位
# 层级与属性结合:定位
# 方法名:find_element_by_xpath(xpath)
# 绝对路径:从最外层元素到指定元素之间所有经过元素层级的路径,以/html开始
# 相对路径:匹配任意层级的元素,不限制元素的位置,以//开始
# 利用元素属性策略
# 语法://标签名[@属性名='属性值']
# 语法: //*[@属性名='属性值' and @属性名='属性值']
# 层级与属性结合
# //*[@id='p1']/input

# 延伸://*[text()="xxx"] 文本内容是xxx的元素
# //*[contains(@attribute,'xxx')] 属性中含有x
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值