通用技术 使用 chrome remote debug protocol 爆破 crosswalk android app 失败

恒温 · 2015年05月30日 · 最后由 恒温 回复于 2015年05月30日 · 2046 次阅读

Chromedriver 能对 webview 进行自动化测试或者 chrome 浏览器的检查设备能调试 webview 的原因在于,当打开 webview 的时候,
会有一个调试的 socket 生成,一般是 webview_devtools_remote_pid 或者 chrome_devtools_remote。但是 crosswalk 是自定义的 xxxx_devtools_remote。

悲剧的是 ChromeDriver 写死了 chrome_devtools_remote。所以导致无法使用 ChromeDriver 来自动化 crosswalk 的 webview, Appium 自然也无力了。
不过听说 crosswalk 也在出 driver,说不定过段时间就可以用上了。

package.json


{
  "name": "crosswalk_app_test",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "dependencies": {
     "chrome-remote-interface": "0.7.0",
     "appium-adb": "1.7.5",
     "npmlog": "~1.1.0",
     "date-utils": "~1.2.16",
     "winston": "~0.9.0"
  },
  "license": "ISC"
}

test.js

var Chrome = require('chrome-remote-interface'),
  logFactory = require('./logger.js'),
  logger = null,
  adb = null;


logFactory.init({"loglevel": "debug"});
logger = logFactory.get("Test");

var ADB = require('./adb.js');

var sleep = function (milliSeconds) {
  var startTime = new Date().getTime();
  while (new Date().getTime() < startTime + milliSeconds);
};

ADB.createADB({}, function (e, _adb) {
  if (e) return;
  adb = _adb;
});

adb.startApp(
  {
    pkg: "com.jiudao.ccare",
    activity: ".MainActivity",
    waitPkg: "com.jiudao.ccare",
    waitActivity: ".MainActivity"
  }, function () {
    sleep(10000);
    adb.forwardAbstractPort(9222, "com.jiudao.ccare_devtools_remote", function () {
    });
    Chrome(function (chrome) {
      with (chrome) {
        Network.enable();
        Page.enable();
        once('ready', function () {
          chrome.send('Runtime.evaluate', {expression: "document.getElementById('username').value='hello'"}, logger.debug);
          chrome.send('Runtime.evaluate', {expression: "document.getElementsByTagName('input')[1].value=1"}, logger.debug);

        });
      }
    }).on('error', function () {
      console.error('Cannot connect to Chrome');
    });
  });

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 5 条回复 时间 点赞

之前研究过用 chrome 插件操作过页面元素,还能用到 app,这么高级?请问下如何使用,或者有没有这样的教程 url

是说要 inspect 基于 crosswalk 的 app 吗?

#2 楼 @luis inspect 没有问题,chrome 本来可以用的。 只是因为 devtools_remote 名字不一样。没法用 chromedriver 来做。

在中间做个代理转换如何? 让调用双方看起来调用的是相同的接口

#4 楼 @seveniruby adb forward 了 就已经是相同接口了。

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册