mirror of
https://github.com/openstf/stf
synced 2025-10-04 10:19:30 +02:00
Clean up the owner plugin (now called 'group').
This commit is contained in:
parent
4676af51d7
commit
d5c96dc50d
6 changed files with 220 additions and 160 deletions
|
@ -27,7 +27,7 @@ module.exports = function(options) {
|
||||||
.dependency(require('./device/plugins/touch'))
|
.dependency(require('./device/plugins/touch'))
|
||||||
.dependency(require('./device/plugins/install'))
|
.dependency(require('./device/plugins/install'))
|
||||||
.dependency(require('./device/plugins/forward'))
|
.dependency(require('./device/plugins/forward'))
|
||||||
.dependency(require('./device/plugins/owner'))
|
.dependency(require('./device/plugins/group'))
|
||||||
.define(function(options, solo) {
|
.define(function(options, solo) {
|
||||||
if (process.send) {
|
if (process.send) {
|
||||||
// Only if we have a parent process
|
// Only if we have a parent process
|
||||||
|
|
146
lib/roles/device/plugins/group.js
Normal file
146
lib/roles/device/plugins/group.js
Normal file
|
@ -0,0 +1,146 @@
|
||||||
|
var events = require('events')
|
||||||
|
|
||||||
|
var Promise = require('bluebird')
|
||||||
|
var syrup = require('syrup')
|
||||||
|
|
||||||
|
var logger = require('../../../util/logger')
|
||||||
|
var wire = require('../../../wire')
|
||||||
|
var wireutil = require('../../../wire/util')
|
||||||
|
var grouputil = require('../../../util/grouputil')
|
||||||
|
var lifecycle = require('../../../util/lifecycle')
|
||||||
|
|
||||||
|
module.exports = syrup.serial()
|
||||||
|
.dependency(require('./identity'))
|
||||||
|
.dependency(require('./input'))
|
||||||
|
.dependency(require('../support/router'))
|
||||||
|
.dependency(require('../support/push'))
|
||||||
|
.dependency(require('../support/sub'))
|
||||||
|
.dependency(require('../support/channels'))
|
||||||
|
.define(function(options, identity, input, router, push, sub, channels) {
|
||||||
|
var log = logger.createLogger('device:plugins:group')
|
||||||
|
, currentGroup = null
|
||||||
|
, emitter = new events.EventEmitter()
|
||||||
|
|
||||||
|
function joinGroup(newGroup, timeout) {
|
||||||
|
if (currentGroup) {
|
||||||
|
return Promise.reject(new grouputil.AlreadyGroupedError())
|
||||||
|
}
|
||||||
|
|
||||||
|
currentGroup = newGroup
|
||||||
|
|
||||||
|
log.info('Now owned by "%s"', currentGroup.email)
|
||||||
|
log.info('Subscribing to group channel "%s"', currentGroup.group)
|
||||||
|
|
||||||
|
channels.register(currentGroup.group, timeout)
|
||||||
|
sub.subscribe(currentGroup.group)
|
||||||
|
|
||||||
|
push.send([
|
||||||
|
wireutil.global
|
||||||
|
, wireutil.envelope(new wire.JoinGroupMessage(
|
||||||
|
options.serial
|
||||||
|
, currentGroup
|
||||||
|
))
|
||||||
|
])
|
||||||
|
|
||||||
|
input.acquireWakeLock()
|
||||||
|
input.unlock()
|
||||||
|
|
||||||
|
emitter.emit('join', currentGroup)
|
||||||
|
|
||||||
|
return Promise.resolve(currentGroup)
|
||||||
|
}
|
||||||
|
|
||||||
|
function leaveGroup() {
|
||||||
|
if (!currentGroup) {
|
||||||
|
return Promise.reject(new grouputil.NotGroupedError())
|
||||||
|
}
|
||||||
|
|
||||||
|
log.info('No longer owned by "%s"', currentGroup.email)
|
||||||
|
log.info('Unsubscribing from group channel "%s"', currentGroup.group)
|
||||||
|
|
||||||
|
channels.unregister(currentGroup.group)
|
||||||
|
sub.unsubscribe(currentGroup.group)
|
||||||
|
|
||||||
|
push.send([
|
||||||
|
wireutil.global
|
||||||
|
, wireutil.envelope(new wire.LeaveGroupMessage(
|
||||||
|
options.serial
|
||||||
|
, currentGroup
|
||||||
|
))
|
||||||
|
])
|
||||||
|
|
||||||
|
input.releaseWakeLock()
|
||||||
|
input.lock()
|
||||||
|
|
||||||
|
var oldGroup = currentGroup
|
||||||
|
currentGroup = null
|
||||||
|
|
||||||
|
emitter.emit('leave', oldGroup)
|
||||||
|
|
||||||
|
return Promise.resolve(oldGroup)
|
||||||
|
}
|
||||||
|
|
||||||
|
channels.on('timeout', function(channel) {
|
||||||
|
if (currentGroup && channel === currentGroup.group) {
|
||||||
|
leaveGroup()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
router
|
||||||
|
.on(wire.GroupMessage, function(channel, message) {
|
||||||
|
var reply = wireutil.reply(options.serial)
|
||||||
|
grouputil.match(identity, message.requirements)
|
||||||
|
.then(function() {
|
||||||
|
return joinGroup(message.owner)
|
||||||
|
})
|
||||||
|
.then(function() {
|
||||||
|
push.send([
|
||||||
|
channel
|
||||||
|
, reply.okay()
|
||||||
|
])
|
||||||
|
})
|
||||||
|
.catch(grouputil.RequirementMismatchError, function(err) {
|
||||||
|
push.send([
|
||||||
|
channel
|
||||||
|
, reply.fail(err.message)
|
||||||
|
])
|
||||||
|
})
|
||||||
|
.catch(grouputil.AlreadyGroupedError, function(err) {
|
||||||
|
push.send([
|
||||||
|
channel
|
||||||
|
, reply.fail(err.message)
|
||||||
|
])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.on(wire.UngroupMessage, function(channel, message) {
|
||||||
|
var reply = wireutil.reply(options.serial)
|
||||||
|
grouputil.match(identity, message.requirements)
|
||||||
|
.then(function() {
|
||||||
|
return leaveGroup()
|
||||||
|
})
|
||||||
|
.then(function() {
|
||||||
|
push.send([
|
||||||
|
channel
|
||||||
|
, reply.okay()
|
||||||
|
])
|
||||||
|
})
|
||||||
|
.catch(grouputil.NotGroupedError, function(err) {
|
||||||
|
push.send([
|
||||||
|
channel
|
||||||
|
, reply.fail(err.message)
|
||||||
|
])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
lifecycle.observe(function() {
|
||||||
|
if (currentGroup) {
|
||||||
|
leaveGroup()
|
||||||
|
return Promise.delay(500)
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
return emitter
|
||||||
|
})
|
|
@ -9,7 +9,7 @@ module.exports = syrup.serial()
|
||||||
.dependency(require('../support/adb'))
|
.dependency(require('../support/adb'))
|
||||||
.dependency(require('../support/router'))
|
.dependency(require('../support/router'))
|
||||||
.dependency(require('../support/push'))
|
.dependency(require('../support/push'))
|
||||||
.dependency(require('./owner'))
|
.dependency(require('./group'))
|
||||||
.define(function(options, adb, router, push, owner) {
|
.define(function(options, adb, router, push, owner) {
|
||||||
var log = logger.createLogger('device:plugins:logcat')
|
var log = logger.createLogger('device:plugins:logcat')
|
||||||
|
|
||||||
|
|
|
@ -1,122 +0,0 @@
|
||||||
var Promise = require('bluebird')
|
|
||||||
var syrup = require('syrup')
|
|
||||||
|
|
||||||
var logger = require('../../../util/logger')
|
|
||||||
var wire = require('../../../wire')
|
|
||||||
var wireutil = require('../../../wire/util')
|
|
||||||
var devutil = require('../../../util/devutil')
|
|
||||||
var lifecycle = require('../../../util/lifecycle')
|
|
||||||
|
|
||||||
module.exports = syrup.serial()
|
|
||||||
.dependency(require('./identity'))
|
|
||||||
.dependency(require('./input'))
|
|
||||||
.dependency(require('../support/router'))
|
|
||||||
.dependency(require('../support/push'))
|
|
||||||
.dependency(require('../support/sub'))
|
|
||||||
.dependency(require('../support/channels'))
|
|
||||||
.define(function(options, identity, input, router, push, sub, channels) {
|
|
||||||
var log = logger.createLogger('device:plugins:owner')
|
|
||||||
var owner = null
|
|
||||||
|
|
||||||
function isGrouped() {
|
|
||||||
return !!owner
|
|
||||||
}
|
|
||||||
|
|
||||||
function isOwnedBy(someOwner) {
|
|
||||||
return owner && owner.group == someOwner.group
|
|
||||||
}
|
|
||||||
|
|
||||||
function joinGroup(newOwner, timeout) {
|
|
||||||
log.info('Now owned by "%s"', newOwner.email)
|
|
||||||
log.info('Subscribing to group channel "%s"', newOwner.group)
|
|
||||||
channels.register(newOwner.group, timeout)
|
|
||||||
sub.subscribe(newOwner.group)
|
|
||||||
push.send([
|
|
||||||
wireutil.global
|
|
||||||
, wireutil.envelope(new wire.JoinGroupMessage(
|
|
||||||
options.serial
|
|
||||||
, newOwner
|
|
||||||
))
|
|
||||||
])
|
|
||||||
input.acquireWakeLock()
|
|
||||||
input.unlock()
|
|
||||||
owner = newOwner
|
|
||||||
}
|
|
||||||
|
|
||||||
function leaveGroup() {
|
|
||||||
log.info('No longer owned by "%s"', owner.email)
|
|
||||||
log.info('Unsubscribing from group channel "%s"', owner.group)
|
|
||||||
channels.unregister(owner.group)
|
|
||||||
sub.unsubscribe(owner.group)
|
|
||||||
push.send([
|
|
||||||
wireutil.global
|
|
||||||
, wireutil.envelope(new wire.LeaveGroupMessage(
|
|
||||||
options.serial
|
|
||||||
, owner
|
|
||||||
))
|
|
||||||
])
|
|
||||||
input.releaseWakeLock()
|
|
||||||
input.lock()
|
|
||||||
owner = null
|
|
||||||
}
|
|
||||||
|
|
||||||
channels.on('timeout', function(channel) {
|
|
||||||
if (owner && channel === owner.group) {
|
|
||||||
leaveGroup()
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
router
|
|
||||||
.on(wire.GroupMessage, function(channel, message) {
|
|
||||||
var reply = wireutil.reply(options.serial)
|
|
||||||
if (devutil.matchesRequirements(identity, message.requirements)) {
|
|
||||||
if (!isGrouped()) {
|
|
||||||
joinGroup(message.owner, message.timeout)
|
|
||||||
push.send([
|
|
||||||
channel
|
|
||||||
, reply.okay()
|
|
||||||
])
|
|
||||||
}
|
|
||||||
else if (isOwnedBy(message.owner)) {
|
|
||||||
push.send([
|
|
||||||
channel
|
|
||||||
, reply.okay()
|
|
||||||
])
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
push.send([
|
|
||||||
channel
|
|
||||||
, reply.fail()
|
|
||||||
])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.on(wire.UngroupMessage, function(channel, message) {
|
|
||||||
var reply = wireutil.reply(options.serial)
|
|
||||||
if (devutil.matchesRequirements(identity, message.requirements)) {
|
|
||||||
if (isGrouped()) {
|
|
||||||
leaveGroup()
|
|
||||||
push.send([
|
|
||||||
channel
|
|
||||||
, reply.okay()
|
|
||||||
])
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
push.send([
|
|
||||||
channel
|
|
||||||
, reply.okay()
|
|
||||||
])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
lifecycle.observe(function() {
|
|
||||||
if (isGrouped()) {
|
|
||||||
leaveGroup()
|
|
||||||
return Promise.delay(500)
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
})
|
|
||||||
})
|
|
|
@ -2,10 +2,6 @@ var util = require('util')
|
||||||
|
|
||||||
var split = require('split')
|
var split = require('split')
|
||||||
var Promise = require('bluebird')
|
var Promise = require('bluebird')
|
||||||
var semver = require('semver')
|
|
||||||
var minimatch = require('minimatch')
|
|
||||||
|
|
||||||
var wire = require('../wire')
|
|
||||||
|
|
||||||
var devutil = module.exports = Object.create(null)
|
var devutil = module.exports = Object.create(null)
|
||||||
|
|
||||||
|
@ -13,38 +9,6 @@ function closedError(err) {
|
||||||
return err.message.indexOf('closed') !== -1
|
return err.message.indexOf('closed') !== -1
|
||||||
}
|
}
|
||||||
|
|
||||||
devutil.matchesRequirements = function(capabilities, requirements) {
|
|
||||||
return requirements.every(function(req) {
|
|
||||||
var capability = capabilities[req.name]
|
|
||||||
|
|
||||||
if (!capability) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (req.type) {
|
|
||||||
case wire.RequirementType.SEMVER:
|
|
||||||
if (!semver.satisfies(capability, req.value)) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
break
|
|
||||||
case wire.RequirementType.GLOB:
|
|
||||||
if (!minimatch(capability, req.value)) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
break
|
|
||||||
case wire.RequirementType.EXACT:
|
|
||||||
if (capability !== req.value) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
return true
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
devutil.ensureUnusedPort = function(adb, serial, port) {
|
devutil.ensureUnusedPort = function(adb, serial, port) {
|
||||||
return adb.openTcp(serial, port)
|
return adb.openTcp(serial, port)
|
||||||
.then(function(conn) {
|
.then(function(conn) {
|
||||||
|
|
72
lib/util/grouputil.js
Normal file
72
lib/util/grouputil.js
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
var util = require('util')
|
||||||
|
|
||||||
|
var Promise = require('bluebird')
|
||||||
|
var semver = require('semver')
|
||||||
|
var minimatch = require('minimatch')
|
||||||
|
|
||||||
|
var wire = require('../wire')
|
||||||
|
|
||||||
|
function RequirementMismatchError(name) {
|
||||||
|
Error.call(this)
|
||||||
|
this.name = 'RequirementMismatchError'
|
||||||
|
this.message = util.format('Requirement mismatch for "%s"', name)
|
||||||
|
Error.captureStackTrace(this, RequirementMismatchError)
|
||||||
|
}
|
||||||
|
|
||||||
|
util.inherits(RequirementMismatchError, Error)
|
||||||
|
|
||||||
|
module.exports.RequirementMismatchError = RequirementMismatchError
|
||||||
|
|
||||||
|
function AlreadyGroupedError(name) {
|
||||||
|
Error.call(this)
|
||||||
|
this.name = 'AlreadyGroupedError'
|
||||||
|
this.message = 'Already a member of another group'
|
||||||
|
Error.captureStackTrace(this, AlreadyGroupedError)
|
||||||
|
}
|
||||||
|
|
||||||
|
util.inherits(AlreadyGroupedError, Error)
|
||||||
|
|
||||||
|
module.exports.AlreadyGroupedError = AlreadyGroupedError
|
||||||
|
|
||||||
|
function NotGroupedError() {
|
||||||
|
Error.call(this)
|
||||||
|
this.name = 'NotGroupedError'
|
||||||
|
this.message = 'Not a member of any group'
|
||||||
|
Error.captureStackTrace(this, NotGroupedError)
|
||||||
|
}
|
||||||
|
|
||||||
|
util.inherits(NotGroupedError, Error)
|
||||||
|
|
||||||
|
module.exports.NotGroupedError = NotGroupedError
|
||||||
|
|
||||||
|
module.exports.match = Promise.method(function(capabilities, requirements) {
|
||||||
|
return requirements.every(function(req) {
|
||||||
|
var capability = capabilities[req.name]
|
||||||
|
|
||||||
|
if (!capability) {
|
||||||
|
throw new RequirementMismatchError(req.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (req.type) {
|
||||||
|
case wire.RequirementType.SEMVER:
|
||||||
|
if (!semver.satisfies(capability, req.value)) {
|
||||||
|
throw new RequirementMismatchError(req.name)
|
||||||
|
}
|
||||||
|
break
|
||||||
|
case wire.RequirementType.GLOB:
|
||||||
|
if (!minimatch(capability, req.value)) {
|
||||||
|
throw new RequirementMismatchError(req.name)
|
||||||
|
}
|
||||||
|
break
|
||||||
|
case wire.RequirementType.EXACT:
|
||||||
|
if (capability !== req.value) {
|
||||||
|
throw new RequirementMismatchError(req.name)
|
||||||
|
}
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
throw new RequirementMismatchError(req.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
})
|
Loading…
Add table
Add a link
Reference in a new issue