news 2026/6/23 23:07:49

Playwright 移动端测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Playwright 移动端测试

Playwright 移动端测试(2025 年最新版)

Playwright 原生支持移动端浏览器模拟(Mobile Emulation)和真实 Android 设备测试,无需额外工具即可覆盖手机/平板场景。核心优势:一套代码跨桌面 + 移动浏览器运行,支持触屏手势、横竖屏、地理位置、设备特性等。

1.最常用方式:浏览器模拟移动设备(Emulation)

无需真实设备,速度快,适合 90% 的移动端测试场景。

在 playwright.config.ts 中定义项目

import{defineConfig,devices}from'@playwright/test';exportdefaultdefineConfig({projects:[// 桌面 Chrome{name:'Desktop Chrome',use:{...devices['Desktop Chrome']}},// iPhone 示例{name:'iPhone 14',use:{...devices['iPhone 14']}},{name:'iPhone 14 Landscape',use:{...devices['iPhone 14 landscape']}},// Android 示例{name:'Pixel 7',use:{...devices['Pixel 7']}},// iPad 示例{name:'iPad Pro',use:{...devices['iPad Pro 11']}},],});

Playwright 内置 100+ 设备模型(devices.ts 源文件),常用:

  • iPhone 13/14/15(包括 Pro/Max、landscape)
  • Pixel 5/7
  • Galaxy S23
  • iPad Air/Mini/Pro

运行移动端测试

npx playwrighttest--project="iPhone 14"# 只跑 iPhonenpx playwrighttest--project="Pixel 7"npx playwrighttest# 默认并行跑所有项目
2.测试代码示例(自动适配移动端)
import{test,expect}from'@playwright/test';test('移动端首页响应式验证',async({page})=>{awaitpage.goto('https://your-app.com');// 移动端特有:验证视口大小(自动由设备配置设置)constviewport=page.viewportSize();console.log('当前视口:',viewport);// e.g., { width: 390, height: 844 }// 验证移动端菜单(汉堡菜单)awaitexpect(page.getByRole('button',{name:'菜单'})).toBeVisible();// 模拟触屏点击(等同 click(),但更真实)awaitpage.getByRole('button',{name:'菜单'}).tap();// 模拟手势:滑动(swipe)awaitpage.touchscreen.tap(200,600);// 触摸起点awaitpage.touchscreen.touchMove(200,200);// 向上滑动// 验证横竖屏切换awaitpage.setViewportSize({width:844,height:390});// 切换到横屏awaitexpect(page.getByText('横屏布局')).toBeVisible();});
3.移动端特有功能
// 模拟地理位置test.use({geolocation:{longitude:116.397,latitude:39.909},// 北京permissions:['geolocation'],});// 模拟网络(离线/慢网)test.use({offline:true,// 离线模式// 或慢网javaScriptEnabled:true,// 自定义:通过 context 设置});// 触屏手势(touchscreen)awaitpage.touchscreen.tap(x,y);awaitpage.touchscreen.touchMove(x,y);awaitpage.touchscreen.touchEnd();// 捏合缩放(pinch zoom)awaitpage.touchscreen.touchStart(x1,y1,x2,y2);// 两指
4.真实 Android 设备测试(高级)

Playwright 支持直接连接真实 Android 手机(无需 Appium)。

前提

  • Android 设备开启 USB 调试。
  • 安装 Android SDK Platform-Tools(adb)。

配置示例

import{android}from'@playwright/test';test('真实 Android 设备',async()=>{const[device]=awaitandroid.devices();// 自动发现连接设备constcontext=awaitdevice.launchBrowser();constpage=awaitcontext.newPage();awaitpage.goto('https://your-app.com');awaitpage.screenshot({path:'real-android.png'});awaitcontext.close();});
5.最佳实践总结
  • 优先使用设备模拟(devices[‘iPhone 14’] 等),速度快、覆盖广。
  • 多项目并行:在 config 中定义多个移动设备项目,CI/CD 自动覆盖。
  • 响应式断言:根据 viewportSize() 或设备名动态断言不同布局。
  • 截图对比:移动端测试建议开启screenshot: 'on',失败时对比视觉差异。
  • 真实设备:仅在需要测试硬件特性(如摄像头、传感器)时使用。

运行示例:

npx playwrighttest--project="iPhone 14"--headed# 可视化看移动端效果

移动端测试在 Playwright 中实现非常优雅,一套代码覆盖桌面 + 多款手机/平板。官方设备列表:https://playwright.dev/docs/emulation#devices

如果需要完整响应式测试示例(如媒体查询断言)、自定义设备配置,或真实 Android 连接步骤,随时告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 19:37:49

ECharts 饼图(Pie Chart)教程

ECharts 饼图(Pie Chart)教程 ECharts 的饼图(series.type ‘pie’)主要用于展示数据在总体中的占比比例,支持实心饼图、圆环图(南丁格尔图/玫瑰图)、多层嵌套等变体。数据通过 data 数组中的…

作者头像 李华
网站建设 2026/6/23 11:47:49

Open-AutoGLM日志加密部署难题:90%团队忽略的2个致命风险点

第一章:Open-AutoGLM 日志数据加密存储在 Open-AutoGLM 系统中,日志数据的安全性至关重要。为防止敏感信息泄露,系统采用端到端加密机制对日志进行安全存储。所有日志在写入磁盘前均经过加密处理,确保即使存储介质被非法获取&…

作者头像 李华
网站建设 2026/6/23 19:53:25

精密机械工厂6个研发如何共享一台SolidWorks云工作站

在精密机械制造行业,产品研发效率与协同能力直接决定市场竞争力。当6名工程师需要共享SolidWorks云工作站时,可借助智能共享云桌面,通过以下综合方案实现共享一台SolidWorks云工作站的目标,该方案涵盖硬件配置、资源管理、软件部署…

作者头像 李华
网站建设 2026/6/23 19:53:52

Open-AutoGLM监控总失效?99%人忽略的3个配置陷阱

第一章:Open-AutoGLM异常访问监控配置在部署 Open-AutoGLM 服务时,保障系统安全与稳定性至关重要。异常访问监控是及时发现潜在攻击、滥用行为或系统故障的关键机制。通过合理配置日志采集、访问频率限制和行为分析规则,可有效识别并阻断异常…

作者头像 李华
网站建设 2026/6/22 19:59:33

LangFlow静态站点生成(SSG)可行性探讨

LangFlow静态站点生成(SSG)可行性探讨 在AI应用开发日益普及的今天,越来越多团队希望快速构建、展示并共享基于大语言模型的工作流。然而,传统的LangChain项目往往依赖复杂的代码结构和持续运行的服务端环境,使得非技术…

作者头像 李华
网站建设 2026/6/23 19:55:42

Linux 如何设置开机自启:全面指南!

在日常运维和开发中,我们经常希望某些程序或服务在系统启动时自动运行,比如 Web 服务、数据库、监控脚本、定时任务等。本文将详细介绍在 Linux 系统中设置开机自启的常见方法,适用于常见发行版如 CentOS、Ubuntu、Debian 等。 一、使用 syst…

作者头像 李华