搜索
首页web前端js教程使用 Playwright、TypeScript 和 JavaScript 进行自动化

使用 TypeScript 的剧作家 | JavaScript 安装

Playwright 是 Microsoft 与 Puppeteer 团队合作推出的基于 Web 的现代 API 自动化工具,Puppeteer 是一个 JavaScript 库,提供高级 API,通过 DevTools 协议或 WebDriver BiDi 控制 Chrome 或 Firefox。 Puppeteer 默认情况下以无头(无可见 UI)运行。

Playwright 支持基于现代 Web 的浏览器,通过单个 API 实现 Web 应用程序的自动化,并且还支持 API 的自动化。

剧作家的建筑

Automation using Playwright and TypeScript and JavaScript

Playwright 使用 Web Socket 协议,一旦建立连接,将触发测试并使用 Web Socket 协议将 JSON 格式的请求发送到服务器,这意味着一旦 Playwright 建立连接,无需再次建立连接来将请求发送到服务器直到完成测试执行。 Playwright 必须通过 playwright.quit() 方法断开连接。

让我们了解一下 HTTP 协议连接 Web Socket 协议连接之间的区别

Automation using Playwright and TypeScript and JavaScript

WebSocket 和 HTTP 协议的区别
剧作家的特点:
任何浏览器• 任何平台• 一个API
跨浏览器。 Playwright 支持所有现代渲染引擎,包括 Chromium、WebKit 和 Firefox。

跨平台。在 Windows、Linux 和 macOS 上进行本地或 CI 测试,无头或有头。

跨语言。在 TypeScript、JavaScript、Python、.NET、Java 中使用 Playwright API。

测试移动网络。适用于 Android 的 Google Chrome 和 Mobile Safari 的本机移动模拟。相同的渲染引擎可以在您的桌面和云端运行。

  1. 有弹性 • 没有不稳定的测试

自动等待。剧作家在执行操作之前等待元素可操作。它还具有丰富的内省活动。两者的结合消除了人为超时的需要——这是不稳定测试的主要原因。

网络优先断言。剧作家断言是专门为动态网络创建的。检查会自动重试,直到满足必要的条件。

追踪。配置测试重试策略,捕获执行轨迹、视频、屏幕截图以消除碎片。

  1. 没有权衡•没有限制

浏览器在不同的进程中运行属于不同来源的网页内容。 Playwright 与现代浏览器架构保持一致,并在进程外运行测试。这使得 Playwright 摆脱了典型的进程内测试运行器限制。

一切都多重。跨越多个选项卡、多个源和多个用户的测试场景。为不同的用户创建具有不同上下文的场景,并在您的服务器上运行它们,所有这些都在一次测试中。

可信事件。悬停元素、与动态控件交互、生成可信事件。 Playwright 使用与真实用户无法区分的真实浏览器输入管道。

测试框架,穿透Shadow DOM。剧作家选择器穿透 Shadow DOM 并允许无缝输入帧。

  1. 完全隔离•快速执行

浏览器上下文。 Playwright 为每个测试创建一个浏览器上下文。浏览器上下文相当于一个全新的浏览器配置文件。这提供了零开销的完整测试隔离。创建新的浏览器上下文只需几毫秒。

登录一次。保存上下文的身份验证状态并在所有测试中重用它。这绕过了每个测试中的重复登录操作,但提供了独立测试的完全隔离。

  1. 强大的工具

代码生成器。通过记录您的操作来生成测试。将它们保存为任何语言。

剧作家检查员。检查页面、生成选择器、逐步执行测试、查看点击点、探索执行日志。

跟踪查看器。捕获所有信息以调查测试失败。 Playwright 跟踪包含测试执行截屏、实时 DOM 快照、动作资源管理器、测试源等等。

让我们开始使用 Playwright 和 TypeScript/JavaScript

安装 Playwright for TypeScript/JavaScript
安装先决条件如下:Node.js 18

Windows 10、Windows Server 2016 或适用于 Linux 的 Windows 子系统 (WSL)。
macOS 13 Ventura 或 macOS 14 Sonoma。
Debian 11、Debian 12、Ubuntu 20.04 或 Ubuntu 22.04、Ubuntu 24.04,x86–64 和 arm64 架构。
首先使用 npm、yarn 或 pnpm 安装 Playwright。或者,您也可以使用 VS Code 扩展开始并运行测试。

创建文件夹,例如 TypeScriptWithPlaywright 同样为 JavaScriptwithPlaywright 创建文件夹,然后导航到文件夹并打开 Windows 的命令提示符

Automation using Playwright and TypeScript and JavaScript

剧作家装置
点击回车,将出现以下屏幕,选择脚本语言,然后按回车

Automation using Playwright and TypeScript and JavaScript

选择脚本语言
选择脚本语言然后按 Enter 键后,将出现以下屏幕,并询问您要将端到端测试放在哪里。就这样吧。

剧作家装置
现在它会询问 GitHub Actions 工作流程。如果您想配置,请按 Y 或 N。它会要求您安装浏览器,如果您想安装,请选择 Y,表示正确。将出现以下屏幕。

Automation using Playwright and TypeScript and JavaScript

注意:Playwright 浏览器可以通过以下命令手动安装

Automation using Playwright and TypeScript and JavaScript

npx 剧作家安装

剧作家装置
现在按 Enter 键,将出现以下屏幕。

Automation using Playwright and TypeScript and JavaScript

剧作家装置
剧作家装置

剧作家装置

剧作家安装完成
Playwright 默认执行在无头模式下执行的测试脚本,以下命令将探索在特定浏览器上执行并调试,使用 codegen 生成测试脚本。

