内容简介:Appium_调试腾讯订制开发的X5版本webview的关键代码和不同于普通webview设置的地方
=
调试x5的webview报错呀。
感谢作者分享: Appium 微信 webview 的自动化技术 。
=
微信的设置
用微信打开debugx5.qq.com, 这是个微信的x5内核调试页面. 你可以在任何聊天窗口内输入这个网址. 并打开它.
勾选"是否打开TBS内核Inspector调试功能"
使用ChromeDriver编写测试用例
首先安装ChromeDriver
从官方下载或者从你的appium的安装路径里面找chromedriver. 在appium的执行日志里面其实也会打印chromedriver的路径的
然后在电脑上启动它, 设置好端口
chromedriver --url-base=wd/hub --port=8000
可以使用selenium或者appium的客户端去编写测试用例.
如下是我的scalatest的测试用例. 大家可以自己用其他的语言实现
test("test chromedriver weixin") { val options = new ChromeOptions() options.setExperimentalOption("androidPackage", "com.tencent.mm") options.setExperimentalOption("androidUseRunningApp", true) options.setExperimentalOption("androidActivity", ".plugin.webview.ui.tools.WebViewUI") options.setExperimentalOption("androidProcess", "com.tencent.mm:tools") val capability = DesiredCapabilities.chrome() capability.setCapability(ChromeOptions.CAPABILITY, options) val url = "http://127.0.0.1:8000/wd/hub" val driver = new AndroidDriver[WebElement](new URL(url), capability) driver.get("https://testerhome.com/topics/6954") println(driver.getPageSource) driver.quit() }
使用appium编写测试用例
有人会经常问为什么android上appium不能自动化微信webview, 其实是可以的. 主要是目前的appium有个bug导致的.
在appium中context的切换时, 没有带上一个关键的androidProcess配置导致的.
他会导致appium识别webview的时候, 把com.tencent.mm:tools的webview识别成com.tencent.mm的webview. 从而导致context切换失败.
正确的用appium测试微信h5的方法如下
test("test weixin h5") { val capability = new DesiredCapabilities() capability.setCapability("app", "") capability.setCapability("appPackage", "com.tencent.mm") capability.setCapability("appActivity", ".ui.LauncherUI") capability.setCapability("deviceName", "emulator-5554") capability.setCapability("fastReset", "false") capability.setCapability("fullReset", "false") capability.setCapability("noReset", "true") //capability.setCapability("unicodeKeyboard", "true") //capability.setCapability("resetKeyboard", "true") //关键是加上这段 val options = new ChromeOptions() options.setExperimentalOption("androidProcess", "com.tencent.mm:tools") capability.setCapability(ChromeOptions.CAPABILITY, options) val url = "http://127.0.0.1:4723/wd/hub" val driver = new AndroidDriver[WebElement](new URL(url), capability) println(driver.getPageSource) driver.findElementByXPath("//*[@text='我']").click driver.findElementByXPath("//*[@text='收藏']").click driver.findElementByXPath("//*[contains(@text, '美团外卖')]").click println(driver.getPageSource) println(driver.getContextHandles) driver.context("WEBVIEW_com.tencent.mm:tools") println(driver.getPageSource) }
最关键的就是这句
val options = new ChromeOptions() options.setExperimentalOption("androidProcess", "com.tencent.mm:tools") capability.setCapability(ChromeOptions.CAPABILITY, options)
后记
之前测试加上ChromeOptions配置的时候没有成功, 我以为是appium不支持ChromeOptions, 就给appium-android-driver提交了一个PR
后来jlipps提醒了我一下
我就又追查了几遍, 最后发现是我本地安装appium时候加上的http_proxy环境变量干扰了ChromeDriver的执行.
Appium其实是支持ChromeOptions的
结论也就是现在的Appium其实是可以完美的做微信自动化的
我在想我是不是国内第一个提供微信webview自动化方法的人
借鉴此思路的同学转发请注明原链. https://testerhome.com/topics/6954
=
=
=
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 为htmlpurifier订制xss过滤
- 数据结构等同于大型数据集的map(在java中)
- 听说程序员的朋友圈都是这样的?真的不同于凡人
- 俄罗斯要求iPhone须预装本国软件,苹果称等同于越狱无法接受
- 常规的haskell代数数据类型等同于上下文无关语法? GADTS怎么样?
- GOLAMG-5 type 不同于C/C++ typedef,切片底层是指针域的函数指针
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。