转载地址:http://blog.csdn.net/testman930/article/details/50799532

问题描述

在测APP的业务流,WebView和Native模式耦合在一起。例如:WebView >> Native >> WebView >> 。。。。。。 
Appium貌似有个问题,从WebView切换到NATIVE后,chromedriver可能会把第一个WebView的缓存驻留在内存中,即便用driver.close()方法关闭当前上下文,也无法清除。 
这样会导致进入其他的WebView,读取的还是第一个WebView的内容,导致页面元素无法识别。 
下面是发现问题到解决问题的一个过程,希望能帮助到遇到过同样问题的同行。

第一版代码:可能大多数人开始都会这么写,这样可能导致无法识别到其他窗口WebView的内容。

  1. public void testDemo() {
  2. try {
  3. Log.logInfo("开始切换到WebView模式");
  4. ((AppiumDriver) driver).context("WEBVIEW_com.xx.xx.xx.xx");
  5. Log.logInfo("成功切换到WebView模式,开始查找WebView元素");
  6. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.second > span")).click();
  7. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.last > span")).click();
  8. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > div")).click();
  9. Log.logInfo("开始切换到NATIVE模式");
  10. ((AppiumDriver) driver).context("NATIVE_APP");
  11. } catch (Exception e) {
  12. // anything
  13. }
  14. }

第二版代码:我的思路是想通过正常途径解决问题,把当前WebView的实例赋给临时对象,用完后调用close()方法(quit()会把整个Seesion关闭),还是以失败告终,有点发吼了。

  1. public void testDemo() {
  2. try {
  3. Log.logInfo("开始切换到WebView模式");
  4. AppiumDriver chromeDriver = (AppiumDriver) ((AppiumDriver) driver).context("WEBVIEW_com.xx.xx.xx.xx");
  5. Log.logInfo("成功切换到WebView模式,开始查找WebView元素");
  6. chromeDriver .findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.second > span")).click();
  7. chromeDriver .findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.last > span")).click();
  8. chromeDriver .findElement(By.cssSelector("#myWeidian > div.tpl_part > div")).click();
  9. chromeDriver.close();
  10. Log.logInfo("开始切换到NATIVE模式");
  11. ((AppiumDriver) driver).context("NATIVE_APP");
  12. } catch (Exception e) {
  13. // anything
  14. }
  15. }

第三版代码:软的不行来硬的,放了个绝招,杀chromedriver的进程,还真的成功了,有时候真的需要暴力。。

  1. public void testDemo() {
  2. try {
  3. Log.logInfo("开始切换到WebView模式");
  4. ((AppiumDriver) driver).context("WEBVIEW_com.xx.xx.xx.xx");
  5. Log.logInfo("成功切换到WebView模式,开始查找WebView元素");
  6. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.second > span")).click();
  7. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > ul > li.last > span")).click();
  8. driver.findElement(By.cssSelector("#myWeidian > div.tpl_part > div")).click();
  9. Log.logInfo("开始切换到NATIVE模式");
  10. ((AppiumDriver) driver).context("NATIVE_APP");
  11. Tools.killProcess("chromedriver");
  12. } catch (Exception e) {
  13. Tools.killProcess("chromedriver");
  14. }
  15. }
  16. public static void killProcess(String processName) {
  17. try {
  18. String cmd = isWindows() ? "tskill " + processName : "killall \"" + processName + "\"";
  19. cmdInvoke(cmd);
  20. } catch (Exception e) {
  21. Log.logInfo(e.getMessage());
  22. }
  23. }
  24. public static String cmdInvoke(String cmd) {
  25. String cmdOut = "";
  26. BufferedReader br = null;
  27. try {
  28. Process p = Runtime.getRuntime().exec(cmd);
  29. br = new BufferedReader(new InputStreamReader(p.getInputStream()));
  30. String line = null;
  31. while ((line = br.readLine()) != null) {
  32. cmdOut = line;
  33. }
  34. } catch (Exception e) {
  35. e.printStackTrace();
  36. } finally {
  37. if (br != null) {
  38. try {
  39. br.close();
  40. } catch (Exception e) {
  41. e.printStackTrace();
  42. }
  43. }
  44. }
  45. return cmdOut;
  46. }

