webview – 使用Appium for Automation访问React元素

前端之家收集整理的这篇文章主要介绍了webview – 使用Appium for Automation访问React元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在使用Appium来测试混合Android应用程序,包括NATIVE和WEBVIEW上下文之间的频繁转换.这些Web视图是使用React Libraries开发的.

To my understanding and correct me if I am wrong,07000
is that it creates a Virtual DOM using the real DOM and generates a
dynamic class name corresponding to those in the javascript. The 07001 provides efficient way to differentiate the objects
using those auto generated class names.

我面临的问题是使用Appium我无法使用任何findElementsBy方法访问这些webview中的元素.在生成的每个新构建上,React都会更改类名,这个名称只是我们可以真正依赖的UIAutomator可见的参数.

  1. Is there a way so that I can refactor these auto-generated class names to some sensible names using the React library itself?

chrome inspect在我的应用程序中提供了webview的详细信息:

<div class="_32f8NoUfyUtNSxo3w4Ptbp" data-reactid=".0.1.$=13:0.0.0">…</div>
  1. Any ideas on how to access the actual DOM elements using Appium for this case?

信息:WebView.setWebContentsDebuggingEnabled(true)在应用程序代码中设置.

非常感谢这里的任何线索.

基于此链接https://github.com/facebook/react-native/issues/7135

此问题的解决方法:在视图上使用accessible和accessibleLabel

accessiblity标签上的DOC:https://facebook.github.io/react-native/docs/accessibility.html#accessibilitylabel-ios-android

在我的本机组件上:

<TextInput accessible={true} accessibilityLabel={'Tap Me'}></TextInput>

在我的脚本测试:

mobileElement = find_Element(accessibilty_id,"Tap Me")
mobileElement.send_keys "hello world"

猜你在找的React相关文章