WebUI自动化测试 —— PlayWright_微软开源了自己的自动化测试框架

–geolocation             specify geolocation coordinates, for example “37.819722,-122.478611”
  --lang                       specify language / locale, for example “en-GB”
  --proxy-server                  specify proxy server, for example “http://myproxy:3128” or “socks5://myproxy:8080”
  --timezone 

Commands:
  open [url]                             open page in browser specified via -b, --browser
  cr [url]                               open page in Chromium
  ff [url]                               open page in Firefox
  wk [url]                               open page in WebKit
  codegen [options] [url]                open page and generate code for user actions
  screenshot [options]    capture a page screenshot
  pdf [options]           save page as pdf
  install                                Ensure browsers necessary for this version of Playwright are installed
  help [command]                         display help for command


从命令行帮助信息中可以看出,Playwright 支持的功能相当丰富!如多浏览器、截图、录制、代理、模拟手机、地理位置、pdf导出等。



现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036【暗号:csdn999】


![](https://img-blog.csdnimg.cn/cdff58590d1e4bafb1cc641ad3500e0e.png)


### 实操演示


#### 录制脚本


命令:`playwright codegen`  
 帮助:


* --help 帮助文档
* -o 指定生成自动化脚本录制的输出目录位置
* --target 指定脚本语言,告诉他用什么语言写,后面一大堆,还有个python-pytest!,默认用python
* -b 指定浏览器驱动,默认用的谷歌


示例:



python3 -m playwright codegen --target python -o 'xndery.py' -b chromium https://www.baidu.com
# 命令解析👇🏻:
# 打开 Chrome 浏览器开始录制脚本
# 指定生成语言为:Python(默认Python,可选)
# 保存的文件名:xndery.py(可选)
# 浏览器驱动:webkit(默认webkit,可选)
# 打开的目标网站(默认仅仅是打开浏览器,可选)
# 录制字符输入,并点击 百度一下 按钮
# 页面所有的人工操作,都会被自动转化成代码后保存至xndery.py文件中
from playwright.sync_api import Playwright, sync_playwright, expect

def run(playwright: Playwright) -> None:
    browser = playwright.chromium.launch(headless=False)
    context = browser.new_context()
    page = context.new_page()
    page.goto(“https://www.baidu.com”)
    page.locator(“#kw”).click()
    page.locator(“#kw”).fill(“小姐姐AI图片”)
    page.get_by_role(“button”, name=“百度一下”).click()

context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)



![图片](https://img-blog.csdnimg.cn/img_convert/3b6d21a9743c3f53393142e10e4aa2b2.png)


脚本正常运行:自动打开谷歌浏览器百度页面,自动输入关键字并点击按钮后得到搜索结果。


#### 支持同步


同步的关键字为:`sync_playwright`,类似selenium脚本,同步模式的语法如下:



# 依次使用三个浏览器内核打开浏览器,
# 然后百度一下,接着对在搜索界面截图,最后关闭浏览器
from time import sleep
from playwright import sync_playwright

# 注意:默认是无头模式
with sync_playwright() as p:
    # 分别对应三个浏览器驱动
    for browser_type in [p.chromium, p.firefox, p.webkit]:
        # 指定为有头模式,方便查看
        browser = browser_type.launch(headless=False)
        page = browser.newPage()
        page.goto(‘http://baidu.com’)

# 执行一次搜索操作
        page.fill(“input[name=“wd”]”, “咸的AutoSense”)
        with page.expect_navigation():
            page.press(“input[name=“wd”]”, “Enter”)
        # 等待页面加载完全
        page.waitForSelector(“text=水勺子”)
        page.screenshot(path=f’test-{browser_type.name}.png’)  # 截图
        sleep(3)
        browser.close()  # 关闭浏览器


playwright-python 内置的 API 基本上囊括常见的自动化操作。


#### 支持异步


异步的关键字为:async\_playwright,异步操作可结合asyncio同时进行三个浏览器操作。



import asyncio
from playwright import async_playwright

# 异步执行
async def main():
    async with async_playwright() as p:
        for browser_type in [p.chromium, p.firefox, p.webkit]:
            # 指定为有头模式,方便查看
            browser = await browser_type.launch(headless=False)
            page = await browser.newPage()
            await page.goto(‘http://www.baidu.com’)
            # 执行一次搜索操作
            await page.fill(“input[name=“wd”]”, “咸的AutoSense”)
            await page.press(“input[name=“wd”]”, “Enter”)
            # 等待页面加载完全
            await page.waitForSelector(“text=水勺子”)
            # 截图
            await page.screenshot(path=f’test-{browser_type.name}.png’)
            await browser.close()

asyncio.get_event_loop().run_until_complete(main())


#### 支持移动端


playwright还可支持移动端的浏览器模拟。



# 模拟在给定地理位置上手机iphone 13 Pro Max上的Safari浏览器,
# 首先导航到高德地图,然后执行定位并截图。
from playwright import sync_playwright

with sync_playwright() as p:
    iphone_11 = p.devices[‘iPhone 13 Pro Max’]
    browser = p.webkit.launch(headless=False)
    context = browser.newContext(
        **iphone_13,
        locale=‘en-US’,
        geolocation={ ‘longitude’: 39.913904, ‘latitude’: 116.39014 },
        permissions=[‘geolocation’]
    )
    page = context.newPage()
    page.goto(‘https://amap.com’)
    page.click(‘text=“Now location”’)
    page.screenshot(path=‘xndery-iphone.png’)
    browser.close()


#### 支持Pytest框架


还可以配合pytest插件一起使用,后面会单独一篇讲怎么结合pytest使用:



# 官网示例
def test_playwright_is_visible_on_google(page):
    page.goto(“https://www.google.com”)
    page.type(“input[name=q]”, “Playwright GitHub”)
    page.click(“input[type=submit]”)
    page.waitForSelector(“text=microsoft/Playwright”)


### 使用场景小结:


* 自动化测试:开发人员和测试人员可以使用Playwright来编写自动化测试脚本,验证Web应用程序的功能和性能。
* 性能测试:Playwright可以模拟多个用户同时访问Web应用程序,帮助测试应用程序在高负载情况下的性能表现。
* 可访问性测试:Playwright可以模拟用户使用辅助技术(如屏幕阅读器)访问Web应用程序,帮助测试应用程序的可访问性。
* 网页截图和录制:Playwright可以生成网页截图,也可以录制用户操作过程,帮助开发人员和测试人员分析问题。
* 爬虫工程师:当接口中有加密参数(包括url加密参数、请求头加密参数、cookie加密参数)或者返回数据也是经过加密的,如果加密逻辑太过复杂暂时无法找出,我们可采用自动化的方式获取经过网站渲染过的源码,抓取需要的数据即可;
* 开发工程师,可与其他项目结合来使用,比如docker、github/gitlab等


总之,Playwright可以用于各种Web应用程序测试场景;相比已有的自动化测试框架来说,具备诸多明显优势,能够帮助团队提高测试效率和测试覆盖率。





![img](https://img-blog.csdnimg.cn/img_convert/249f284051881f370cb19d221011584e.png)
![img](https://img-blog.csdnimg.cn/img_convert/563727f07b3791039990445cfe7c5bab.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

N7g-1719240956920)]
[外链图片转存中...(img-3IUHJO0X-1719240956921)]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

### Python 爬虫处理服务器端渲染的技术和方法 对于服务器端渲染的内容,传统的HTML解析库如BeautifulSoup可能无法直接获取动态加载的数据。为了有效抓取这类网页内容,可以采用多种技术和工具。 #### 使用Selenium WebDriver模拟浏览器行为 Selenium是一个强大的自动化测试框架,能够驱动真实浏览器执行操作。通过安装对应的语言绑定和支持的WebDriver,比如ChromeDriver或GeckoDriver,可以在Python脚本中控制这些浏览器实例完成页面交互并提取所需信息。 ```python from selenium import webdriver import time options = webdriver.ChromeOptions() options.add_argument('--headless') # 设置无头模式运行 driver = webdriver.Chrome(options=options) try: driver.get('https://example.com') time.sleep(5) # 等待JavaScript渲染完毕 html_content = driver.page_source finally: driver.quit() print(html_content) ``` 这种方法适用于那些依赖大量JavaScript逻辑构建DOM结构的应用程序[^2]。 #### 利用Headless Chrome/Chromium作为服务 除了集成到本地环境中之外,还可以部署一个轻量级的服务化解决方案——即把Headless Chrome/Chromium作为一个独立进程启动,并通过远程调试协议与其通信。这种方式允许更灵活地管理和扩展爬虫作业,同时也减少了对宿主机环境的影响。 #### Pyppeteer - 基于asyncio的异步版本Puppeteer Pyppeteer是Google Puppeteer项目的官方Python移植版,它提供了与Node.js原生实现几乎相同的API接口,支持创建高并发的任务队列以及管理多个标签页间的上下文切换等功能。 ```python import asyncio from pyppeteer import launch async def main(): browser = await launch(headless=True) page = await browser.newPage() await page.goto('https://example.com') content = await page.content() # 获取完整的HTML文档字符串 print(content) await browser.close() asyncio.run(main()) ``` 此方案特别适合需要频繁刷新目标站点或者长时间保持连接状态下的场景应用[^1]。 #### Playwright - 支持多浏览器类型的现代Web自动化平台 Playwright是由微软开发的一个开源项目,旨在提供跨平台兼容性的WebUI测试能力。相较于其他同类产品而言,其优势在于内置了丰富的特性集,包括但不限于自动等待机制、文件上传下载功能等,极大简化了复杂业务流程的操作难度。 ```python from playwright.async_api import async_playwright async def run(playwright): chromium = playwright.chromium browser = await chromium.launch(headless=True) context = await browser.new_context() page = await context.new_page() await page.goto("http://whatsmyuseragent.org/") title = await page.title() print(title) await browser.close() async with async_playwright() as p: asyncio.run(run(p)) ``` 上述三种途径均能有效地应对由服务器端负责生成视图层的情况,在实际开发过程中可根据具体需求权衡选用最合适的工具组合[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值