解决 hybird 应用中重复获取 WebView,导致页面元素无法识别的问题的更多相关文章

  1. [Android] 获取WebView的页面标题(Title)-----WebChromeClient.onReceivedTitle()方法的重写

    应用开发中需要获取WebView当前页面的标题,可能通过对WebChromeClient.onReceivedTitle()方法的重写来实现 效果图如下: 代码如下: public class Mai ...

  2. js在数组arr中随机获取count数量的元素

    // 在数组arr中随机获取count数量的元素; const getRandomArrayElements = (arr, num) => { // 新建一个数组,将传入的数组复制过来,用于运 ...

  3. 在js中获取到的页面元素为undefined

    在学习js的过程中发现了一个问题就是:在js代码中获取页面元素进行操作的时候发现怎么都没有效果,控制台也不报错,弹出获取的元素结果发现是undefined类型. 后来查找了资料发现:因为我的js是写在 ...

  4. chrome 获取移动端页面元素信息

    一:背景在使用appium进行app端自动化测试的时候,一般使用的是uiautomatorviewer来给页面元素做定位.但如果遇到页面元素类型是webview的时候,则只能定位整个页面,而不能更进一 ...

  5. Appium Inspector定位Webview/H5页面元素

    目录 操作步骤 Python操作该混合App代码 Appium在操作混合App或Android App的H5页面时, 常常需要定位H5页面中的元素, 传统方式是 翻墙 + 使用Chrome://ins ...

  6. Selenium_webdriver获取iframe子页面元素

    有时候我们在定位一个页面元素的时候发现一直定位不了,反复检查自己写的定位器没有任何问题,代码也没有任何问题.这时你就要看一下这个页面元素是否在一个iframe中,这可能就是找不到的原因之一.如果你在一 ...

  7. [bug] VUE 的 template 中使用 ES6 语法导致页面空白

    如果你在 template 中,使用了 es6 及以上的语法,那么,在部分ios.安卓.微信浏览器中,打开页面后显示一片空白内容.如下: <ul id="example-1" ...

  8. react中如何获取onclick事件调用元素的dom对象

    今天终于有时间写博客了, 前几天项目有个需求,我感觉用dom操作兄弟元素实现比较方便,但是前端用的react框架不能用jquery的$(this)获取当前元素,查了好多资料和尝试后写下总结: 在HTM ...

  9. Nginx下完美解决WordPress的伪静态 (wordpress 迁移后 导致 页面404)

    直奔主题 如何设置WordPress在 Nginx下的伪静态 第一步:按照文章名为例,登陆后台按照箭头顺序修改固定连接,点击保存更改 第二步:登陆宝塔面板后台,按照文件路径 找到属于要配置域名的con ...

随机推荐

  1. React系列——react-redux之connect方法解析

      connect简介 前方高能预警,有耐心才能看完文章!! react-redux仅有2个API,Provider和connect,Provider提供的是一个顶层容器的作用,实现store的上下文 ...

  2. landa语法

    sg_orm看当前sql信息 db.IsEnableLogEvent = true; db.LogEventStarting = (sql, pa) => { var t = 0; }; //出 ...

  3. 项目文件不完整。缺少预期导入,DotnetCore如何切换SDK版本

    1. 项目文件不完整.缺少预期导入 如图: 2. 出现原因: SDK版本与项目所需的SDK版本不一致. 3. 解决问题: 3.1 项目所需的SDK版本如何确定? a. 检查.sln文件所在目录是否有: ...

  4. (转)Unity笔记之编辑器(BeginToggleGroup、BoundsField、ColorField) ...

    1. BeginToggleGroup() BeginToggleGroup函数是定义了一个控制范围,可以控制该范围中的GUI是否启用,看下演示代码: [code]csharpcode: using ...

  5. 如何用MathType编辑这三个符号

    MathType是一款专门的公式编辑器,用来编辑数学物理等公式,很多期刊杂志的排版都会用到它.用MathType编辑公式的时候,完全不用考虑学习和上手的过程,打开就可以编辑出你的公式,所以这个工具对于 ...

  6. Linux中buffer/cache,swap,虚拟内存和page ++

    1.Buffer 和 cache Free 命令相对于top 提供了更简洁的查看系统内存使用情况: [apptest@vs022 ~]$ free -m               ——以MB为单位  ...

  7. IOS控件:分歧解决其(UILabel 和 IBAction)

    #import <UIKit/UIKit.h> @interface demo7_dayViewController : UIViewController { // 用来显示程序结果 IB ...

  8. 【BZOJ2653】middle 二分+可持久化线段树

    [BZOJ2653]middle Description 一个长度为n的序列a,设其排过序之后为b,其中位数定义为b[n/2],其中a,b从0开始标号,除法取下整.给你一个 长度为n的序列s.回答Q个 ...

  9. linux一台机器文件传到另一台机器上

    登录一台机器35.73: scp -P 端口 要传的文件 user@xxx.xxx.xxx.xxx:/目标文件夹/ 例子 :scp -r -P3561 /home/ismp/build/app/bec ...

  10. jQuery 对象访问 index([selector|element])

    搜索匹配的元素,并返回相应元素的索引值,从0开始计数. 如果不给 .index() 方法传递参数,那么返回值就是这个jQuery对象集合中第一个元素相对于其同辈元素的位置. 如果参数是一组DOM元素或 ...