博客
关于我
Appium+python自动化13-native和webview切换
阅读量:470 次
发布时间:2019-03-06

本文共 1674 字,大约阅读时间需要 5 分钟。

为什么理解WebView元素是必要的

在现代移动应用开发中,混合式应用(Native + WebView)已经成为主流。对于测试人员来说,最大的挑战在于如何准确定位和操作WebView渲染的屏幕区域。Native组件的元素可以轻松定位和操作,但WebView渲染的区域则完全不同。通过学习如何识别和处理WebView元素,我们可以更高效地完成测试任务。

如何正确获取WebView的上下文

第一步:观察页面元素

使用定位工具(如Android Studio的LayoutInspector)查看页面元素。通常,页面会分为两部分:Native区域和WebView区域。通过观察,可以发现WebView区域内的元素无法通过普通的定位方式识别。

第二步:检查元素属性

在WebView区域内,通常会有一些固定的标识符。例如,class属性可能显示为"WebView",这表明该区域是由WebView渲染的。通过查看元素属性,我们可以确认该区域是否属于WebView。

上下文管理:理解contexts的作用

在Appium中,contexts用于区分不同的应用上下文(environment)。每个上下文代表一个不同的应用或页面。以下是操作步骤:

第一步:获取所有上下文

通过调用driver.contexts获取当前应用的所有上下文列表。列表中通常包含两个项:

  • NATIVE_APP:表示原生应用
  • WEBVIEW_com.xxxx:表示WebView渲染的区域

第二步:验证WebView上下文

如果列表中包含WEBVIEW_com.xxxx项,说明已经成功识别到了WebView上下文。可以通过打印上下文列表来确认这一点。

第三步:切换到WebView上下文

在完成Native操作后,为了操作WebView元素,需要切换到相应的上下文:

driver.switch_to.context(contexts[1])

这里的contexts[1]表示WebView上下文。

如何切回Native上下文

完成WebView操作后,需要切回Native上下文。可以通过以下两种方式实现:

方法一:使用固定的上下文名称

driver.switch_to.context("NATIVE_APP")

方法二:使用上下文列表

driver.switch_to.context(contexts[0])

完整示例代码

以下是完整的代码示例,展示了上下文切换的实际应用:

from appium import webdriverimport timedesired_caps = {    'platformName': 'Android',    'deviceName': '30d4e606',    'platformVersion': '6.0',    'appPackage': 'com.baidu.yuedu',    'appActivity': 'com.baidu.yuedu.splash.SplashActivity'}driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)time.sleep(30)# 切换到图书界面后获取所有的环境contexts = driver.contextsprint(contexts)# 切换到webviewdriver.switch_to.context(contexts[1])# 获取当前的环境,看是否切换成功now = driver.current_contextprint(now)# 切回nativedriver.switch_to.context(contexts[0])

总结

通过上述方法,我们可以轻松地在混合式应用中切换Between Native和WebView上下文。掌握这一技能,对于自动化测试和应用调试都非常有帮助。在实际开发中,确保正确获取WebView上下文是确保测试成功的关键步骤。

转载地址:http://nfmbz.baihongyu.com/

你可能感兴趣的文章
Oracle查询前几条数据的方法
查看>>
oracle树形查询 start with connect by
查看>>
oracle毕业论文题目,历届毕业论文申报题目大全.doc
查看>>
oracle求助---win7下oracle配置相关疑问Starting Oracle Enterprise Manager 10g Database Control ...发生系统错误 5。
查看>>
oracle深度解析检查点
查看>>
oracle用户改名
查看>>
oracle用户解压不了,PLSQL developer 连接不上64位Oracle 的解决方法
查看>>
oracle用户解锁
查看>>
Oracle用游标删除重复数据
查看>>
oracle的内置函数
查看>>
Oracle的存储结构
查看>>
Oracle的聚合函数group by结合CUBE和ROLLUP的使用
查看>>
Oracle监听配置、数据库实例配置等
查看>>
Oracle笔记(十三) 视图、同义词、索引
查看>>
Oracle笔记(十) 约束
查看>>
Oracle系列:安装Oracle RAC数据库(二)
查看>>
oracle系统 介绍,ORACLE数据库管理系统介绍
查看>>
oracle获取数据库表、字段、注释、约束等
查看>>
oracle表空间查询维护命令大全之三(暂时表空间)史上最全
查看>>
oracle表访问方式
查看>>