npx剧作家测试
运行端到端测试。

npx 剧作家测试 --ui
启动交互式 UI 模式。

npx 剧作家测试 --project=chromium
仅在桌面 Chrome 上运行测试。

npx 剧作家测试示例
在特定文件中运行测试。

npx 剧作家测试 --debug
在调试模式下运行测试。

npx 剧作家代码生成
使用 Codegen 自动生成测试。

我们建议您首先输入:

npx playwright test

现在让我们使用以下命令执行测试脚本并查看报告。 Playwright 将在 chromium、Firefox 和 WebKit 中并行执行测试。

npx剧作家测试

npx剧作家表演报告

Playwright 默认报告仅支持 TypeScript/JavaScript
默认情况下,Playwright 将您的测试脚本配置为在以下浏览器中以无头模式执行。配置将出现在名为 playwright.config.js

的文件夹中

从'@playwright/test'导入{defineConfig, devices};

/**

  • 从文件中读取环境变量。
  • https://github.com/motdotla/dotenv*/ // 从 'dotenv' 导入 dotenv; // 从 'path' 导入路径; // dotenv.config({ path: path.resolve(__dirname, '.env') });

/**

  • 请参阅 https://playwright.dev/docs/test-configuration。
    /
    导出默认的defineConfig({
    testDir: './tests',
    /
    在文件中并行运行测试 /
    完全并行:true,
    /
    如果您不小心在源代码中留下了 test.only,那么 CI 上的构建将会失败。 /
    禁止仅:!!process.env.CI,
    /
    仅在 CI 上重试 /
    重试:process.env.CI? 2:0,
    /
    选择退出 CI 上的并行测试。 /
    工人:process.env.CI? 1:未定义,
    /
    使用的记者。请参阅 https://playwright.dev/docs/test-reporters /
    记者:'html',
    /
    以下所有项目的共享设置。请参阅 https://playwright.dev/docs/api/class-testoptions。 /
    使用:{
    /
    在等待 page.goto('/') 等操作中使用的基本 URL。 */
    // baseURL: 'http://127.0.0.1:3000',

    /* 重试失败的测试时收集跟踪。请参阅 https://playwright.dev/docs/trace-viewer */
    跟踪:“第一次重试时”,
    },

/* 为主要浏览器配置项目 */
项目:[
{
名称:'铬',
使用:{ ...devices['桌面 Chrome'] },
},

npx playwright test

],

/* 在开始测试之前运行本地开发服务器 */
// 网络服务器: {
// 命令:'npm run start',
// url: 'http://127.0.0.1:3000',
// 重用现有服务器: !process.env.CI,
// },
});
现在让我们修改为执行非 headleases 模式(UI)的测试脚本并添加其他浏览器。 Playwright 还提供了记录测试脚本执行的选项和跟踪视图选项,这对于调试非常有用。如果启用跟踪查看器选项,则可以查看测试前的状态、测试期间的状态以及测试后的状态。我修改了剧作家的配置文件,如下:

// @ts-check
const { DefineConfig, devices } = require('@playwright/test');

module.exports = DefineConfig({
testDir: './tests',
完全并行:true,
禁止仅:!!process.env.CI,
重试:process.env.CI? 2:0,
工人:process.env.CI? 1:未定义,
记者:'html',
使用:{
trace: 'on', // 启用跟踪
video: 'on', // 为每个测试录制视频
headless: false, // 以 headless 模式运行测试
},
项目:[
{
名称:'铬',
使用:{ ...devices['桌面 Chrome'] },
},
{
名称:'火狐',
使用:{ ...devices['桌面 Firefox'] },
},
{
名称:'webkit',
使用:{ ...devices['Desktop Safari'] },
},
{
名称:“Microsoft Edge”,
使用:{
...设备['桌面边缘'],
频道:'msedge'
},
},
{
名称:“谷歌浏览器”,
使用:{
...设备['桌面 Chrome'],
频道:'chrome'
},
},
],
});
现在测试脚本可以在配置文件中提到的浏览器上以非无头模式执行测试,并带有记录、跟踪查看器选项。

快乐学习!!自动化快乐!!测试愉快

请随时通过 santoshvqa@gmail.com 和 LinkedIn 个人资料与我联系任何信息/问题

https://www.linkedin.com/in/santosh-kulkarni-ab571639/

以上是使用 Playwright、TypeScript 和 JavaScript 进行自动化的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. JavaScript:学习曲线和易用性Python vs. JavaScript:学习曲线和易用性Apr 16, 2025 am 12:12 AM

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

Python vs. JavaScript:社区,图书馆和资源Python vs. JavaScript:社区,图书馆和资源Apr 15, 2025 am 12:16 AM

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C到JavaScript:所有工作方式从C/C到JavaScript:所有工作方式Apr 14, 2025 am 12:05 AM

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

JavaScript引擎:比较实施JavaScript引擎:比较实施Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

超越浏览器:现实世界中的JavaScript超越浏览器:现实世界中的JavaScriptApr 12, 2025 am 12:06 AM

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

使用Next.js(后端集成)构建多租户SaaS应用程序使用Next.js(后端集成)构建多租户SaaS应用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

如何使用Next.js(前端集成)构建多租户SaaS应用程序如何使用Next.js(前端集成)构建多租户SaaS应用程序Apr 11, 2025 am 08:22 AM

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

JavaScript:探索网络语言的多功能性JavaScript:探索网络语言的多功能性Apr 11, 2025 am 12:01 AM

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器