web自动化测试环境搭建+元素定位

web自动化测试

⾃动化测试理论

  • UI:User Interface(⽤户接⼝-⽤户界⾯),主要包括:app、web
  • ui⾃动化测试:使⽤⼯具或代码执⾏⽤例的过程
  • 什么样的项⽬适合做⾃动化:

1、需要回归测试项⽬(甲⽅⾃营项⽬、⾦融、电商)

2、需求变动不频繁:稳定的模块

3、项⽬周期⻓的项⽬:(甲⽅⾃营项⽬、6个⽉以上的外包)

⾃动化测试⼯具及环境

⼯具说明

  • QTP:商业、收费、⽀持UI
  • robot Framework:python扩展库、使⽤封装好的关键字驱动、半代码⽔平、
    ⽀持UI
  • selenium:开源、免费、主流 ⽀持UI

selenium介绍

环境搭建

pthon解释器+pycharm+selenium+浏览器+浏览器驱动

  • selenium
python 复制代码
pip install selenium
  • 浏览器驱动
python 复制代码
chrome: http://npm.taobao.org/mirrors/chromedriver/
提示:浏览器驱动⼤版本必须和浏览器版本⼀致。


下载链接: https://googlechromelabs.github.io/chrome-for-testing/

windows:

1、解压下载的驱动,获取到chromedriver.exe

2、将chromedriver.exe复制到python.exe所在⽬录即可(避免再次将chromedrver.exe

添加path变量)
mac:

1、解压下载的驱动,获取到chromedriver

2、将chromedriver复制到/usr/local/bin⽬录即可。

元素定位

元素定位⽅法

1、id

2、name

3、class

4、tag_name

5、link_text

6、partial_link_text

7、xpath

8、css

元素定位步骤

1、打开⾕歌浏览器(实例化)

2、输⼊url

3、找元素及操作

4、关闭浏览器

python 复制代码
from time import sleep
from selenium import webdriver
# 1、打开⾕歌浏览器(实例化浏览器对象)
driver = webdriver.Chrome()
# 2、输⼊url
driver.get("http://tpshop-test.itheima.net/Home/user/login.html")
# 3、找元素及操作
# 4、关闭浏览器
sleep(3)
driver.quit()

3.1 id定位

方法:driver.find_element(by=By.ID, value="id值")

前置:标签必须有id属性

输入方法:元素.send_keys("内容")

python 复制代码
from time import sleep

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

# 1、获取浏览器
driver = webdriver.Chrome()
# 2、打开url
driver.get("file:///D:/Chrome/%E6%B3%A8%E5%86%8CA.html")
# 3、查找操作元素
# 用户名 -> id ->driver.find_element_by_id("id")
# 元素.send_keys()输入方法
# driver.find_element_by_id("userA").send_keys("admin")
driver.find_element(by=By.ID, value="userA").send_keys("admin")

# # 密码
# driver.find_element_by_id("passwordA").send_keys("123456")
driver.find_element(by=By.ID, value="passwordA").send_keys("123456")


# 4、关闭浏览器
sleep(5)
driver.quit()

3.2 name定位

driver.find_element(by=By.NAME, value="name属性值")

前置: 标签必须有name属性

特点: 当前页面可以重复

提示: 由于name属性值可以重复,所以使用时需要查看是否为唯一。

python 复制代码
from time import sleep

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

# 1、获取浏览器
driver = webdriver.Chrome()
# 2、打开url
driver.get("file:///D:/Chrome/%E6%B3%A8%E5%86%8CA.html")
# 3、查找操作元素
# 用户名 -> name
# 元素.send_keys()输入方法
driver.find_element(by=By.NAME, value="userA").send_keys("admin")
# 密码
driver.find_element(by=By.NAME, value="passwordA").send_keys("123456")
# 电话 -> class
driver.find_element(by=By.CLASS_NAME, value="telA").send_keys("18611111111")
# driver.find_element_by_class_name("c3").send_keys("123@163.com")

# 4、关闭浏览器
sleep(3)
driver.quit()

说明:根据链接文本(a标签)进行定位

