笔记:web自动化测试(基础,元素定位)(黑马)

今天目标:
    1. 自动化相关概念知识
    2. 自动化相关环境搭建
    3. 元素定位
    
一、课程大纲
    1. 核心重点(第二章)
    2. 提高代码质量,自动化水平(第三、四、五、六章)
    3. 项目实战(第七章)
    4. 理论及环境与定位(第一章)

自动化相关理论知识


    2.1 自动化 
        说明:让机器设备代替人为完成指定目标的而过程
        优点:
            1. 减少劳动力
            2. 提高效率(批量生产)
            3. 提高产品质量
            4. 规格统一标准
        
    
    2.2 自动化测试
        说明:让程序或工具代替人为对程序功能验证的过程
        解决: 
            1. 回归测试[重点]
            2. 压力测试
            3. 兼容性(1. 浏览器、2. 分辨率 3. 操作系统)
            4. 提高测试效率
            
        优点: 
            1. 在最短时间内运行最多的bug
            2. 脚本重复运行
            3. 减少人为错误
            4. 克服手工测试局限性(图片大小)
            
        误区:
            1. 自动化测试比手工厉害
            2. 自动化测试比手工发现更多bug
            3. 自动化测试可以完全替代手工测试
            4. 软件所有功能都适合自动化测试。
            
    
    2.3 自动化测试分类 
    
        1. Web自动化测试【本阶段学习】
        2. 移动自动化测试(app自动化)
        3. 接口自动化(工具、代码)
        4. 单元测试
    
    2.4 web自动化测试
        概念:让程序代替人为对web项目进功能验证过程
        
        什么web项目适合自动化?
            1. 需求变动不频繁
            2. 需要回归测试项目
            3. 项目周期长
            
        web自动化开始进行阶段?
            手工测试之后(1. 时间问题 2. 功能不完善)
            
        web自动化所属分类
            1. 黑盒测试
            2. 灰盒测试
            3. 白盒测试
            
        提示:
            1. 以上分类为站在代码可见度上划分
            2. web自动化测试属于黑盒测试

自动化工具


    2.1 主流自动化工具
            1. QTP: 收费 支持(支持web、桌面软件自动化)
            2. selenium: 免费 开源 只支持web项目 【本阶段学习】
            3. Robot framework: 基于python扩展关键字驱动自动化工具。2014年停止更新
            
    2.2 什么是selenium?
            一个web自动化测试工具, 中文的意思:硒
            
    2.3 特点:
        1. 开源、免费
        2. 跨平台(Linux windows mac)
        3. 支持多浏览器:谷歌 火狐 IE
        4. 支持多语言:python、java...等等
        5. 成熟稳定:已经被 谷歌、百度大型公司广泛使用
        6. 功能强大:支持商业化大部分功能,并且由于开源,可以定制化需求功能。
        
        
    2.4 slenium家族介绍
        版本:
            selenium1.0 
                1. selenium IDE (录制自动化代码工具)
                2. selenium Grid (分布式工具:同时启动多个浏览器)
                3. selenium RC(通过JS模拟浏览器,实现自动化方式)
            selenium2.0(稳定推荐版)
                selenium2.0 = selenium1.0+webdriver
                
            selenium3.0
                2.0升级版,支持JAVA8、woindows10 Edge浏览器、safa浏览器
                
            提示:无论是通过2.0还是3.0编写的自动化脚本,API方法是不变的,唯一不同就是环境不同。

环境搭建

安装 selenium ,版本最好用3.141.0     用清华源快一点

 安装浏览器驱动,自己上网看一下,记得设置系统变量

pip install --upgrade selenium==3.141.0 -i https://pypi
.tuna.tsinghua.edu.cn/simple

现在就可以开始写selenium代码了,

打开百度,3秒后关闭

# 导包
from selenium import webdriver
 import time
 # 创建浏览器驱动对象
driver = webdriver.Firefox()
 # driver = webdriver.Chrome()
 # driver = webdriver.Edge()
 # 加载web页面
driver.get("http://www.baidu.com/")
 # 暂停3秒
time.sleep(3)
 # 关闭驱动对象
driver.quit()

元素定位

通过元素的信息或元素层级结构来定位元素

浏览器开发者工具

浏览器开发者工具就是给专业的web应用和网站开发人员使用的工具。 包含了对HTML查看和编 辑、Javascript控制台、网络状况监视等功能,是开发JavaScript、CSS、HTML和Ajax的得力助 手。

作用:快速定位元素,查看元素信息

快捷键:一般在windows系统上打开浏览器开发者工具都是按F12

火狐浏览器:在页面上点击右键选择‘查看元素’

谷歌浏览器:在页面上点击右键选择‘检查’

定位元素时依赖于什么?
        1. 标签名
        2. 属性
        3. 层级
        4. 路径

定位方式

        1. id
        2. name
        3. class_name(使用元素的class属性定位)
        4. teg_name(标签名称 <标签名 .../>)
        5. link_text(定位超连接 a标签)
        6. partial_link_text(定位超链接 a标签 模糊)
        7. xpath(基于元素路径)
        8. css(元素选择器)

这里我们只看Xpath和css

Xpath

什么是XPath?

1. XPath即为XML Path的简称,它是一门在 XML 文档中查找元素信息的语言。

2. HTML可以看做是XML的一种实现,所以Selenium用户可以使用这种强大的语言在Web应用中定位元素。

XML:一种标记语言,用于数据的存储和传递。 后缀.xml结尾

<?xml version="1.0" encoding="UTF-8" ?>
 <node>
    <db id="db" desc="三条边的长度都一样">
        <b1>3</b1>
        <b2>3</b2>
        <b3>3</b3>
        <expect>等边三角形</expect>
    </db>
    <dy>
        <b1>4</b1>
        <b2>4</b2>
        <b3>5</b3>
        <expect>等腰三角形</expect>
    </dy>
 </node>

XPath定位策略(方式)

1. 路径-定位

2. 利用元素属性-定位

3. 属性与逻辑结合-定位

4. 层级与属性结合-定位

2.XPath定位方法

chrome浏览器方法:源代码选择一个元素——copy——copy xpath

火狐:firepath插件,也可以和Chrome一样

element = driver.find_element_by_xpath(xpath)

2.1 路径定位(绝对路径、相对路径)

绝对路径:从最外层元素到指定元素之间所有经过元素层级的路径/

1). 绝对路径以/html根节点开始,使用/来分隔元素层级;

如:/html/body/div/fieldset/p[1]/input

2). 绝对路径对页面结构要求比较严格,不建议使用

提示: 
            1. 虽然借助工具可以快速生成xpath路径和css语法,但是前期不建议使用。
            2. 工具在智能,没有人智能。

"""
    需求:
        1. 使用绝对路径定位 用户名 输入 admin
        2. 暂停2秒钟
        3. 使用相对路径定位 密码框 输入 123

    方法:
        driver.find_element_by_xpath()
"""

# 导包
from selenium import webdriver
from time import sleep


# 获取 浏览器驱动对象
# driver = webdriver.Firefox()
driver = webdriver.Chrome()

# 打开 注册A.html
url = r"E:\BaiduNetdiskDownload\8天web自动化全套测试—资料\web自动化_day01_课件+笔记+资料+代码\02_其他资料\注册A.html"
driver.get(url)

# 使用绝对路径定位 用户名 admin
# driver.find_element_by_xpath("/html/body/form/div/fieldset/p[1]/input").send_keys("admin")

# 使用层级结合属性 定位用户名 ,输入 admin:
driver.find_element_by_xpath("//p[@id='p1']/input").send_keys("admin")

# 暂停2秒
sleep(2)

# 使用相对路径 定位 密码  123
# driver.find_element_by_xpath("//input[@id='passwordA']").send_keys("123")


# 使用逻辑结合
driver.find_element_by_xpath("//input[@id='passwordA' and @placeholder='密码A']").send_keys("123")
# 暂停 3秒
sleep(3)
# 退出浏览器驱动
driver.quit()

定位一组元素:


    方法:driver.find_elements_by_xxx()
    返回结果:类型为列表,要对列表进行访问和操作必须指定下标或进行遍历,[下标从0开始]

"""
    目标:
        driver.find_elements_by_xxx
"""

# 导包
from selenium import webdriver
from time import sleep


# 获取 浏览器驱动对象
# driver = webdriver.Firefox()
driver = webdriver.Chrome()

# 打开 注册A.html
url = r"E:\BaiduNetdiskDownload\8天web自动化全套测试—资料\web自动化_day01_课件+笔记+资料+代码\02_其他资料\注册A.html"
driver.get(url)

# 获取所有的input元素
# 得到的是一个列表
# elements = driver.find_elements_by_tag_name("input")

elements = driver.find_elements_by_id("userA")
print(len(elements))
print("elements的类型为:", type(elements))

# 输入内容
# elements[0].send_keys("admin")

# 通过遍历来输入
for el in elements:
    el.send_keys("admin")

# 暂停 3秒
sleep(3)
# 退出浏览器驱动
driver.quit()

driver.find_element()

        现在最新selenium就用这种方法

"""
    目标:
        driver.find_element()
        现在最新就用这种方法
    需求:
        1. 使用driver.find_element()方法
        2. 输入用户名:admin
        3. 输入密码:123456
"""

# 导包
from selenium import webdriver
from time import sleep


# 获取 浏览器驱动对象
from selenium.webdriver.common.by import By

# driver = webdriver.Firefox()
driver = webdriver.Chrome()

# 打开 注册A.html
url = r"E:\BaiduNetdiskDownload\8天web自动化全套测试—资料\web自动化_day01_课件+笔记+资料+代码\02_其他资料\注册A.html"
driver.get(url)

# 使用find_element()定位用户名
driver.find_element(By.ID, "userA").send_keys("admin")
# 使用find_element()定位密码
driver.find_element(By.CSS_SELECTOR, "#passwordA").send_keys("123456")

# 暂停 3秒
sleep(3)
# 退出浏览器驱动
driver.quit()

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值