Playwright自动化测试工具 java版本

news2024/12/28 3:14:01

Playwright

第一个程序

public static void main(String[] args) {
        Playwright playwright = Playwright.create();
//        Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false));
        BrowserType.LaunchOptions launchOptions = new BrowserType.LaunchOptions();
        launchOptions.setChannel("chrome");
        launchOptions.setHeadless(false);
        Browser browser = playwright.chromium().launch(launchOptions);
        Page page = browser.newPage();
        page.navigate("https://www.baidu.com/");
        String title = page.title();
        String url = page.url();
        System.out.println("page title is : " + title);
        System.out.println("page url is : " + url);
        browser.close();
        playwright.close();
    }

自动捕捉

mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="codegen https://www.baidu.com/"
    
debug
PWDEBUG=1
page.pause();

屏幕录制

package com.pihao.playwright;

import com.microsoft.playwright.*;

import java.nio.file.Paths;

public class TracerInspector {
    public static void main(String[] args) {
        try (Playwright playwright = Playwright.create()) {
            Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions()
                    .setHeadless(false));
            BrowserContext context = browser.newContext();

            //开始录制
            context.tracing().start(new Tracing.StartOptions()
                    .setScreenshots(true)
                    .setSnapshots(true));

            // Open new page
            Page page = context.newPage();
            // Go to https://www.bilibili.com/
            page.navigate("https://www.bilibili.com/");
            // Click text=登录
            page.click("text=登录");
            // Click [placeholder="请输入账号"]
            page.click("[placeholder=\"请输入账号\"]");
            // Fill [placeholder="请输入账号"]
            page.fill("[placeholder=\"请输入账号\"]", "15083601111");
            // Click [placeholder="请输入密码"]
            page.click("[placeholder=\"请输入密码\"]");
            // Fill [placeholder="请输入密码"]
            page.fill("[placeholder=\"请输入密码\"]", "123456");
            // Click text=注册 登录 >> div
            page.click("text=注册 登录 >> div");
            // Click div:has-text("输入手机号,注册账号")
            page.click("div:has-text(\"输入手机号,注册账号\")");
            // Fill [placeholder="请输入手机号"]
            page.fill("[placeholder=\"请输入手机号\"]", "15083601111");
            // Click [placeholder="请输入验证码"]
            page.click("[placeholder=\"请输入验证码\"]");
            // Fill [placeholder="请输入验证码"]
            page.fill("[placeholder=\"请输入验证码\"]", "123456");
            // Click text=登录/注册
            page.click("text=登录/注册");


            //结束录制
            context.tracing().stop(new Tracing.StopOptions()
                    .setPath(Paths.get("trace.zip")));
        }
    }
}

观看录制

mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="show-trace trace.zip"


或者使用这个网址
https://trace.playwright.dev/

打开多个窗口,只要重新new 一个

多个窗口

public static void main(String[] args) {
        Playwright playwright = Playwright.create();
        Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false));
        BrowserContext context = browser.newContext();
        Page page = context.newPage();
        page.navigate("https://www.baidu.com/");
        System.out.println("page title is : " + page.title());
        System.out.println("page url is : " + page.url());

        BrowserContext context2 = browser.newContext();
        Page page2 = context2.newPage();
        page2.navigate("https://www.bilibili.com/");
        System.out.println("page title is : " + page2.title());
        System.out.println("page url is : " + page2.url());

    }

Locators Concept

//single element
Locator locator = page.locator("text = 关于百度");
//如果有多个可以指定哪一个
Locator first = locator.first();
Locator last = locator.last();
first.hover();
first.click();
//multiple element
Locator locator = page.locator("selecst#id选择器的名字");
int count = locator.count();
for (int i = 0; i < count; i++) {
    String textContent = locator.nth(i).textContent();
    System.out.println(textContent);
}
//同样可以获取到下拉框中所有的值
List<String> strings = locator.allTextContents();

Text Selectors

Locator locator = page.locator("text = 关于百度");
//如果有多个可以指定哪一个
Locator first = locator.first();
Locator last = locator.last();
first.hover();
first.click();
//注意:如果没有text=的话,要使用单引号,不然获取不到内容
Locator locator1 = page.locator("text=Your Store");
Locator locator3 = page.locator("'Your Store'");


//选择h2标签,其中内容为New Customer的
Locator locator = page.locator("h2:has-text('New Customer')");
System.out.println(locator.textContent());

//选择class=header 的div标签下的h2标签,并且h2标签中的内容为New Customer
Locator locator2 = page.locator("div.header h2:has-text('New Customer')");
System.out.println(locator2.textContent());

//form表单登入
Locator locator4 = page.locator("from input:has-text('登入')");

Frame Selector

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Handle ShadowDom Elements

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Selecting Visible Elements

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Inspect Playwright Selectors in Chrome Dev Tools

在自动捕捉的模式下,可以在控制台使用playwright 检查dom元素

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

注意:$ 是取多个元素, 是取多个元素, 是取多个元素,只取单个元素

在这里插入图片描述

在这里插入图片描述

Selecting elements that contain other elements

案例一

在这里插入图片描述

在这里插入图片描述

案例二

在这里插入图片描述

通过包含子的选择父的

在这里插入图片描述

在这里插入图片描述

Comma separated CSS Selectors and Xpath Union

在这里插入图片描述

在这里插入图片描述

Relative CSS Selectors in Playwright

left-of

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

right-of

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

above below

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

near

附近多少px元素

在这里插入图片描述

在这里插入图片描述

Nth Element Selector in Playwright

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

XPath Locator in Playwright

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

取第一个和最后一个

在这里插入图片描述

Complex Dynamic WebTable Handle

在这里插入图片描述

这里的scope是td标签中的属性

在这里插入图片描述

automatic login

在这里插入图片描述

在这里插入图片描述

Handle Javascript based popups

在这里插入图片描述

alert prompt confirm

在这里插入图片描述

File Upload in Playwright

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

nginx+lua(openresty) lua-mongodb 安装及使用(四)

前言 前章已经讲述 ua-protobuf 安装及使用 这章主要讲述 openresty 环境下 lua-mongodb 安装及使用 1:环境 ubuntu16(18) mongodb 3.6 2:安装mongodb 3.6 sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 #创…

MySQL的初步认识——【初识MySQL】第一节

MySQL的初步认识——【初识MySQL】第一节 文章目录 MySQL的初步认识——【初识MySQL】第一节MySQL简介简介版本MySQL 5.5MySQL 5.6MySQL 5.7MySQL 8.0 安装建议 MySQL的卸载补充操作详情 小技巧 MySQL5.7.17的下载教训 MySQL简介 简介 MySQL是一个开源的关系型数据库管理系统…

【MongoDB】

目录 MongoDB基本简介 MongoDB基本概念 MongoDB和关系数据库的对比 MongoDB数据类型 MongoDB元素命名规则 MongoDB安装部署 MongoDB配置管理 MongoDB服务管理 MongoDB 多实例配置 基本操作 集合 数据备份与恢复 MongoDB复制集集群部署及管理 MongoDB复制集ReplSe…

[PG]生成表注释SQL

由于PostgreSQL无论是表还是字段的注释是通过 comment on语句来处理的。 可通过如下语句生成表的注释SQL执行语句&#xff1a; SELECT CONCAT(COMMENT ON , "type", 模式., "name", IS ", "comment", ";) AS "comment_sql&q…

软考:中级软件设计师:存储管理,分区存储,页式存储,逻辑地址,物理地址

软考&#xff1a;中级软件设计师:存储管理&#xff0c;分区存储 提示&#xff1a;系列被面试官问的问题&#xff0c;我自己当时不会&#xff0c;所以下来自己复盘一下&#xff0c;认真学习和总结&#xff0c;以应对未来更多的可能性 关于互联网大厂的笔试面试&#xff0c;都是…

idea 启动项目 java: Compilation failed: internal java compiler error

1. 首先查看 项目的 编译的 JDK 版本是否是 匹配了或匹配的 2. 堆分配的内存不足导致&#xff0c;如下图位置 堆 构建程序的 堆大小调大

JMeter分布式压测连接Jenkins生成HTML报告时候报错No such file or directory

JMeter-master机器上没有该文件。从官网下载的JMeter都会有该文件&#xff0c;添加进去即可。

C++罕见的纯虚函数调用异常(_purecall abort)

现象 笔者最近遇到了一个诡异的BUG&#xff0c;析构函数执行期间crash&#xff08;VS2022调试器下表现为abort&#xff09;&#xff0c;调用堆栈最后一级是调用虚函数&#xff0c;所有指针变量正常。 更深层的原因和特征隐藏在虚函数表中。abort发生时&#xff0c;虚函数表中…

LNMP架构及部署、skyuc电影网站部署

