1
0
Fork 0
mirror of https://github.com/openstf/stf synced 2025-10-05 10:39:25 +02:00

Add support for Android O Developer Preview 1.

This commit is contained in:
Simo Kinnunen 2017-04-08 23:21:19 +09:00
parent 9fa11ac7ff
commit 43f0341297
8 changed files with 63 additions and 16 deletions

View file

@ -4,6 +4,7 @@
### Enhancements ### Enhancements
- Added support for Android O Developer Preview 1
- You can now set screen JPEG quality with the `SCREEN_JPEG_QUALITY` environment variable at launch time. Can be useful for slow networks. - You can now set screen JPEG quality with the `SCREEN_JPEG_QUALITY` environment variable at launch time. Can be useful for slow networks.
- Switched to [yargs](http://yargs.js.org) for option parsing to make it easier to modify the CLI. - Switched to [yargs](http://yargs.js.org) for option parsing to make it easier to modify the CLI.
- Almost all command line options can now be specified with environment variables. - Almost all command line options can now be specified with environment variables.

View file

@ -32,7 +32,7 @@ Please [contact us][contact-link] for sponsor arrangements. Both recurring and o
* OS support * OS support
- Android - Android
* Supports versions 2.3.3 (SDK level 10) to 7.1 (SDK level 25) * Supports versions 2.3.3 (SDK level 10) to 7.1 (SDK level 25) and Android O Developer Preview 1
* Supports Wear 5.1 (but not 5.0 due to missing permissions) * Supports Wear 5.1 (but not 5.0 due to missing permissions)
* Supports Fire OS, CyanogenMod, and other heavily Android based distributions * Supports Fire OS, CyanogenMod, and other heavily Android based distributions
* `root` is **not** required for any current functionality * `root` is **not** required for any current functionality

View file

@ -15,7 +15,8 @@ module.exports = syrup.serial()
.dependency(require('../support/adb')) .dependency(require('../support/adb'))
.dependency(require('../support/properties')) .dependency(require('../support/properties'))
.dependency(require('../support/abi')) .dependency(require('../support/abi'))
.define(function(options, adb, properties, abi) { .dependency(require('../support/sdk'))
.define(function(options, adb, properties, abi, sdk) {
var log = logger.createLogger('device:resources:minicap') var log = logger.createLogger('device:resources:minicap')
var resources = { var resources = {
@ -42,12 +43,17 @@ module.exports = syrup.serial()
pathutil.module(util.format( pathutil.module(util.format(
'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so' 'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so'
, supportedAbi , supportedAbi
, properties['ro.build.version.release'] , sdk.release
)) ))
, pathutil.module(util.format( , pathutil.module(util.format(
'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so' 'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so'
, supportedAbi , supportedAbi
, properties['ro.build.version.sdk'] , sdk.previewLevel
))
, pathutil.module(util.format(
'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so'
, supportedAbi
, sdk.level
)) ))
]) ])
}, [])) }, []))
@ -82,7 +88,7 @@ module.exports = syrup.serial()
} }
function installResource(res) { function installResource(res) {
log.info('Installing "%s" as "%s"', res.comm, res.dest) log.info('Installing "%s" as "%s"', res.src, res.dest)
function checkExecutable(res) { function checkExecutable(res) {
return adb.stat(options.serial, res.dest) return adb.stat(options.serial, res.dest)

View file

@ -13,16 +13,19 @@ var Resource = require('./util/resource')
module.exports = syrup.serial() module.exports = syrup.serial()
.dependency(require('../support/adb')) .dependency(require('../support/adb'))
.dependency(require('../support/properties')) .dependency(require('../support/properties'))
.define(function(options, adb, properties) { .dependency(require('../support/abi'))
.define(function(options, adb, properties, abi) {
var log = logger.createLogger('device:resources:minirev') var log = logger.createLogger('device:resources:minirev')
var resources = { var resources = {
bin: new Resource({ bin: new Resource({
src: pathutil.vendor(util.format( src: pathutil.requiredMatch(abi.all.map(function(supportedAbi) {
return pathutil.vendor(util.format(
'minirev/%s/minirev%s' 'minirev/%s/minirev%s'
, properties['ro.product.cpu.abi'] , supportedAbi
, properties['ro.build.version.sdk'] < 16 ? '-nopie' : '' , abi.pie ? '' : '-nopie'
)) ))
}))
, dest: [ , dest: [
'/data/local/tmp/minirev' '/data/local/tmp/minirev'
, '/data/data/com.android.shell/minirev' , '/data/data/com.android.shell/minirev'
@ -54,7 +57,7 @@ module.exports = syrup.serial()
} }
function installResource(res) { function installResource(res) {
log.info('Installing "%s" as "%s"', res.comm, res.dest) log.info('Installing "%s" as "%s"', res.src, res.dest)
function checkExecutable(res) { function checkExecutable(res) {
return adb.stat(options.serial, res.dest) return adb.stat(options.serial, res.dest)

View file

@ -56,7 +56,7 @@ module.exports = syrup.serial()
} }
function installResource(res) { function installResource(res) {
log.info('Installing "%s" as "%s"', res.comm, res.dest) log.info('Installing "%s" as "%s"', res.src, res.dest)
function checkExecutable(res) { function checkExecutable(res) {
return adb.stat(options.serial, res.dest) return adb.stat(options.serial, res.dest)

View file

@ -4,7 +4,8 @@ var logger = require('../../../util/logger')
module.exports = syrup.serial() module.exports = syrup.serial()
.dependency(require('./properties')) .dependency(require('./properties'))
.define(function(options, properties) { .dependency(require('./sdk'))
.define(function(options, properties, sdk) {
var log = logger.createLogger('device:support:abi') var log = logger.createLogger('device:support:abi')
return (function() { return (function() {
function split(list) { function split(list) {
@ -13,7 +14,7 @@ module.exports = syrup.serial()
var abi = { var abi = {
primary: properties['ro.product.cpu.abi'] primary: properties['ro.product.cpu.abi']
, pie: properties['ro.build.version.sdk'] >= 16 , pie: sdk.level >= 16
, all: [] , all: []
, b32: [] , b32: []
, b64: [] , b64: []

View file

@ -0,0 +1,36 @@
var syrup = require('stf-syrup')
var logger = require('../../../util/logger')
module.exports = syrup.serial()
.dependency(require('./properties'))
.define(function(options, properties) {
var log = logger.createLogger('device:support:sdk')
return (function() {
var level = parseInt(properties['ro.build.version.sdk'], 10)
var previewDelta =
parseInt(properties['ro.build.version.preview_sdk'], 10) || 0
var previewLevel = level + previewDelta
var sdk = {
level: level
, previewDelta: previewDelta
, previewLevel: previewLevel
, release: properties['ro.build.version.release']
}
if (sdk.previewDelta) {
log.info(
'Supports SDK %s (base %s, preview delta +%s)'
, sdk.previewLevel
, sdk.level
, sdk.previewDelta
)
}
else {
log.info('Supports SDK %s', sdk.level)
}
return sdk
})()
})

View file

@ -61,7 +61,7 @@
"lodash": "^4.14.2", "lodash": "^4.14.2",
"markdown-serve": "^0.3.2", "markdown-serve": "^0.3.2",
"mime": "^1.3.4", "mime": "^1.3.4",
"minicap-prebuilt": "^1.3.0", "minicap-prebuilt": "^1.4.0",
"minimatch": "^3.0.3", "minimatch": "^3.0.3",
"my-local-ip": "^1.0.0", "my-local-ip": "^1.0.0",
"openid": "^2.0.1", "openid": "^2.0.1",