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
- 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.
- 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.

View file

@ -32,7 +32,7 @@ Please [contact us][contact-link] for sponsor arrangements. Both recurring and o
* OS support
- 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 Fire OS, CyanogenMod, and other heavily Android based distributions
* `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/properties'))
.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 resources = {
@ -42,12 +43,17 @@ module.exports = syrup.serial()
pathutil.module(util.format(
'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so'
, supportedAbi
, properties['ro.build.version.release']
, sdk.release
))
, pathutil.module(util.format(
'minicap-prebuilt/prebuilt/%s/lib/android-%s/minicap.so'
, 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) {
log.info('Installing "%s" as "%s"', res.comm, res.dest)
log.info('Installing "%s" as "%s"', res.src, res.dest)
function checkExecutable(res) {
return adb.stat(options.serial, res.dest)

View file

@ -13,16 +13,19 @@ var Resource = require('./util/resource')
module.exports = syrup.serial()
.dependency(require('../support/adb'))
.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 resources = {
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'
, properties['ro.product.cpu.abi']
, properties['ro.build.version.sdk'] < 16 ? '-nopie' : ''
, supportedAbi
, abi.pie ? '' : '-nopie'
))
}))
, dest: [
'/data/local/tmp/minirev'
, '/data/data/com.android.shell/minirev'
@ -54,7 +57,7 @@ module.exports = syrup.serial()
}
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) {
return adb.stat(options.serial, res.dest)

View file

@ -56,7 +56,7 @@ module.exports = syrup.serial()
}
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) {
return adb.stat(options.serial, res.dest)

View file

@ -4,7 +4,8 @@ var logger = require('../../../util/logger')
module.exports = syrup.serial()
.dependency(require('./properties'))
.define(function(options, properties) {
.dependency(require('./sdk'))
.define(function(options, properties, sdk) {
var log = logger.createLogger('device:support:abi')
return (function() {
function split(list) {
@ -13,7 +14,7 @@ module.exports = syrup.serial()
var abi = {
primary: properties['ro.product.cpu.abi']
, pie: properties['ro.build.version.sdk'] >= 16
, pie: sdk.level >= 16
, all: []
, b32: []
, 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",
"markdown-serve": "^0.3.2",
"mime": "^1.3.4",
"minicap-prebuilt": "^1.3.0",
"minicap-prebuilt": "^1.4.0",
"minimatch": "^3.0.3",
"my-local-ip": "^1.0.0",
"openid": "^2.0.1",