1
0
Fork 0
mirror of https://github.com/openstf/stf synced 2025-10-04 18:29:17 +02:00
OpenSTF/lib/units/device/plugins/touch.js

142 lines
4.1 KiB
JavaScript

var Promise = require('bluebird')
var syrup = require('syrup')
var monkey = require('adbkit-monkey')
var wire = require('../../../wire')
var devutil = require('../../../util/devutil')
var logger = require('../../../util/logger')
var lifecycle = require('../../../util/lifecycle')
var streamutil = require('../../../util/streamutil')
var SeqQueue = require('../../../wire/seqqueue')
module.exports = syrup.serial()
.dependency(require('../support/adb'))
.dependency(require('../support/router'))
.dependency(require('../resources/remote'))
.dependency(require('./display'))
.dependency(require('./data'))
.define(function(options, adb, router, remote, display, data) {
var log = logger.createLogger('device:plugins:touch')
var plugin = Object.create(null)
var service = {
port: 2820
}
function openService() {
log.info('Launching touch service')
return devutil.ensureUnusedPort(adb, options.serial, service.port)
.timeout(10000)
.then(function() {
return adb.shell(options.serial, [
remote.bin
, '--lib', remote.lib
, '--listen-input', service.port
])
.timeout(10000)
})
.then(function(out) {
lifecycle.share('Touch shell', out)
streamutil.talk(log, 'Touch shell says: "%s"', out)
})
.then(function() {
return devutil.waitForPort(adb, options.serial, service.port)
.timeout(15000)
})
.then(function(conn) {
return Promise.promisifyAll(monkey.connectStream(conn))
})
.then(function(monkey) {
return lifecycle.share('Touch monkey', monkey)
})
}
function modifyCoords(message) {
message.x = Math.floor(message.x * display.width)
message.y = Math.floor(message.y * display.height)
}
return openService()
.then(function(monkey) {
var queue = new SeqQueue()
, pressure = (data && data.touch && data.touch.defaultPressure) || 50
log.info('Setting default pressure to %d', pressure)
plugin.touchDown = function(point) {
modifyCoords(point)
monkey.sendAsync([
'touch down'
, point.x
, point.y
, pressure
].join(' '))
.catch(function(err) {
log.error('touchDown failed', err.stack)
})
}
plugin.touchMove = function(point) {
modifyCoords(point)
monkey.sendAsync([
'touch move'
, point.x
, point.y
, pressure
].join(' '))
.catch(function(err) {
log.error('touchMove failed', err.stack)
})
}
plugin.touchUp = function(point) {
modifyCoords(point)
monkey.sendAsync([
'touch up'
, point.x
, point.y
, pressure
].join(' '))
.catch(function(err) {
log.error('touchUp failed', err.stack)
})
}
plugin.tap = function(point) {
modifyCoords(point)
monkey.sendAsync([
'tap'
, point.x
, point.y
, pressure
].join(' '))
.catch(function(err) {
log.error('tap failed', err.stack)
})
}
router
.on(wire.TouchDownMessage, function(channel, message) {
queue.push(message.seq, function() {
plugin.touchDown(message)
})
})
.on(wire.TouchMoveMessage, function(channel, message) {
queue.push(message.seq, function() {
plugin.touchMove(message)
})
})
.on(wire.TouchUpMessage, function(channel, message) {
queue.push(message.seq, function() {
plugin.touchUp(message)
})
// Reset queue
queue = new SeqQueue()
})
.on(wire.TapMessage, function(channel, message) {
plugin.tap(message)
})
})
.return(plugin)
})