百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

微软在Web自动化测试框架上的左直拳——Playwright

yuyutoo 2025-01-31 16:03 7 浏览 0 评论

背景

今年微软在Web端投入不少,先有Edge浏览器全面转向Chromium,现在又开发了自己的Web测试框架。肯定很多人想问,有了Puppeteer为啥还需要Playwright。实际上Playwright就是Puppeteer延伸,如果比较Playwright和Puppeteer的贡献者页面,你会注意到Puppeteer的前两名贡献者现在都在Playwright上工作。 Puppeteer团队实际上从Google移至Microsoft,并成为Playwright团队。

Playwright的最大与众不同之处在于直驱跨浏览器的支持。它可以驱动Chromium,WebKit(用于Safari的浏览器引擎)和Firefox。



项目的Github地址是:https://github.com/microsoft/playwright


Puppeteer与Playwright在架构上基本上是一致的。而Selenium是通过不同的WebDriver来与浏览器进行通讯。



比较重要区别就是Playwright的目录是在做一整个测试框架,而不仅仅是一自动化框架。


Playwright 基于Puppeteer,但又向Selenium取了经,它能使用熟悉的npm语法快速轻松地安装,并使用JavaScript来构建网络应用程序自动化和测试。它可与更多浏览器一起使用,并支持Edge等基于Chromium的浏览器,以及Firefox和Apple的WebKit。但它也有它的劣势使,用的人暂时不是很多,生态还不是很完整。不过从微软的投入上来看,Playwright还是很有发展前途的。

入手

Playwright入门就像创建新的Node.js项目一样容易。


首先,你必须要有Node.js,由于Playwright使用Node,因此您可以在CI / CD中任何一环集成它,这使其成为GitHub操作的一部分,可在应用整个软件开发周期中。 您只需要一个npm命令,即可安装Playwright软件包以及所有受支持浏览器的二进制文件。



安装完成后,您可以使用JavaScript或TypeScript创建自动化脚本来调用Playwright API。 这些都是异步调用,需要使用await语句来管理它们的promise。

const { webkit } = require('playwright');

(async () => {
  const browser = await webkit.launch();
  const page = await browser.newPage();
  await page.goto('http://whatsmyuseragent.org/');
  await page.screenshot({ path: `example.png` });
  await browser.close();
})();

Context支持

Playwright有一个非常重要的功能,是它对浏览器Context的支持。 它能够在单个浏览器实例中运行隔离的操作,因此您可以设置多个Context以同时测试多个Web页面。 在每个Context中创建页面。 页面支持它们自己的单击交互,并且可以并行监视。 进入页面后,可以使用CSS或XPath选择器,HTML属性或文本,以不同的方式查找与之交互的内容。 如果您熟悉Selenium,则应该浏览熟悉的页面,并具有等待页面完全加载或在单页面Web应用程序中呈现动态内容的附加功能。

Playwright有很多功能,它可以替代Selenium来测试浏览器应用程序。 随着Microsoft不断在Edge中添加F12开发人员工具,Playwright也同样被赋予了新功能,这些功能让你在测试Web页面的时候有更多的选择。

多语言绑定

微软最近为喜欢用Python而不是JavaScript进行测试的开发人员发布了新版本的Playwright。 这是一个非常重要的功能,因为许多现有的Selenium测试框架都是基于Python的,它允许您使用Python丰富的Analysis功能和多样的生态将测试和测试结果整合起来。

Playwright还提供了用于C#的语言绑定,因此您可以将Playwright带入ASP.NET或其他.NET工具的现有测试框架中。 您不必更改引入新工具的工作方式,Microsoft承诺为Java和Ruby提供更多语言绑定。 Playwright文档指出,它旨在支持任何语言的绑定,因此在将来会有更多的前景。 有了GitHub上的所有代码,您就有机会为自己选择的测试语言创建自己的绑定,并将其作为请求请求提交给项目。

相关推荐

YAML配置文件简介及使用(yaml 配置)

简介YAML是"YAMLAin'taMarkupLanguage"(YAML不是一种标记语言)的缩写。相比JSON格式的方便。...

教你如何解决最常见的58种网络故障排除方法

1.故障现象:网络适配器(网卡)设置与计算机资源有冲突。分析、排除:通过调整网卡资源中的IRQ和I/O值来避开与计算机其它资源的冲突。有些情况还需要通过设置主板的跳线来调整与其它资源的冲突。2.故障现...

一分钟带你了解服务器网卡(服务器网卡怎么用)

今天小编和大家聊一下服务器的网卡。什么是网卡?简单说网卡就是计算机与局域网互连的设备。计算机主要通过网卡接入网络。网卡又称为网络适配器或网络接口卡NIC(NetworkinterfaceCard)...

linux文件之ssh配置文件的含义与作用

ssh远程登录命令是操作系统(包括linux和window系统)下常用的操作命令,可以帮助用户,远程登录服务器系统,查看,操作系统相关信息。linux系统对于ssh命令有专门保存其相关配置的目录和文件...

Cilium 官方文档翻译 - IPAM(二)Kubernetes Host模式

KubernetesHostScopeciliumIPAM的kuberneteshost-scope模式通过选项ipam:kubernetes开启,将集群IP地址分配委托给每个独立的节点,并...

域名劫持跳转,域名劫持跳转的解决办法只需5步

简单来说,域名劫持就是把原本准备访问某网站的用户,在不知不觉中,劫持到仿冒的网站上,例如用户准备访问某家知名品牌的网上商店,黑客就可以通过域名劫持的手段,把其带到假的网上商店,同时收集用户的ID信息和...

Linux基本命令(linux基本命令总结)

...

Linux 磁盘和文件系统管理(linux磁盘管理fdisk)

1检测并确认新硬盘...

windows host文件怎么恢复?局域网访问全靠这些!

windowshost文件怎么恢复?windowshost文件是常用网址域名及其相应IP地址建立一个关联文件,通过这个host文件配置域名和IP的映射关系,以提高域名解析的速度,方便局域网用户使用...

Nginx配置文件详解与优化建议(nginx 配置详解)

1、概述今天来详解一下Nginx的配置文件,以及给出一些配置建议,希望能对大家有所帮助。...

Mac电脑hosts文件锁定,如何修改hosts文件权限

有时候我们需要修改hosts文件,但是网上很多教程都行不通,使用sudo命令也不行。其实有一个很简单的方法。打开终端命令行,使用如下命令即可:sudochflags-hvnoschg/etc/...

windows电脑如何修改hosts文件?(windows 修改hosts文件)

先来简单说下电脑host的作用hosts文件的作用:hosts文件是一个用于储存计算机网络中各节点信息的计算机文件;作用是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,当用户在浏览器中...

Vigilante恶意软件行为怪异:修改Hosts文件以阻止受害者访问盗版网站

Sophos刚刚报道了一款名叫Vigilante的恶意软件,但其行为却让许多受害者感到不解。与其它专注于偷密码、搞破坏、或勒索赎金的恶意软件不同,Vigilante会通过修改Hosts文件...

hosts文件无法修改几种现象和解决方法

第一种、hosts文件修改完不是直接保存而是弹出另存为窗口解决:1、右击hosts文件——属性——把“只读”前面勾去掉。第二种、打开hosts文件时提示“你没有权限打开该文件,请向文件的所有者或管理员...

hosts文件位置在哪里,教你hosts文件位置在哪里

Hosts是一个没有扩展名的系统文件,其基本作用就是将一些常用的网址域名与其对应的IP地址建立一个关联"数据库",当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的I...

取消回复欢迎 发表评论: