Commit c186d0df authored by Devon Carew's avatar Devon Carew Committed by GitHub

pass the value of the android sdk (#11268)

* pass the value of the android sdk

* swap flag

* allow the user to set the android-sdk location
parent daa7860e
...@@ -67,7 +67,10 @@ class AndroidSdk { ...@@ -67,7 +67,10 @@ class AndroidSdk {
static AndroidSdk locateAndroidSdk() { static AndroidSdk locateAndroidSdk() {
String androidHomeDir; String androidHomeDir;
if (platform.environment.containsKey(kAndroidHome)) {
if (config.containsKey('android-sdk')) {
androidHomeDir = config.getValue('android-sdk');
} else if (platform.environment.containsKey(kAndroidHome)) {
androidHomeDir = platform.environment[kAndroidHome]; androidHomeDir = platform.environment[kAndroidHome];
} else if (platform.isLinux) { } else if (platform.isLinux) {
if (homeDirPath != null) if (homeDirPath != null)
......
...@@ -24,6 +24,8 @@ class Config { ...@@ -24,6 +24,8 @@ class Config {
Iterable<String> get keys => _values.keys; Iterable<String> get keys => _values.keys;
bool containsKey(String key) => _values.containsKey(key);
dynamic getValue(String key) => _values[key]; dynamic getValue(String key) => _values[key];
void setValue(String key, String value) { void setValue(String key, String value) {
......
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
import 'dart:async'; import 'dart:async';
import 'dart:convert'; import 'dart:convert';
import '../android/android_sdk.dart';
import '../android/android_studio.dart'; import '../android/android_studio.dart';
import '../globals.dart'; import '../globals.dart';
import '../runner/flutter_command.dart'; import '../runner/flutter_command.dart';
...@@ -19,6 +20,7 @@ class ConfigCommand extends FlutterCommand { ...@@ -19,6 +20,7 @@ class ConfigCommand extends FlutterCommand {
negatable: false, negatable: false,
help: 'Clear the saved development certificate choice used to sign apps for iOS device deployment.'); help: 'Clear the saved development certificate choice used to sign apps for iOS device deployment.');
argParser.addOption('gradle-dir', help: 'The gradle install directory.'); argParser.addOption('gradle-dir', help: 'The gradle install directory.');
argParser.addOption('android-sdk', help: 'The Android SDK directory.');
argParser.addOption('android-studio-dir', help: 'The Android Studio install directory.'); argParser.addOption('android-studio-dir', help: 'The Android Studio install directory.');
argParser.addFlag('machine', argParser.addFlag('machine',
negatable: false, negatable: false,
...@@ -38,6 +40,9 @@ class ConfigCommand extends FlutterCommand { ...@@ -38,6 +40,9 @@ class ConfigCommand extends FlutterCommand {
@override @override
final List<String> aliases = <String>['configure']; final List<String> aliases = <String>['configure'];
@override
bool get shouldUpdateCache => false;
@override @override
String get usageFooter { String get usageFooter {
// List all config settings. // List all config settings.
...@@ -69,6 +74,9 @@ class ConfigCommand extends FlutterCommand { ...@@ -69,6 +74,9 @@ class ConfigCommand extends FlutterCommand {
if (argResults.wasParsed('gradle-dir')) if (argResults.wasParsed('gradle-dir'))
_updateConfig('gradle-dir', argResults['gradle-dir']); _updateConfig('gradle-dir', argResults['gradle-dir']);
if (argResults.wasParsed('android-sdk'))
_updateConfig('android-sdk', argResults['android-sdk']);
if (argResults.wasParsed('android-studio-dir')) if (argResults.wasParsed('android-studio-dir'))
_updateConfig('android-studio-dir', argResults['android-studio-dir']); _updateConfig('android-studio-dir', argResults['android-studio-dir']);
...@@ -90,8 +98,11 @@ class ConfigCommand extends FlutterCommand { ...@@ -90,8 +98,11 @@ class ConfigCommand extends FlutterCommand {
if (results['android-studio-dir'] == null && androidStudio != null) { if (results['android-studio-dir'] == null && androidStudio != null) {
results['android-studio-dir'] = androidStudio.directory; results['android-studio-dir'] = androidStudio.directory;
} }
if (results['android-sdk'] == null && androidSdk != null) {
results['android-sdk'] = androidSdk.directory;
}
printStatus(JSON.encode(results)); printStatus(const JsonEncoder.withIndent(' ').convert(results));
} }
void _updateConfig(String keyName, String keyValue) { void _updateConfig(String keyName, String keyValue) {
......
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'dart:convert';
import 'package:flutter_tools/src/android/android_sdk.dart';
import 'package:flutter_tools/src/android/android_studio.dart';
import 'package:flutter_tools/src/base/context.dart';
import 'package:flutter_tools/src/base/logger.dart';
import 'package:flutter_tools/src/commands/config.dart';
import 'package:mockito/mockito.dart';
import 'package:test/test.dart';
import '../src/context.dart';
void main() {
MockAndroidStudio mockAndroidStudio;
MockAndroidSdk mockAndroidSdk;
setUp(() {
mockAndroidStudio = new MockAndroidStudio();
mockAndroidSdk = new MockAndroidSdk();
});
group('config', () {
testUsingContext('machine flag', () async {
final BufferLogger logger = context[Logger];
final ConfigCommand command = new ConfigCommand();
await command.handleMachine();
expect(logger.statusText, isNotEmpty);
final dynamic json = JSON.decode(logger.statusText);
expect(json, isMap);
expect(json.containsKey('android-studio-dir'), true);
expect(json['android-studio-dir'], isNotNull);
expect(json.containsKey('android-sdk'), true);
expect(json['android-sdk'], isNotNull);
}, overrides: <Type, Generator>{
AndroidStudio: () => mockAndroidStudio,
AndroidSdk: () => mockAndroidSdk,
});
});
}
class MockAndroidStudio extends Mock implements AndroidStudio, Comparable<AndroidStudio> {
@override
String get directory => 'path/to/android/stdio';
}
class MockAndroidSdk extends Mock implements AndroidSdk {
@override
String get directory => 'path/to/android/sdk';
}
...@@ -2,28 +2,17 @@ ...@@ -2,28 +2,17 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
import 'dart:convert';
import 'package:flutter_tools/src/android/android_studio.dart';
import 'package:flutter_tools/src/base/config.dart'; import 'package:flutter_tools/src/base/config.dart';
import 'package:flutter_tools/src/base/context.dart';
import 'package:flutter_tools/src/base/file_system.dart'; import 'package:flutter_tools/src/base/file_system.dart';
import 'package:flutter_tools/src/base/logger.dart';
import 'package:flutter_tools/src/commands/config.dart';
import 'package:mockito/mockito.dart';
import 'package:test/test.dart'; import 'package:test/test.dart';
import 'src/context.dart';
void main() { void main() {
Config config; Config config;
MockAndroidStudio mockAndroidStudio;
setUp(() { setUp(() {
final Directory tempDirectory = fs.systemTempDirectory.createTempSync('flutter_test'); final Directory tempDirectory = fs.systemTempDirectory.createTempSync('flutter_test');
final File file = fs.file(fs.path.join(tempDirectory.path, '.settings')); final File file = fs.file(fs.path.join(tempDirectory.path, '.settings'));
config = new Config(file); config = new Config(file);
mockAndroidStudio = new MockAndroidStudio();
}); });
group('config', () { group('config', () {
...@@ -34,6 +23,12 @@ void main() { ...@@ -34,6 +23,12 @@ void main() {
expect(config.keys, contains('foo')); expect(config.keys, contains('foo'));
}); });
test('containsKey', () async {
expect(config.containsKey('foo'), false);
config.setValue('foo', 'bar');
expect(config.containsKey('foo'), true);
});
test('removeValue', () async { test('removeValue', () async {
expect(config.getValue('foo'), null); expect(config.getValue('foo'), null);
config.setValue('foo', 'bar'); config.setValue('foo', 'bar');
...@@ -43,24 +38,5 @@ void main() { ...@@ -43,24 +38,5 @@ void main() {
expect(config.getValue('foo'), null); expect(config.getValue('foo'), null);
expect(config.keys, isNot(contains('foo'))); expect(config.keys, isNot(contains('foo')));
}); });
testUsingContext('machine flag', () async {
final BufferLogger logger = context[Logger];
final ConfigCommand command = new ConfigCommand();
await command.handleMachine();
expect(logger.statusText, isNotEmpty);
final dynamic json = JSON.decode(logger.statusText);
expect(json, isMap);
expect(json.containsKey('android-studio-dir'), true);
expect(json['android-studio-dir'], isNotNull);
}, overrides: <Type, Generator>{
AndroidStudio: () => mockAndroidStudio,
});
}); });
} }
class MockAndroidStudio extends Mock implements AndroidStudio, Comparable<AndroidStudio> {
@override
String get directory => 'path/to/android/stdio';
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment