Appium Appium 版本 1.4.16,Android 设备固件 7.x,执行脚本时,报错

Z · January 18, 2017 · Last by 独行数息 replied at April 18, 2017 · 1836 hits

使用语言:python
报错如下:
WebDriverException: Message: A new session could not be created. (Original error: Could not extract PIDs from ps output. PIDS: [], Procs: ["bad pid 'uiautomator'"])

这个是因为appium版本1.4.16 使用的 uiatumator1.0不支持的原因导致?如果不升级appium版本,是否有解决方案?

共收到 2 条回复 时间 点赞

uiautomator1.0应该是不支持7.0,不升版本就换用uiautomator2.0吧。

—— 来自TesterHome官方 安卓客户端

原因:
1. adb.js 中1035 行this.shell("ps '" + name + "'", function (err, stdout) {
对应执行的指令是ps 'uiautomator', Android7不支持这个指令格式,所以执行结果是bad pid 'uiautomator'
目前Appium未对此进行处理,所以需要修改此指令的执行方式
即将
this.shell("ps '" + name + "'", function (err, stdout) {
if (err) return cb(err);
替换成
this.shell_grep("ps", name, function (err, stdout) {

if (err) {

logger.debug("No matching processes found");
return cb(null, []);

}

并增加上面用到的shell_grep函数:
ADB.prototype.shell_grep = function (cmd, grep, cb) {
if (cmd.indexOf('"') === -1) {
cmd = '"' + cmd + '"';
}
var execCmd = 'shell ' + cmd + '| grep ' + grep;
this.exec(execCmd, cb);

};

需要 Sign In 后方可回复, 如果你还没有账号请点击这里 Sign Up