【Playwright+Python】系列教程(一)环境搭建及脚本录制

news/2024/7/20 15:33:50

一、前言

看到这个文章,有的同学会说:

六哥,你为啥不早早就写完python系列的文章。

因为有徒弟需要吧,如果你也想学自学,那这篇文章,可以说是我们结缘一起学习的开始吧!

如果对你有用,建议收藏和转发!

二、Playwright是什么?

微软开源自动化测试工具Playwright,支持主流浏览器,包括:Chrome、Firefox、Safari 等,同时支持以无头模式、有头模式运行,并提供了同步、异步的 API,可以结合 主流测试框架使用,并且支持浏览器端的自动化脚本录制等功能。

特点:

  • 跨浏览器:Playwright 支持所有现代渲染引擎,包括Chromium、WebKit 和 Firefox;
  • 跨平台:在 Windows、Linux 和 MacOS 上进行本地或 CI、无头或有头测试;
  • 跨语言:在 TypeScript、JavaScript、Python、.NET、Java 中使用Playwright API;
  • 测试移动网络:适用于 Android 和 Mobile Safari 的 Google Chrome 原生移动仿真。相同的渲染引擎适用于您的桌面和云端。

官网地址:

https://playwright.dev

GitHub地址:

https://github.com/microsoft/playwright

通俗的讲:

就是一款主流的自动化测试工具,可以跨平台、跨语言、开源、支持分布式、拥有成熟的社区及学习文档,主要用于接口和web自动化测试。

三、开发环境搭建

1、系统要求:

  • Python 3.8 or higher. Python 3.8 或更高版本。
  • Windows 10+, Windows Server 2016+ or Windows Subsystem for Linux (WSL). Windows 10+、Windows Server 2016+ 或适用于 Linux 的 Windows 子系统 (WSL)。
  • MacOS 12 Monterey, MacOS 13 Ventura, or MacOS 14 Sonoma. MacOS 12 Monterey、MacOS 13 Ventura 或 MacOS 14 Sonoma。
  • Debian 11, Debian 12, Ubuntu 20.04 or Ubuntu 22.04. Debian 11、Debian 12、Ubuntu 20.04 或 Ubuntu 22.04。

2、安装依赖

安装 Pytest 插件:

pip install pytest-playwright

安装所需的浏览器:

playwright install

3、示例程序

打开首页并截图,示例代码如下:

# -*- coding: utf-8 -*-
# @Time    : 2024/06/18 22:26
# @Author  : longrong.lang
# @FileName: test_demo.py
# @Software: PyCharm
# @Cnblogs :https://www.cnblogs.com/longronglang
# @Motto:你只管努力,剩下的交给天意.
import re
from playwright.sync_api import Page, expectdef test_has_title(page: Page):
    page.goto("https://playwright.dev/")    # Expect a title "to contain" a substring.
    expect(page).to_have_title(re.compile("Playwright"))def test_get_started_link(page: Page):
    page.goto("https://playwright.dev/")    # Click the get started link.
    page.get_by_role("link", name="Get started").click()    # Expects page to have a heading with the name of Installation.
    expect(page.get_by_role("heading", name="Installation")).to_be_visible()

运行结果:

image.png

image.png

说明: 默认情况下,测试将在 chromium 上运行。这可以通过 CLI 选项进行配置。测试在无外设模式下运行,这意味着在运行测试时不会打开浏览器 UI。测试结果和测试日志将显示在终端中。

4、更新Playwright

pip install pytest-playwright playwright -U

四、脚本录制

和很多自动化测试工具一样,Playwright也是可以录制并生成脚本的。 那么接下来将演示如何进行脚本的录制(我个人是不喜欢录制的),此处操作只为有需要的人。 由于之前做的electron桌面应用环境开发,依赖node.js运行环境,而Playwright也是完美支持node. js,那我将用node环境给大家演示。

1、如何录制

使用Playwright无需写一行代码,我们只需手动操作浏览器,它会录制我们的操作,然后自动生成代码脚本。

输入如下命令,开启录制 如下所示:

playwright codegen  https://www.cnblogs.com/longronglang (测试的网址)

image.png 在target中选择你需要的语言和框架:

这里以Pytest为例,如下所示:

image.png

操作中会有页面相关定位提示,点击结束录制,并复制生成脚本,如下所示:

image.png

关于元素定位,可以用自带的验证工具验证元素定位表达式,如下图所示:

image.png

image.png

2、生成脚本

生成代码如下所示:

# -*- coding: utf-8 -*-
# @Time    : 2024/06/18 22:26
# @Author  : longrong.lang
# @FileName: test_demo.py
# @Software: PyCharm
# @Cnblogs :https://www.cnblogs.com/longronglang
# @Motto:你只管努力,剩下的交给天意.
import re
from playwright.sync_api import Page, expectdef test_example(page: Page) -> None:
    page.goto("https://www.cnblogs.com/longronglang")
    page.locator("#main-header div").nth(1).click()
    page.locator(".onOff").click()
    page.locator("#main-header div").nth(1).click()
    page.locator("div:nth-child(6)").first.click()
    page.get_by_text("久曲健的测试窝").click()
    page.get_by_text("久曲健的测试窝").click(button="right")
    page.get_by_text("我知道了").click()
    page.get_by_role("heading", name="青春的土壤中,只有记忆是潮湿的。").click()
    page.get_by_text("久曲健的测试窝").click()
    page.get_by_text("久曲健的测试窝").click()
    page.get_by_text("久曲健的测试窝").click()
    page.locator("#main-header div").nth(1).click()
    expect(page.locator("#homeTopTitle")).to_contain_text("久曲健的测试窝")
    page.get_by_role("heading", name="青春的土壤中,只有记忆是潮湿的。").click()

说明: 从上面可以看到,录制的工具也很好用,具体用法参考https://playwright.dev/python/docs/codegen-intro

回放脚本如下所示:

image.png

image.png

这个框架执行速度有些慢,首次运行比较耗时,其他感觉还好。

到此关于Playwright开发环境搭建及脚本的录制已完成,有兴趣的同学可以自行尝试。

五、写在最后

有的时候,你的一时想法,真的强烈建议你记录下来,如果觉得它是有意义的,那么就什么都不要去想,干就完了!

最后,分享一句李尚龙的一句话,你只是看起来很努力,你所谓的稳定不过是浪费生命!

形式上的努力,并没有什么用,打卡什么的也不过于自我安慰,真正的强者,已经都开始行动起来了,不是吗?

如果你苦于找不到同学一起学习来,来加我好友,我们有学习群,来一起当同学好么!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/45259.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

苹果CMS 阿里云OSS插件

直接下载插件上传到CMS的addons目录解压点击启用插件点击配置插件配置完毕后进入系统菜单>附件参数配置保存方式改为阿里云OSS即可需要插件直接联系我 :vx:qianjingchuangqi本文来自博客园,作者:ikay,转载请注明原文链接:https://www.cnblogs.com/ikay/p/18255405

PPT使用技巧

PPT使用说明: 查看版本:账户 撤回次数: 自动保存: 图片压缩:(ppt图片默认是压缩的),只针对单个ppt文件 字体嵌入:解决不同电脑导致字体显示的不一样。 ppt多格式导出:如视频、图片、图片型的ppt 参考线: 默认字体: 默认样式:设置所有图形的样式清除占位符:…

点云分割网络PointConv

PDF:《PointConv: Deep Convolutional Networks on 3D Point Clouds》 CODE: https://github.com/DylanWusee/pointconv 一、大体内容 PointConv是一种在非均匀采样下对3D点云进行卷积的运算,可以用来构建深度卷积网络,其将卷积核视为由权重函数和密度函数组成的三维点的局部…

算法金 | 一个强大的算法模型:t-SNE !!

大侠幸会,在下全网同名「算法金」0 基础转 AI 上岸,多个算法赛 Top「日更万日,让更多人享受智能乐趣」t-SNE(t-Distributed Stochastic Neighbor Embedding)是一种用于降维和数据可视化的非线性算法。它被广泛应用于图像处理、文本挖掘和生物信息学等领域,特别擅长处理高…

软件测试理论基础Part2

测试用例设计 等价类划分法有效等价类满足需求的无效等价类不满足需求的等价类划分方法操作步骤明确需求 确定有效和无效等价类 编写测试用例边界值划分法 边界范围上点处在边界上的点(正好等于)离点离上点最近的点内点范围内的点开区间,闭区间[开始值,结束值] - 闭区间,包含开…

解决Ubuntu 下 idea Dock 图标显示错乱

问题表现 通过官网下载的 idea ubuntu 安装包安装之后,默认是需要通过 sh 脚本运行的,我们可以通过在 /usr/share/applications 创建一个 .desktop 的文件,来生成一个可以被 ubuntu 识别的应用。在我的 Ubuntu 下,idea 的配置如下: [Desktop Entry]Name=IntelliJ IDEA Com…

kettle从入门到精通 第七十一课 ETL之kettle 再谈http post,轻松掌握body中传递json参数

场景: kettle中http post步骤如何发送http请求且传递body参数? 解决方案: http post步骤中直接设置Request entity field字段即可。 1、手边没有现成的post接口,索性用python搭建一个简单的接口,关键代码如下(安装python环境略):from flask import Flask, request, jso…