”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 Playwright、TypeScript 和 JavaScript 进行自动化

使用 Playwright、TypeScript 和 JavaScript 进行自动化

发布于2024-11-08
浏览:178

剧作家与 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。 */
    // 基本URL: 'http://127.0.0.1:3000',

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

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

{
  name: 'firefox',
  use: { ...devices['Desktop Firefox'] },
},

{
  name: 'webkit',
  use: { ...devices['Desktop Safari'] },
},

/* Test against mobile viewports. */
// {
//   name: 'Mobile Chrome',
//   use: { ...devices['Pixel 5'] },
// },
// {
//   name: 'Mobile Safari',
//   use: { ...devices['iPhone 12'] },
// },

/* Test against branded browsers. */
// {
//   name: 'Microsoft Edge',
//   use: { ...devices['Desktop Edge'], channel: 'msedge' },
// },
// {
//   name: 'Google Chrome',
//   use: { ...devices['Desktop Chrome'], channel: 'chrome' },
// },

],

/* 在开始测试之前运行本地开发服务器 */
// 网络服务器: {
// 命令:'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 模式运行测试
},
项目:[
{
名称:'铬',
use: { ...devices['桌面 Chrome'] },
},
{
名称:'火狐',
use: { ...devices['桌面 Firefox'] },
},
{
名称:'webkit',
使用:{ ...devices['桌面 Safari'] },
},
{
名称:'Microsoft Edge',
使用: {
...设备['桌面边缘'],
频道:'msedge'
},
},
{
名称:“谷歌浏览器”,
使用: {
...设备['桌面 Chrome'],
频道:'chrome'
},
},
],
});
现在测试脚本可以在配置文件中提到的浏览器上以非无头模式执行测试,并带有记录、跟踪查看器选项。

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

如有任何信息/问题,请随时通过 [email protected] 和 LinkedIn 个人资料与我联系

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

