forked from flutter/flutter
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add flutter build aar (flutter#35217)
`flutter build aar` This new build command works just like `flutter build apk` or `flutter build appbundle`, but for plugin and module projects. This PR also refactors how plugins are included in app or module projects. By building the plugins as AARs, the Android Gradle plugin is able to use Jetifier to translate support libraries into AndroidX libraries for all the plugin's native code. Thus, reducing the error rate when using AndroidX in apps. This change also allows to build modules as AARs, so developers can take these artifacts and distribute them along with the native host app without the need of the Flutter tool. This is a requirement for add to app. `flutter build aar` generates POM artifacts (XML files) which contain metadata about the native dependencies used by the plugin. This allows Gradle to resolve dependencies at the app level. The result of this new build command is a single build/outputs/repo, the local repository that contains all the generated AARs and POM files. In a Flutter app project, this local repo is used by the Flutter Gradle plugin to resolve the plugin dependencies. In add to app case, the developer needs to configure the local repo and the dependency manually in `build.gradle`: repositories { maven { url "<path-to-flutter-module>build/host/outputs/repo" } } dependencies { implementation("<package-name>:flutter_<build-mode>:1.0@aar") { transitive = true } }
- Loading branch information
Emmanuel Garcia
authored
Jul 23, 2019
1 parent
c8f168f
commit 11460b8
Showing
30 changed files
with
2,162 additions
and
147 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,219 @@ | ||
// Copyright (c) 2019 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:async'; | ||
import 'dart:io'; | ||
|
||
import 'package:flutter_devicelab/framework/framework.dart'; | ||
import 'package:flutter_devicelab/framework/utils.dart'; | ||
import 'package:path/path.dart' as path; | ||
|
||
final String gradlew = Platform.isWindows ? 'gradlew.bat' : 'gradlew'; | ||
final String gradlewExecutable = Platform.isWindows ? gradlew : './$gradlew'; | ||
|
||
/// Tests that AARs can be built on module projects. | ||
Future<void> main() async { | ||
await task(() async { | ||
|
||
section('Find Java'); | ||
|
||
final String javaHome = await findJavaHome(); | ||
if (javaHome == null) | ||
return TaskResult.failure('Could not find Java'); | ||
print('\nUsing JAVA_HOME=$javaHome'); | ||
|
||
section('Create module project'); | ||
|
||
final Directory tempDir = Directory.systemTemp.createTempSync('flutter_module_test.'); | ||
final Directory projectDir = Directory(path.join(tempDir.path, 'hello')); | ||
try { | ||
await inDirectory(tempDir, () async { | ||
await flutter( | ||
'create', | ||
options: <String>['--org', 'io.flutter.devicelab', '--template', 'module', 'hello'], | ||
); | ||
}); | ||
|
||
section('Add plugins'); | ||
|
||
final File pubspec = File(path.join(projectDir.path, 'pubspec.yaml')); | ||
String content = pubspec.readAsStringSync(); | ||
content = content.replaceFirst( | ||
'\ndependencies:\n', | ||
'\ndependencies:\n device_info:\n package_info:\n', | ||
); | ||
pubspec.writeAsStringSync(content, flush: true); | ||
await inDirectory(projectDir, () async { | ||
await flutter( | ||
'packages', | ||
options: <String>['get'], | ||
); | ||
}); | ||
|
||
section('Build release AAR'); | ||
|
||
await inDirectory(projectDir, () async { | ||
await flutter( | ||
'build', | ||
options: <String>['aar', '--verbose'], | ||
); | ||
}); | ||
|
||
final String repoPath = path.join( | ||
projectDir.path, | ||
'build', | ||
'host', | ||
'outputs', | ||
'repo', | ||
); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'flutter_release', | ||
'1.0', | ||
'flutter_release-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'flutter_release', | ||
'1.0', | ||
'flutter_release-1.0.pom', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'deviceinfo', | ||
'device_info_release', | ||
'1.0', | ||
'device_info_release-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'deviceinfo', | ||
'device_info_release', | ||
'1.0', | ||
'device_info_release-1.0.pom', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'packageinfo', | ||
'package_info_release', | ||
'1.0', | ||
'package_info_release-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'packageinfo', | ||
'package_info_release', | ||
'1.0', | ||
'package_info_release-1.0.pom', | ||
)); | ||
|
||
section('Build debug AAR'); | ||
|
||
await inDirectory(projectDir, () async { | ||
await flutter( | ||
'build', | ||
options: <String>['aar', '--verbose', '--debug'], | ||
); | ||
}); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'flutter_release', | ||
'1.0', | ||
'flutter_release-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'flutter_debug', | ||
'1.0', | ||
'flutter_debug-1.0.pom', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'deviceinfo', | ||
'device_info_debug', | ||
'1.0', | ||
'device_info_debug-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'deviceinfo', | ||
'device_info_debug', | ||
'1.0', | ||
'device_info_debug-1.0.pom', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'packageinfo', | ||
'package_info_debug', | ||
'1.0', | ||
'package_info_debug-1.0.aar', | ||
)); | ||
|
||
checkFileExists(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'plugins', | ||
'packageinfo', | ||
'package_info_debug', | ||
'1.0', | ||
'package_info_debug-1.0.pom', | ||
)); | ||
|
||
return TaskResult.success(null); | ||
} catch (e) { | ||
return TaskResult.failure(e.toString()); | ||
} finally { | ||
rmTree(tempDir); | ||
} | ||
}); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,138 @@ | ||
// Copyright (c) 2019 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:async'; | ||
import 'dart:io'; | ||
|
||
import 'package:flutter_devicelab/framework/framework.dart'; | ||
import 'package:flutter_devicelab/framework/utils.dart'; | ||
import 'package:path/path.dart' as path; | ||
|
||
final String gradlew = Platform.isWindows ? 'gradlew.bat' : 'gradlew'; | ||
final String gradlewExecutable = Platform.isWindows ? gradlew : './$gradlew'; | ||
|
||
/// Tests that AARs can be built on plugin projects. | ||
Future<void> main() async { | ||
await task(() async { | ||
|
||
section('Find Java'); | ||
|
||
final String javaHome = await findJavaHome(); | ||
if (javaHome == null) | ||
return TaskResult.failure('Could not find Java'); | ||
print('\nUsing JAVA_HOME=$javaHome'); | ||
|
||
section('Create plugin project'); | ||
|
||
final Directory tempDir = Directory.systemTemp.createTempSync('flutter_module_test.'); | ||
final Directory projectDir = Directory(path.join(tempDir.path, 'hello')); | ||
try { | ||
await inDirectory(tempDir, () async { | ||
await flutter( | ||
'create', | ||
options: <String>[ | ||
'--org', 'io.flutter.devicelab', | ||
'--template', 'plugin', | ||
'hello', | ||
], | ||
); | ||
}); | ||
|
||
section('Build release AAR'); | ||
|
||
await inDirectory(projectDir, () async { | ||
await flutter( | ||
'build', | ||
options: <String>['aar', '--verbose'], | ||
); | ||
}); | ||
|
||
final String repoPath = path.join( | ||
projectDir.path, | ||
'build', | ||
'outputs', | ||
'repo', | ||
); | ||
|
||
final File releaseAar = File(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'hello_release', | ||
'1.0', | ||
'hello_release-1.0.aar', | ||
)); | ||
|
||
if (!exists(releaseAar)) { | ||
return TaskResult.failure('Failed to build the release AAR file.'); | ||
} | ||
|
||
final File releasePom = File(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'hello_release', | ||
'1.0', | ||
'hello_release-1.0.pom', | ||
)); | ||
|
||
if (!exists(releasePom)) { | ||
return TaskResult.failure('Failed to build the release POM file.'); | ||
} | ||
|
||
section('Build debug AAR'); | ||
|
||
await inDirectory(projectDir, () async { | ||
await flutter( | ||
'build', | ||
options: <String>[ | ||
'aar', | ||
'--verbose', | ||
'--debug', | ||
], | ||
); | ||
}); | ||
|
||
final File debugAar = File(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'hello_debug', | ||
'1.0', | ||
'hello_debug-1.0.aar', | ||
)); | ||
|
||
if (!exists(debugAar)) { | ||
return TaskResult.failure('Failed to build the debug AAR file.'); | ||
} | ||
|
||
final File debugPom = File(path.join( | ||
repoPath, | ||
'io', | ||
'flutter', | ||
'devicelab', | ||
'hello', | ||
'hello_debug', | ||
'1.0', | ||
'hello_debug-1.0.pom', | ||
)); | ||
|
||
if (!exists(debugPom)) { | ||
return TaskResult.failure('Failed to build the debug POM file.'); | ||
} | ||
|
||
return TaskResult.success(null); | ||
} catch (e) { | ||
return TaskResult.failure(e.toString()); | ||
} finally { | ||
rmTree(tempDir); | ||
} | ||
}); | ||
} |
Oops, something went wrong.