STF adb远程链接需要手动授权的问题

问题描述
  1. 因为我需要在docker里面调用设备来执行自动化测试,因此我需要通过adb connect IP:PROT来链接设备,但是因为STF执行这个命令的时候,需要手动授权接受才可以在远程电脑上授权使用,否则不可以使用。
  2. 因此我通过debug发现来授权步骤实际在socket里面的,因此做了以下修改.
  3. 文件地址: lib/units/websocket/index.js#adb keys confirm
  4. 删除socket.emit(‘adb keys confirm’,{})
  5. 然后复制user.keys.adb.accept的代码到这里来,实现默认授权
  6. 完整代码:
.on(wire.JoinGroupByAdbFingerprintMessage, function(channel, message) {
        log.info('adb keys confirm 张沛', message)
        log.info('adb keys user 张沛', user)
        var data = {
          title: message.comment
          , fingerprint: message.fingerprint
        }
        log.info('接受user.keys.adb.accept data', data)
        return dbapi.lookupUsersByAdbKey(data.fingerprint)
          .then(function(cursor) {
            return cursor.toArray()
          })
          .then(function(users) {
            log.info('接受users', users)
            if (users.length) {
              log.info('接受users.length data', users.length)
              throw new dbapi.DuplicateSecondaryIndexError()
            }
            else {
              log.info('接受adbkey', user.email)
              log.info('接受data.title', data.title)
              log.info('接受key.fingerprint', data.fingerprint)
              return dbapi.insertUserAdbKey(user.email, {
                title: data.title
                , fingerprint: data.fingerprint
              })
            }
          })
          .then(function() {
            socket.emit('user.keys.adb.added', {
              title: data.title
              , fingerprint: data.fingerprint
            })
          })
          .then(function() {
            push.send([
              user.group
              , wireutil.envelope(new wire.AdbKeysUpdatedMessage())
            ])
          })
          .catch(dbapi.DuplicateSecondaryIndexError, function() {
            // No-op
          })
      })
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值