版本声明 本文转载于:https://dev.to/santosh_kulkarni_ffbde129/automation-using-playwright-and-typescript-and-javascript-493l?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何在 C++ 容器中存储异构对象:boost::any 或自定义实现?
    如何在 C++ 容器中存储异构对象:boost::any 或自定义实现?
    在 C 容器中存储异构对象C 容器通常需要同质元素,这意味着它们只能保存单一类型的对象。但是,在某些情况下,您可能需要一个可以容纳混合数据类型的容器。本文探讨了如何使用 boost::any 库和自定义方法来实现此目的。使用 boost::anyboost::any 是一个模板类可以容纳任何 C 类...
    编程 发布于2024-11-08
  • 使用 Pandas 掌握数据分析:从数据中释放洞察力
    使用 Pandas 掌握数据分析:从数据中释放洞察力
    数据分析是数据科学的核心,Python 的 Pandas 库是一个强大的工具,可以使这项任务变得更轻松、更高效。无论您使用简单的电子表格还是大型数据集,Pandas 都可以让您像专业人士一样灵活地操作、分析和可视化数据。在本文中,我们将深入探讨 Pandas 的基础知识,涵盖从数据操作到高级分析技术...
    编程 发布于2024-11-08
  • 最佳免费开源图标库 4
    最佳免费开源图标库 4
    In 2024, finding the best free icon library can significantly enhance the visual appeal of your websites, apps, or digital projects. Whether you're a ...
    编程 发布于2024-11-08
  • React Part 组件、State 和 Props 入门
    React Part 组件、State 和 Props 入门
    欢迎回到我们的 React.js 之旅!在上一篇文章中,我们介绍了 React 的基础知识,强调了它作为构建动态用户界面的库的优势。今天,我们将深入探讨创建 React 应用程序所必需的三个基本概念:组件、状态和属性。让我们详细探讨这些概念! 什么是 React 组件? React ...
    编程 发布于2024-11-08
  • 如何利用原生 ES6 Promises 有效地链接异步 jQuery 函数?
    如何利用原生 ES6 Promises 有效地链接异步 jQuery 函数?
    JavaScript 的互操作性承诺实现异步 jQuery 函数的高效链接链接异步 jQuery 函数时,通常需要避免 jQuery 的内置函数Promises 功能并使用原生 ES6 Promises 代替。这种互操作性允许 jQuery 操作和您想要的 Promise 实现之间的无缝集成。使用 ...
    编程 发布于2024-11-08
  • 在 Python 中使用 ElementTree 的“find”和“findall”方法时如何忽略 XML 命名空间?
    在 Python 中使用 ElementTree 的“find”和“findall”方法时如何忽略 XML 命名空间?
    在 ElementTree 的“find”和“findall”方法中忽略 XML 命名空间使用 ElementTree 模块解析和定位 XML 文档中的元素时,命名空间会带来复杂性。下面介绍了如何在 Python 中使用“find”和“findall”方法时忽略命名空间。当 XML 文档包含命名空间...
    编程 发布于2024-11-08
  • Bitbucket 综合指南:功能、集成和最佳实践
    Bitbucket 综合指南:功能、集成和最佳实践
    Bitbucket简介 Bitbucket 是 Atlassian 旗下基于 Git 的源代码存储库托管服务,以其强大的集成能力和强大的协作功能而闻名。它适合各种规模的团队,提供可简化开发工作流程、提高生产力并确保安全代码管理的解决方案。无论您是小型团队还是大型企业的一部分,Bitbucket 都...
    编程 发布于2024-11-08
  • 如何在 Python 中用逗号连接列表中的字符串?
    如何在 Python 中用逗号连接列表中的字符串?
    从列表中用逗号连接字符串将字符串列表映射到逗号分隔的字符串是编程中的常见任务。可以采用各种方法来实现此目标,每种方法都有自己的优点和缺点。一种流行的方法是将 join 方法与映射函数结合使用。此方法需要创建一个中间字符串,用作各个字符串之间的分隔符。例如:my_list = ['a', 'b', '...
    编程 发布于2024-11-08
  • 如何处理 AngularJS 应用程序中的锚点哈希链接?
    如何处理 AngularJS 应用程序中的锚点哈希链接?
    AngularJS 中的锚点哈希处理使用锚点浏览网页是一种常见的做法,特别是对于具有多个部分的长页面。然而,在 AngularJS 应用程序中,锚链接处理可能会出现问题。当单击 AngularJS 中的锚链接时,默认行为是拦截单击并将用户重定向到不同的页面。为了解决这个问题,AngularJS 提供...
    编程 发布于2024-11-08
  • 用 Java 编写多线程应用程序:综合指南
    用 Java 编写多线程应用程序:综合指南
    在软件开发领域,效率和速度至关重要。随着应用程序复杂性的增加以及需要处理的数据量的增加,利用现代多核处理器的功能变得至关重要。这就是 Java 的并发特性发挥作用的地方,它允许开发人员编写可以同时执行多个任务的多线程应用程序,从而显着提高性能。 了解 Java 并发 Java 中的...
    编程 发布于2024-11-08
  • JavaScript 中的 Promise,4 人指南
    JavaScript 中的 Promise,4 人指南
    随着 JavaScript 的不断发展,理解异步编程对于现代开发至关重要。 Promise 是一个强大的工具,可让您更有效地处理异步操作。这是有关如何在 JavaScript 项目中使用 Promise 的指南。 什么是 Promise? Promise 是一个对象,表示异步操作的最终完成(或失败)...
    编程 发布于2024-11-08
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-11-08
  • **何时在 JavaScript 中使用 Mouseover 与 Mouseenter?**
    **何时在 JavaScript 中使用 Mouseover 与 Mouseenter?**
    了解 Mouseover 和 Mouseenter 事件之间的区别mouseover 和 mouseenter 事件都响应鼠标光标在元素上的移动。然而,它们之间有一个微妙的区别。Mouseover每次鼠标光标进入或在元素(包括后代)的边界内移动时,都会触发 mouseover 事件元素。这意味着,如...
    编程 发布于2024-11-08
  • 在 Gmail 中使用 PHPmailer 时如何解决“SMTP Connect() Failed”错误?
    在 Gmail 中使用 PHPmailer 时如何解决“SMTP Connect() Failed”错误?
    PHPmailer 中 SMTP 连接失败:解决问题通过 PHPmailer 发送电子邮件时,开发者可能会遇到错误:“Mailer Error: SMTP连接()失败。”这个问题在使用 Gmail 的 SMTP 服务器时经常出现。解决方案在于 Google 实施了新的授权机制 XOAUTH2。要允许...
    编程 发布于2024-11-08
  • 为什么在发出跨域 AJAX 请求时会收到“jQuery XML 错误:\'Access-Control-Allow-Origin\' 标头缺失”?
    为什么在发出跨域 AJAX 请求时会收到“jQuery XML 错误:\'Access-Control-Allow-Origin\' 标头缺失”?
    jQuery XML 错误:'Access-Control-Allow-Origin' 标头丢失在这种情况下,根本问题是 同源策略,出于安全原因限制跨域请求。当向 HTML 页面来源以外的域发出 AJAX 请求时,浏览器将触发 CORS(跨域资源共享)请求。具体错误消息表明目标服务器...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3