方法:driver.find_element(by=By.LINK_TEXT, value="链接文本")

特点:传入的链接文本必须全部匹配,不能模糊匹配。
需求:

打开注册A.html页面,完成以下操作

1).使用link_text定位(访问 网易 网站)超链接,并点击

2).3秒后关闭浏览器窗口

python 复制代码
from time import sleep

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

# 1、获取浏览器
driver = webdriver.Chrome()
# 2、打开url
driver.get("file:///D:/Chrome/Register.html")
# 3、查找操作元素
driver.find_element(by=By.TAG_NAME, value="input").send_keys("admin")
"""
    需求:点击注册页面的 新浪
    点击:元素.click()
"""
# link_text 全部值
driver.find_element(by=By.LINK_TEXT, value="网易").click()

# partial_link_text  模糊匹配
# driver.find_element(by=By.PARTIAL_LINK_TEXT, value="网").click()

# 4、关闭浏览器
sleep(10)
driver.quit()

3.4 tag_name定位

说明:根据标签名进行定位

方法:driver.find_element(by=By.TAG_NAME, value="标签名")

提示: 如果⻚⾯存在多个相同标签,默认返回第⼀个。
需求:

打开注册A.html页面,完成以下操作

1).使用tag_name定位用户名输入框,并输入:admin

2).3秒后关闭浏览器窗口

python 复制代码
from time import sleep

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

# 1、获取浏览器
driver = webdriver.Chrome()
# 2、打开url
driver.get("file:///D:/Chrome/%E6%B3%A8%E5%86%8CA.html")
# 3、查找操作元素
driver.find_element(by=By.TAG_NAME, value="input").send_keys("admin")


# 4、关闭浏览器
sleep(3)
driver.quit()

3.5 拓展:查找一组元素

说明:返回列表格式,要使用需要添加下标或遍历。

方法:driver.find_elements(by=By.XXXX, value="xxx")

提示:八大元素定位方法都可以使用一组元素定位。如果没有搜索到符合标签,返回空列表。

python 复制代码
"""
    需求:使用定位一组元素的方法+tag_name 将注册a页面所有信息进行填写。
"""
from time import sleep

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

# 1、获取浏览器
driver = webdriver.Chrome()
# 2、打开url
driver.get("file:///D:/Chrome/%E6%B3%A8%E5%86%8CA.html")
# 3、查找操作元素

# 查找所有的input标签
inputs = driver.find_elements(by=By.TAG_NAME, value="input")
inputs[0].send_keys("admin")
inputs[1].send_keys("123456")
inputs[2].send_keys("13800001111")
inputs[3].send_keys("123@qq.com")



# for input in inputs:
#     input.send_keys("admin")

# 4、关闭浏览器
sleep(3)
driver.quit()
相关推荐
生而为虫3 小时前
Selenium打开网页时保持登陆状态
selenium·测试工具
Yeats_Liao4 小时前
评估体系构建:基于自动化指标与人工打分的双重验证
运维·人工智能·深度学习·算法·机器学习·自动化
好好学习天天向上~~5 小时前
6_Linux学习总结_自动化构建
linux·学习·自动化
骆驼爱记录7 小时前
Word样式检查器使用指南
自动化·word·excel·wps·新人首发
XiaoMu_0017 小时前
自动化漏洞扫描与预警平台
运维·网络·自动化
生而为虫9 小时前
[Windows] 【浏览器自动化精灵V1.0】用Excel表格控制浏览器的自动化
运维·自动化
淡忘_cx10 小时前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins
风指引着方向10 小时前
昇腾 AI 开发生产力工具:CANN CLI 的高级使用与自动化脚本编写
运维·人工智能·自动化
掌心向暖RPA自动化10 小时前
影刀RPA如何在网页和桌面软件中实现自动滚动长截图?最好同时支持横向滚动纵向滚动的?
经验分享·自动化·影刀rpa·长截图
淡忘_cx10 小时前
使用Jenkins自动化部署spring-java项目+宝塔重启项目命令(2.528.2版本)
java·自动化·jenkins