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("[email protected]")

# 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("[email protected]")



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

# 4、关闭浏览器
sleep(3)
driver.quit()
相关推荐
Kookoos3 小时前
Dynamics 365 Finance + Power Automate 自动化凭证审核
运维·自动化·dynamics 365·power automate
半导体守望者13 小时前
ADVANTEST R3764 66 R3765 67爱德万测试networki connection programming网络程序设计手册
经验分享·笔记·功能测试·自动化·制造
有风南来14 小时前
算术图片验证码(四则运算)+selenium
自动化测试·python·selenium·算术图片验证码·四则运算验证码·加减乘除图片验证码
东方佑17 小时前
使用 Python 自动化 Word 文档样式复制与内容生成
python·自动化·word
会又不会19 小时前
JMeter-SSE响应数据自动化2.0
jmeter·自动化
新加坡内哥谈技术21 小时前
Meta计划借助AI实现广告创作全自动化
运维·人工智能·自动化
集成显卡1 天前
PlayWright | 初识微软出品的 WEB 应用自动化测试框架
前端·chrome·测试工具·microsoft·自动化·edge浏览器
b***25111 天前
动力电池点焊机:驱动电池焊接高效与可靠的核心力量|比斯特自动化
人工智能·科技·自动化
沉到海底去吧Go1 天前
【行驶证识别成表格】批量OCR行驶证识别与Excel自动化处理系统,行驶证扫描件和照片图片识别后保存为Excel表格,基于QT和华为ocr识别的实现教程
自动化·ocr·excel·行驶证识别·行驶证识别表格·批量行驶证读取表格
Iamccc13_1 天前
智能仓储的未来:自动化、AI与数据分析如何重塑物流中心
人工智能·数据分析·自动化