目录 一、安装nginx 1、关闭防火墙 2.创建管理nginx用户 3.配置nginx 4.命令优化 5.创建nginx脚本 二、安装mysql数据库 三、安装PHP 1.上传php安装包 2.上传 zend-loader-hph5.6 3.创建用户 四、LNMP平台中部署skyuc电影网站 1.解压 SKYUC.v3.4.2.srouce 2.创建数据…

TCP的3次握手和4次挥手

一、3次握手、4次挥手的简单描述 1、3次握手 三次握手&#xff08;Three-way Handshake&#xff09;指建立一个TCP连接时&#xff0c;需要客户端和服务器总共发送3个包。流程简单描述如下图所示&#xff1a; 在socket编程中&#xff0c;客户端执行connect()时&#xff0c;将触…

仿苹果鼠标滚轮控制 文字渐入 淡出效果

废话不多说&#xff0c;上代码&#xff0c;纯jscss3 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport&…

测试服务器CPU情况

要查看服务器的CPU情况&#xff0c;你可以使用 TOP 命令结合一些选项来执行相应的测试top 命令&#xff1a;运行 top 命令可以实时监视系统的各个进程和 CPU 使用情况在 top 命令的输出中&#xff0c;有几个重要的指标参数可以帮助你了解系统的 CPU 使用情况和进程信息。以下是…

2023.07.05java面试总结

1、springboot 怎么创建新的对象 2、sprintboot 怎么引用第三方类 3、list set map 区别 4、jvm常用配置 5、list怎么排序&#xff0c;怎么按多个字段排序 6、io怎么读取文件 7、angular现在使用什么版本&#xff0c;angular入口 项目结构 8、promise用法 9、和equals …

c++11 标准模板(STL)(std::basic_ostream)(七)

定义于头文件 <ostream> template< class CharT, class Traits std::char_traits<CharT> > class basic_ostream : virtual public std::basic_ios<CharT, Traits> 类模板 basic_ostream 提供字符流上的高层输出操作。受支持操作包含有格式…

安信可蓝牙PB-02 SDK二次开发记录

目录 1.开发环境 & 烧录调试2.例程踩坑(1).编译烧录 watchdog 例程 1.开发环境 & 烧录调试 详细参考下面两篇教程 【安信可PB-01/02模组专题①】PB-01/02模组开发板应用- BLE-UART固件的使用教程 【安信可PB-01/02模组专题③】PB-01/02模组开发板应用-快速入门SDK二次…

代码随想录算法训练营第十天 | 二叉树系列1

二叉树系列1 二叉树理论基础注意点小记二叉树的种类二叉树的存储方式二叉树的遍历 要熟悉自己所用编程语言常用的数据容器的底层实现一定要会自己实现所用数据结构的定义 二叉树的递归遍历递归三部曲前中后序递归遍历前序遍历--我的代码前序遍历--代码随想录的代码中序遍历--我…

【解决】Pyinstaller打包报错IndexError: tuple index out of range

问题 这个问题主要是在Python3.7以上的版本中遇到&#xff0c;用pyinstaller打包的时候发现报错 /usr/local/lib/python3.10/dis.py argval const_list[const_index], IndexError: tuple index out of range解决方案 vim 进入报错的文件&#xff0c;/usr/local/lib/python…

Css 基础:选择器,三大特性

1.emmet的 快速格式化代码 配置 "editor.formatOnType": true, "editor.formatOnSave": true 2.基础选择器 3.复合选择器 4.单行文本垂直居中原理 5.css背景 6.CSS三大特性 层叠性&#xff1a;相同选择器设置相同样式&#xff0c;发生在样式冲突时&#xf…

VUE:el-button里面的倒计时显示,验证码发送后两分钟倒计时

验证码倒计时显示 框架需求样式图代码template部分script部分style部分部分内容解读 框架 UI&#xff1a;elementUI 前端&#xff1a;vue 需求 发送验证码后&#xff0c;2分钟内不可以在发送&#xff0c;button置灰&#xff0c;120s后可以点击重新发送验证码 样式图 代码 …

【算法设计与分析】拉丁矩阵问题——对于给定的m和n,计算出不同的宝石排列方案数。

问题描述 现有n种不同形状的宝石&#xff0c;每种宝石有足够多颗。欲将这些宝石排列成m行n列的一个矩阵&#xff0c;m≤n&#xff0c;使矩阵中每行和每列的宝石都没有相同的形状。试设计一个算法&#xff0c;计算出对于给定的m和n&#xff0c;有多少种不同的宝石排列方案。 数…