自动化测试理论[理解]
什么是自动化测试
自动化测试是把以人为驱动的测试行为转化为机器执行的一种过程。
为什么要做自动化测试
- 重复性高的测试工作
- 提高执行测试效率
- 在非工作时间执行
- 每次执行的方式/步骤都是一样的
自动测试解决的问题
- 解决-回归测试
- 解决-压力测试
- 解决-兼容性测试
什么样的项目适合自动化测试
- 需求变动不频繁
- 项目周期长
- 代码复用度高
selenium简介[了解]
什么是selenium
Selenium 是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作浏览器一样。
这个工具的主要功能包括:测试程序与浏览器的兼容性,测试你的应用程序是否能够很好得工作在不同浏览器和操作系统之上,测试系统功能,用户需求等。
selenium的特点
- 开源,免费
- 多浏览器支持:FireFox、Chrome、IE、Opera、Edge
- 多平台支持:Linux 、Windows、Mac
- 多语言支持:Java、Python、PHP、Ruby、C#、JavaScript、Golang
- 对web 页面有良好的支持
- 简单(API 简单)、灵活(用开发语言驱动)
- 支持分布式测试用例执行
Selenium版本
官方网址:https://www.selenium.dev/
Selenium截至目前已经发布了4个大版本,下面介绍每个版本的区别。
- Selenium1.0
Selenium 1.0包括:Selenium IDE、Selenium Grid、Selenium RC三部分。 - Selenium2.0
Selenium 2.0= Selenium 1.0 + WebDriver - Selenium3.0
Selenium 3.0在Selenium 2.0的基础上有了更多的改进,支持的原生驱动方面更为丰富。
去掉了对Selenium RC的支持。JDK的最低版本要求为8。
Selenium 3.0包括:Selenium IDE(录制回放)、Selenium Grid(分布式)、WebDriver(通过浏览器操作页面元素)三部分。
- Selenium4.0
主要是为了标准化,抛弃了一些老的用法。
前端技术介绍
由于selenium 基于web 的自动化测试技术,我们的要操作的对象是页面,所以有必要对前端的技术和工具有一个基本的了解。
- HTML + CSS
- JavaScript
- XML[自定义标签名的标签语言](明天介绍)
环境搭建[操作]
下载安装浏览器
- chrome
chrome下载地址 - firefox
firefox下载地址
安装python
python官网
下载配置浏览器驱动
- 下载驱动,选择和自己浏览器匹配的版本下载
驱动下载地址
- 配置驱动
将下载的驱动放到python安装目录下,或者把驱动的文件夹地址放到系统环境变量中。
windows系统下可通过where python命令找到python的安装目录。
安装selenium
# 安装selenium
pip install selenium -i 国内镜像地址
# 查看当前解释器所有的包
pip list
# 查看指定包的信息
pip show selenium
# 卸载selenium
pip uninstall selenium
各个浏览器驱动使用[掌握]
chrome(推荐使用)
# 导入selenium
import time
from selenium import webdriver
# 打开chrome浏览器, 返回一个webdriver对象
driver = webdriver.Chrome()
# 退出浏览器
time.sleep(2)
driver.quit()
firefox
# 导入selenium
import time
from selenium import webdriver
# 打开firefox浏览器, 返回一个webdriver对象
driver = webdriver.Firefox()
# 退出浏览器
time.sleep(2)
driver.quit()
浏览器开发者工具介绍[操作]
在任意页面右键-->检查或者F12进入浏览器开发者工具。
- Elements:web页面自动化测试中快速定位元素对应的html代码
- Console:对BUG定位,是否是前端BUG
- Network:接口测试,抓包请求,对BUG定位,是否是服务端BUG
- Application:获取Cookie
- Lighthouse:前端性能测试工具
第一个测试案例[掌握]
1、打开Chrome,打开百度首页
2、搜索框输入“python自动化测试”,点击百度一下
3、获取页面标题,并打印出来
4、检查“python”关键字是否在标题中
5、关闭Chrome浏览器
面向过程-案例
import time
from selenium import webdriver
from selenium.webdriver.common.by import By
# 1、打开Chrome
driver = webdriver.Chrome()
# 2、输入网址-百度网址,必须是完整的网址,必须要有协议。比如:https://www.baidu.com
# driver.get(完整的网址)
time.sleep(2)
driver.get("https://www.baidu.com") # https://www.so.com
# 3、获取搜索框输入关键字-python自动化测试
time.sleep(2)
# 获取搜索框标签-标签定位(8种方法)通过id定位 driver.find_element(定位类型, 定位的值)
# kw = driver.find_element_by_id("kw") # 即将抛弃这种使用方式
# kw = driver.find_element("id", "kw") # 可以但不建议
kw = driver.find_element(By.ID, "kw")
# 向搜搜框输入关键字 webelement.send_keys(文本内容)
kw.send_keys("python自动化测试")
# 获取百度一下按钮
time.sleep(2)
su = driver.find_element(By.ID, "su")
# 点击方法 webelement.click()
su.click()
# 4、获取页面标题,并打印出来
# driver.title 获取当前页面的标题-获取html中title标签的文本内容
time.sleep(2)
print(driver.title)
# 5、检查’python’关键字是否在标题中
if "python" in driver.title:
print("ok")
else:
print("no")
# 6、关闭Chrome浏览器
time.sleep(2)
driver.quit()
面向对象-案例
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
class TestCase:
def __init__(self):
# 初始化对象属性
self.driver = webdriver.Chrome()
def get_baidu(self):
# 请求百度
self.driver.get("https://www.baidu.com")
# 搜索框输入内容
time.sleep(2)
self.driver.find_element(By.ID, "kw").send_keys("python自动化测试")
# 点击百度一下
time.sleep(2)
self.driver.find_element(By.ID, "su").click()
# 检查’python’关键字是否在标题中
time.sleep(2)
if "python" in self.driver.title:
print("ok")
else:
print("no")
# seconds 秒
def quit(self, seconds=3):
# 退出浏览器
time.sleep(seconds)
self.driver.quit()
if __name__ == "__main__":
case = TestCase()
case.get_baidu()
case.quit()
浏览器选项配置[操作]
模拟移动端
import time
from selenium import webdriver
# 准备配置项
mobileEmulation = {"deviceName":"iPhone SE"}
# 创建options对象
options = webdriver.ChromeOptions()
# 添加选项配置信息
options.add_experimental_option("mobileEmulation",mobileEmulation)
# 打开浏览器,配置选项对象
driver = webdriver.Chrome(options=options)
# 访问网址
driver.get("https://www.baidu.com")
# 退出浏览器
time.sleep(5)
driver.quit()
无头模式
浏览器在后台运行,不在界面显示,通常在linux服务器上运行时使用。
from selenium import webdriver
# 选项对象,添加参数
options = webdriver.ChromeOptions()
options.add_argument("-headless")
# 打开浏览器,设置选项
driver = webdriver.Chrome(options=options)
# 请求百度
driver.get("https://www.baidu.com")
# 输出网页标题
print(driver.title)
# 退出浏览器
driver.quit()
浏览器操作[掌握]
浏览器窗口大小设置
# 设置浏览器宽480、高800
driver.set_window_size(480, 800)
# 浏览器窗口最大化
driver.maximize_window()
浏览器页面前进后退
# 前进
driver.forward()
# 后退
driver.back()
浏览器页面刷新
# 刷新
driver.refresh()
浏览器关闭
# 关闭当前窗口
driver.close()
# 退出驱动并关闭所有关联的窗口
driver.quit()
浏览器操作代码
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
class BrowserOperation:
def __init__(self):
self.driver = webdriver.Chrome()
self.driver.get("http://www.baidu.com")
def quit(self, seconds=2):
time.sleep(seconds)
self.driver.quit()
def window_size(self):
# 浏览器窗口大小设置
# 设置具体的尺寸
for i in range(3):
time.sleep(2)
self.driver.set_window_size(480, 800)
# 浏览器最大化
time.sleep(2)
self.driver.maximize_window()
# 浏览器最小化
time.sleep(2)
self.driver.minimize_window()
def forward_and_back(self):
# 浏览器前进和后退
for i in range(3):
# 后退
time.sleep(2)
self.driver.back()
# 前进
time.sleep(2)
self.driver.forward()
def refresh(self):
# 浏览器刷新
time.sleep(2)
self.driver.refresh()
def close(self):
# close关闭标签页
# 获取新闻这个连接标签-链接文本定位方式
time.sleep(2)
news = self.driver.find_element(By.LINK_TEXT, "新闻")
news.click()
# 关闭当前标签-百度首页
time.sleep(2)
self.driver.close()
if __name__ == '__main__':
browser = BrowserOperation()
# browser.window_size()
# browser.forward_and_back()
# browser.refresh()
browser.close()
browser.quit(10)
本文暂时没有评论,来添加一个吧(●'◡'●)