Appium 解决微信公众号、小程序切换 webview 后无法定位元素的问题

本文介绍如何使用Appium进行微信小程序的自动化测试,包括设置WebDriver参数、切换WebView上下文及定位元素等关键技术点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如何切换webview进入小程序请参考https://testerhome.com/topics/12003

脚本思路:
进入webview后会存在多个handle同Web页签一样,获取所有的handle,然后在遍历所有的handle,通过switch_to_window进行handle切换,当某个handle可以定位到我们需要定位的元素时,然后我们就可以进行之后的自动化操作了!

开启bug网址:debugx5.qq.com

#coding=utf-8
from appium import webdriver
import time,os,re
from appium.webdriver.common.touch_action import TouchAction


desired_caps = {}
desired_caps['platformName'] = 'Android'    
desired_caps['deviceName'] = 'Android001'   
desired_caps['unicodeKeyboard'] = True      
desired_caps["resetKeyboard"] = True        
desired_caps["newCommandTimeout"]=30       
desired_caps['fullReset'] = 'false'     
desired_caps['appPackage'] = 'com.tencent.mm'           
desired_caps['appActivity'] = 'com.tencent.mm.ui.LauncherUI'        
desired_caps['recreateChromeDriverSessions'] = True
desired_caps['noReset'] = True
desired_caps['newCommandTimeout'] = 10
desired_caps['chromeOptions']={'androidProcess': 'com.tencent.mm:appbrand0'}
driver = webdriver.Remote(command_executor = 'http://127.0.0.1:4723/wd/hub',desired_capabilities = desired_caps)  
time.sleep(2)
time.sleep(1)
driver.implicitly_wait(10)
driver.find_element_by_name('发现').click()
time.sleep(1)
driver.swipe(100,1200,100,900)
driver.find_element_by_name('小程序').click()
driver.find_element_by_name('美团外卖').click()
time.sleep(2)
contexts = driver.contexts
print contexts
time.sleep(2)
driver.switch_to.context('WEBVIEW_com.tencent.mm:appbrand0')
print '切换成功'
print driver.current_context
all_handles = driver.window_handles
print len(all_handles)
for handle in all_handles:
    try:
        driver.switch_to_window(handle)
        print driver.page_source
        driver.find_element_by_css_selector('.filter-select.flex-center')    #定位“筛选 ”按钮
        print '定位成功'
        break
    except Exception as e:
        print e
driver.find_element_by_css_selector('.filter-select.flex-center').click()
time.sleep(5)
driver.quit()
### 使用Appium进行微信小程序的功能测试 #### 背景概述 Appium 是一种开源的自动化测试工具,能够支持多平台的应用程序测试,包括 iOS 和 Android 应用[^3]。然而,由于微信小程序运行在一个特殊的环境中(即微信客户端内部),传统的 Appium 测试方式无法直接应用于微信小程序。为了实现对微信小程序的有效测试,开发者通常会结合特定的技术手段来完成。 --- #### 技术方案分析 ##### 1. 微信官方提供的 Mini Program DevTools 支持 微信提供了专门的小程序调试工具——Mini Program DevTools,该工具允许开发者通过 WebSocket 或者其他协议与目标设备通信并捕获页面数据。虽然这并非传统意义上的 UI 自动化测试,但它可以作为辅助手段用于验证某些逻辑行为[^4]。 ##### 2. 基于 WebView 的间接测试方法 部分情况下,可以通过模拟 WebView 中的行为来进行有限度的交互操作。具体来说,在安卓平台上,如果能获取到嵌入式的 Webview 控件,则可利用 Selenium WebDriver API 来控制这些控件;而在 iOS 上则相对复杂一些,可能需要用到 XCUITest 配合 JavaScript 注入的方式执行脚本[^1]。 ##### 3. 第三方插件扩展能力 目前存在针对 Appium 扩展的支持微信小程序自动化的第三方库或插件,比如 `appium-wechat` 这样的项目尝试解决这一难题。这类工具一般通过对底层通讯机制的研究实现了更深层次集成可能性[^2]: - **安装必要的依赖项** 确保已经正确配置好基础环境之后还需要额外引入相关模块: ```bash npm install appium --save-dev npm install wd --save-dev ``` - **编写初始化代码片段** 下面展示了一个简单的例子说明如何启动 session 并连接至指定包名的服务端口上: ```javascript const { remote } = require('webdriverio'); (async () => { const opts = { capabilities: { platformName: 'Android', deviceName: 'emulator-5554', // 替换为实际设备名称或者序列号 automationName: 'UiAutomator2', appPackage: 'com.tencent.mm', // 微信应用包名 appActivity: '.ui.LauncherUI' // 启动入口 activity 名称 } }; let client; try { client = await remote(opts); console.log(await client.getWindowSize()); // 更加复杂的业务流程处理... } finally { if (client) await client.deleteSession(); } })(); ``` 上述示例仅展示了基本框架结构,并未涉及具体的定位策略以及动作触发等内容。 --- #### 注意事项 尽管技术理论上可行,但在实践过程中仍需注意以下几点限制条件: - **权限约束**:出于安全考虑,许多敏感接口会被屏蔽掉访问权限; - **版本兼容性**:不同版本之间可能存在差异较大的表现形式; - **性能开销**:频繁调用远程服务可能会带来一定延迟影响效率。 --- ### 结论 综上所述,要成功实施基于 Appium 的微信小程序功能测试工作流并不简单直截了当,往往需要综合运用多种技术和资源才能达成预期效果。随着社区不断进步发展,未来或许会有更加成熟稳定的产品问世满足此类需求。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值