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:
parent
9fa11ac7ff
commit
43f0341297
8 changed files with 63 additions and 16 deletions
|
@ -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.
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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) {
|
||||||
'minirev/%s/minirev%s'
|
return pathutil.vendor(util.format(
|
||||||
, properties['ro.product.cpu.abi']
|
'minirev/%s/minirev%s'
|
||||||
, properties['ro.build.version.sdk'] < 16 ? '-nopie' : ''
|
, supportedAbi
|
||||||
))
|
, 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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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: []
|
||||||
|
|
36
lib/units/device/support/sdk.js
Normal file
36
lib/units/device/support/sdk.js
Normal 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
|
||||||
|
})()
|
||||||
|
})
|
|
@ -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",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue