软件测试|web自动化测试神器playwright教程(三十一)

简介: 软件测试|web自动化测试神器playwright教程(三十一)

image.png

前言

我们都知道selenium可以操作命令行打开的Chrome浏览器,并且可以加载本地数据,因此我们可以绕过部分网站的登录步骤,直接对网站进行操作。如果我们不加任何参数,playwright打开的浏览器就是一个无痕浏览器,一般情况下,对我们测试人员来说,这一点并不影响我们的使用。但是playwright还是给我们提供了launch_persistent_context来启动本地的Chrome浏览器。

selenium加载Chrome插件

启动浏览器的时候添加--user-data-dir 用户数据目录,即可启动带插件的浏览器,并且会记住用户的cookies数据,示例如下:

import time
from selenium import webdriver
import getpass

# 启用带插件的浏览器
option = webdriver.ChromeOptions()
option.add_argument(f"--user-data-dir=C:\\Users\\{getpass.getuser()}\\AppData\Local\Google\Chrome\\User Data")
driver = webdriver.Chrome(options=option)   # 打开chrome浏览器
driver.maximize_window()
driver.get("https://www.baidu.com")
time.sleep(10)

运行脚本,结果如下图,自动加载了百度的用户数据:

在这里插入图片描述

playwright 启动本地 Chrome浏览器

launch_persistent_context 方法启动本地的chrome 浏览器,并且设置 channel="chrome"

import getpass
from playwright.sync_api import sync_playwright



# 获取 google chrome 的本地缓存文件
USER_DIR_PATH = f"C:\\Users\\{getpass.getuser()}\\AppData\Local\Google\Chrome\\User Data"

with sync_playwright() as p:
    browser = p.chromium.launch_persistent_context(
                        # 指定本机用户缓存地址
                        user_data_dir=USER_DIR_PATH,
                        # 接收下载事件
                        accept_downloads=True,
                        # 设置 GUI 模式
                        headless=False,
                        bypass_csp=True,
                        slow_mo=1000,
                        channel="chrome",

                    )

    page = browser.new_page()
    page.goto("https://www.baidu.com")

    page.pause()

运行脚本,打开的浏览器如下:

image.png

注:在运行脚本之前,需要将浏览器关闭

加载插件

Chrome浏览器插件加载需配置args 参数,示例如下:

import getpass
from playwright.sync_api import sync_playwright


# 获取 google chrome 的本地缓存文件
USER_DIR_PATH = f"C:\\Users\\{getpass.getuser()}\\AppData\Local\Google\Chrome\\User Data"
# chrome.exe指定可执行文件路径

# chrome插件目录,下载后解压crx
path_to_extension = r"C:\Users\xxxxx\AppData\Local\Google\Chrome\User Data\Default\Extensions"

with sync_playwright() as p:
    browser = p.chromium.launch_persistent_context(
                        # 指定本机用户缓存地址
                        user_data_dir=USER_DIR_PATH,
                        # executable_path=executable_path,  # 如果有需要可以下载chrome.exe到指定目录加载
                        # 接收下载事件
                        accept_downloads=True,
                        # 设置 GUI 模式
                        headless=False,
                        bypass_csp=True,
                        slow_mo=1000,
                        channel="chrome",
                        args=[
                            f"--disable-extensions-except={path_to_extension}",
                            f"--load-extension={path_to_extension}"
                        ],  # 加载扩展插件

                    )

注: 加载扩展程序必须在有界面模式使用,即headless=false下使用。

使用代理

如果需要使用代理,可以添加proxy参数,添加方式如下:

proxy=ProxySettings(server="http://xxx.xxx.xxx.xxx:xxxx")

总结

本文主要介绍了playwright启动本地浏览器并且加载本地插件的方法,启动本地浏览器可以免登录操作网页,节省我们登录的时间。

相关文章
|
9月前
|
前端开发 测试技术 API
测试金字塔:别再只盯着UI自动化了
测试金字塔:别再只盯着UI自动化了
743 116
|
9月前
|
敏捷开发 测试技术 API
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
632 116
|
9月前
|
人工智能 自然语言处理 测试技术
从人工到AI驱动:天猫测试全流程自动化变革实践
天猫技术质量团队探索AI在测试全流程的落地应用,覆盖需求解析、用例生成、数据构造、执行验证等核心环节。通过AI+自然语言驱动,实现测试自动化、可溯化与可管理化,在用例生成、数据构造和执行校验中显著提效,推动测试体系从人工迈向AI全流程自动化,提升效率40%以上,用例覆盖超70%,并构建行业级知识资产沉淀平台。
从人工到AI驱动:天猫测试全流程自动化变革实践
|
9月前
|
人工智能 自然语言处理 JavaScript
利用MCP Server革新软件测试:更智能、更高效的自动化
MCP Server革新软件测试:通过标准化协议让AI实时感知页面结构,实现自然语言驱动、自适应维护的自动化测试,大幅提升效率,降低脚本开发与维护成本,推动测试左移与持续测试落地。
|
10月前
|
人工智能 数据可视化 测试技术
Postman 性能测试教程:快速上手 API 压测
本文介绍API上线后因高频调用导致服务器告警,通过Postman与Apifox进行压力测试排查性能瓶颈。对比两款工具在批量请求、断言验证、可视化报告等方面的优劣,探讨API性能优化策略及行业未来发展方向。
Postman 性能测试教程:快速上手 API 压测
|
9月前
|
测试技术 API 数据库
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
647 114
|
9月前
|
Java 测试技术 网络安全
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
383 0
Burp Suite Professional 2025.10 for Windows x64 - 领先的 Web 渗透测试软件
|
9月前
|
安全 Linux iOS开发
Burp Suite Professional 2025.10 发布 - Web 应用安全、测试和扫描
Burp Suite Professional 2025.10 (macOS, Linux, Windows) - Web 应用安全、测试和扫描
564 3
|
10月前
|
安全 NoSQL Shell
web渗透-SSRF漏洞及discuz论坛网站测试
SSRF(服务器端请求伪造)是一种安全漏洞,攻击者可诱使服务端发起任意请求,进而探测或攻击内网系统。常用于端口扫描、访问内部服务、读取本地文件等。常见防御包括限制协议、域名和IP,但可通过302跳转、短地址等方式绕过。
498 1
web渗透-SSRF漏洞及discuz论坛网站测试
|
安全 JavaScript 前端开发
AppSpider 7.5.020 发布 - Web 应用程序安全测试
AppSpider 7.5.020 for Windows - Web 应用程序安全测试
243 0