mirror of
https://github.com/openstf/stf
synced 2025-10-04 10:19:30 +02:00
Add browser list to device identity.
This commit is contained in:
parent
2bf8f2352b
commit
e17f306d30
11 changed files with 144 additions and 9 deletions
|
@ -33,9 +33,9 @@ program
|
||||||
, Number
|
, Number
|
||||||
, 7400)
|
, 7400)
|
||||||
.option('--max-port <port>'
|
.option('--max-port <port>'
|
||||||
, 'maximum port number for worker use'
|
, 'maximum port number for worker use (total must be multiple of 3)'
|
||||||
, Number
|
, Number
|
||||||
, 7800)
|
, 7700)
|
||||||
.option('--public-ip <ip>'
|
.option('--public-ip <ip>'
|
||||||
, 'public ip for global access'
|
, 'public ip for global access'
|
||||||
, String
|
, String
|
||||||
|
|
|
@ -114,6 +114,7 @@ dbapi.saveDeviceIdentity = function(serial, identity) {
|
||||||
, abi: identity.abi
|
, abi: identity.abi
|
||||||
, sdk: identity.sdk
|
, sdk: identity.sdk
|
||||||
, display: identity.display
|
, display: identity.display
|
||||||
|
, browsers: identity.browsers
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
51
lib/roles/device/plugins/browsers.js
Normal file
51
lib/roles/device/plugins/browsers.js
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
var util = require('util')
|
||||||
|
|
||||||
|
var syrup = require('syrup')
|
||||||
|
|
||||||
|
var logger = require('../../../util/logger')
|
||||||
|
|
||||||
|
module.exports = syrup()
|
||||||
|
.dependency(require('../support/http'))
|
||||||
|
.dependency(require('./input'))
|
||||||
|
.define(function(options, http, input) {
|
||||||
|
var log = logger.createLogger('device:plugins:browsers')
|
||||||
|
|
||||||
|
log.info('Fetching browser list')
|
||||||
|
return input.getBrowsers()
|
||||||
|
.then(function(browsers) {
|
||||||
|
var icons = Object.create(null)
|
||||||
|
|
||||||
|
browsers.apps.forEach(function(app) {
|
||||||
|
icons[app.component] = app.icon.toBuffer()
|
||||||
|
app.icon = util.format(
|
||||||
|
'%s/api/v1/browsers/%s/icon'
|
||||||
|
, http.get('public url')
|
||||||
|
, app.component
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
|
http.get(
|
||||||
|
'/api/v1/browsers/:package/:activity/icon'
|
||||||
|
, function(req, res) {
|
||||||
|
var component = util.format(
|
||||||
|
'%s/%s'
|
||||||
|
, req.params.package
|
||||||
|
, req.params.activity
|
||||||
|
)
|
||||||
|
|
||||||
|
var icon = icons[component]
|
||||||
|
|
||||||
|
if (icon) {
|
||||||
|
res.set('Content-Type', 'image/png')
|
||||||
|
res.set('Content-Length', icon.length)
|
||||||
|
res.send(200, icon)
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
res.send(404)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return browsers
|
||||||
|
})
|
||||||
|
})
|
|
@ -6,13 +6,15 @@ var logger = require('../../../util/logger')
|
||||||
module.exports = syrup.serial()
|
module.exports = syrup.serial()
|
||||||
.dependency(require('../support/properties'))
|
.dependency(require('../support/properties'))
|
||||||
.dependency(require('./display'))
|
.dependency(require('./display'))
|
||||||
.define(function(options, properties, display) {
|
.dependency(require('./browsers'))
|
||||||
|
.define(function(options, properties, display, browsers) {
|
||||||
var log = logger.createLogger('device:plugins:identity')
|
var log = logger.createLogger('device:plugins:identity')
|
||||||
|
|
||||||
function solve() {
|
function solve() {
|
||||||
log.info('Solving identity')
|
log.info('Solving identity')
|
||||||
var identity = devutil.makeIdentity(options.serial, properties)
|
var identity = devutil.makeIdentity(options.serial, properties)
|
||||||
identity.display = display
|
identity.display = display
|
||||||
|
identity.browsers = browsers
|
||||||
return identity
|
return identity
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -293,6 +293,21 @@ module.exports = syrup.serial()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getBrowsers() {
|
||||||
|
return runServiceCommand(
|
||||||
|
apk.serviceProto.RequestType.GET_BROWSERS
|
||||||
|
, new apk.serviceProto.GetBrowsersRequest()
|
||||||
|
)
|
||||||
|
.then(function(data) {
|
||||||
|
var response = apk.serviceProto.GetBrowsersResponse.decode(data)
|
||||||
|
if (response.success) {
|
||||||
|
delete response.success
|
||||||
|
return response
|
||||||
|
}
|
||||||
|
throw new Error('Unable to get browser list')
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
function runServiceCommand(type, cmd) {
|
function runServiceCommand(type, cmd) {
|
||||||
var resolver = Promise.defer()
|
var resolver = Promise.defer()
|
||||||
service.writer.write(new apk.serviceProto.RequestEnvelope(
|
service.writer.write(new apk.serviceProto.RequestEnvelope(
|
||||||
|
@ -361,6 +376,7 @@ module.exports = syrup.serial()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
, copy: getClipboard
|
, copy: getClipboard
|
||||||
|
, getBrowsers: getBrowsers
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -42,6 +42,17 @@ module.exports = syrup.serial()
|
||||||
, identity.display.secure
|
, identity.display.secure
|
||||||
, identity.display.url
|
, identity.display.url
|
||||||
)
|
)
|
||||||
|
, new wire.DeviceBrowsersMessage(
|
||||||
|
identity.browsers.selected
|
||||||
|
, identity.browsers.apps.map(function(app) {
|
||||||
|
return new wire.DeviceBrowserAppMessage(
|
||||||
|
app.name
|
||||||
|
, app.component
|
||||||
|
, app.selected
|
||||||
|
, app.icon
|
||||||
|
)
|
||||||
|
})
|
||||||
|
)
|
||||||
))
|
))
|
||||||
])
|
])
|
||||||
})
|
})
|
||||||
|
|
29
lib/roles/device/support/http.js
Normal file
29
lib/roles/device/support/http.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
var http = require('http')
|
||||||
|
var util = require('util')
|
||||||
|
|
||||||
|
var syrup = require('syrup')
|
||||||
|
var express = require('express')
|
||||||
|
|
||||||
|
var logger = require('../../../util/logger')
|
||||||
|
|
||||||
|
module.exports = syrup()
|
||||||
|
.define(function(options) {
|
||||||
|
var log = logger.createLogger('device:support:http')
|
||||||
|
, port = options.ports.pop()
|
||||||
|
, app = express()
|
||||||
|
, server = http.createServer(app)
|
||||||
|
|
||||||
|
app.set('strict routing', true)
|
||||||
|
app.set('case sensitive routing', true)
|
||||||
|
app.set('public url', util.format(
|
||||||
|
'http://%s:%s'
|
||||||
|
, options.publicIp
|
||||||
|
, port
|
||||||
|
))
|
||||||
|
|
||||||
|
server.listen(port)
|
||||||
|
|
||||||
|
log.info('Listening on %s', app.get('public url'))
|
||||||
|
|
||||||
|
return app
|
||||||
|
})
|
|
@ -253,7 +253,7 @@ module.exports = function(options) {
|
||||||
|
|
||||||
// Spawn a device worker
|
// Spawn a device worker
|
||||||
function spawn() {
|
function spawn() {
|
||||||
var ports = options.ports.splice(0, 2)
|
var ports = options.ports.splice(0, 3)
|
||||||
, proc = options.fork(device, ports)
|
, proc = options.fork(device, ports)
|
||||||
, resolver = Promise.defer()
|
, resolver = Promise.defer()
|
||||||
|
|
||||||
|
|
|
@ -127,6 +127,18 @@ message DeviceDisplayMessage {
|
||||||
required string url = 10;
|
required string url = 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message DeviceBrowserAppMessage {
|
||||||
|
required string name = 1;
|
||||||
|
required string component = 2;
|
||||||
|
required bool selected = 3;
|
||||||
|
required string icon = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message DeviceBrowsersMessage {
|
||||||
|
required bool selected = 1;
|
||||||
|
repeated DeviceBrowserAppMessage apps = 2;
|
||||||
|
}
|
||||||
|
|
||||||
message DeviceIdentityMessage {
|
message DeviceIdentityMessage {
|
||||||
required string serial = 1;
|
required string serial = 1;
|
||||||
required string platform = 2;
|
required string platform = 2;
|
||||||
|
@ -137,6 +149,7 @@ message DeviceIdentityMessage {
|
||||||
required string abi = 7;
|
required string abi = 7;
|
||||||
required string sdk = 8;
|
required string sdk = 8;
|
||||||
required DeviceDisplayMessage display = 9;
|
required DeviceDisplayMessage display = 9;
|
||||||
|
required DeviceBrowsersMessage browsers = 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
message DeviceProperty {
|
message DeviceProperty {
|
||||||
|
|
BIN
vendor/STFService/STFService.apk
vendored
BIN
vendor/STFService/STFService.apk
vendored
Binary file not shown.
22
vendor/STFService/proto/service.proto
vendored
22
vendor/STFService/proto/service.proto
vendored
|
@ -8,6 +8,7 @@ enum RequestType {
|
||||||
SET_WAKE_LOCK = 2;
|
SET_WAKE_LOCK = 2;
|
||||||
SET_CLIPBOARD = 3;
|
SET_CLIPBOARD = 3;
|
||||||
GET_CLIPBOARD = 4;
|
GET_CLIPBOARD = 4;
|
||||||
|
GET_BROWSERS = 5;
|
||||||
GET_PROPERTIES = 6;
|
GET_PROPERTIES = 6;
|
||||||
IDENTIFY = 7;
|
IDENTIFY = 7;
|
||||||
}
|
}
|
||||||
|
@ -17,11 +18,6 @@ message RequestEnvelope {
|
||||||
required bytes request = 2;
|
required bytes request = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
message ResponseEnvelope {
|
|
||||||
required bool success = 1;
|
|
||||||
required bytes response = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
message VersionRequest {
|
message VersionRequest {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,6 +65,22 @@ message GetClipboardResponse {
|
||||||
optional string text = 3;
|
optional string text = 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message BrowserApp {
|
||||||
|
required string name = 1;
|
||||||
|
required string component = 2;
|
||||||
|
required bool selected = 3;
|
||||||
|
required bytes icon = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message GetBrowsersRequest {
|
||||||
|
}
|
||||||
|
|
||||||
|
message GetBrowsersResponse {
|
||||||
|
required bool success = 1;
|
||||||
|
required bool selected = 2;
|
||||||
|
repeated BrowserApp apps = 3;
|
||||||
|
}
|
||||||
|
|
||||||
message Property {
|
message Property {
|
||||||
required string name = 1;
|
required string name = 1;
|
||||||
required string value = 2;
|
required string value = 2;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue