Unverified Commit 83fad745 authored by Andrew Kolos's avatar Andrew Kolos Committed by GitHub

Expose build mode in environment of asset transformer processes (#144752)

In service of https://github.com/flutter/flutter/issues/143348

When invoking a package to transform an asset, we set `FLUTTER_BUILD_MODE` to the CLI name of the build mode being used. Inspired by https://github.com/flutter/flutter/issues/101077#issuecomment-1890379501:

> Do transformers know whether they get executed in debug or release mode? I kinda imagine that being useful. Ex: There's a transformer that optimizes the file size of images. Depending on the amount and size of the images, that could take a significant amount of time. Therefore, I might want to only execute it in release builds.

Note for the reviewer: the interesting part of this change can be found in the commit [set environment variable to build mode when running asset transformer…](https://github.com/flutter/flutter/pull/144752/commits/579912d470b6f6eb036fd6b23a128fa3942f6282). The rest of the change is updating call sites with a new argument.
parent d98d842d
...@@ -15,6 +15,7 @@ import '../../devfs.dart'; ...@@ -15,6 +15,7 @@ import '../../devfs.dart';
import '../../flutter_manifest.dart'; import '../../flutter_manifest.dart';
import '../build_system.dart'; import '../build_system.dart';
import '../depfile.dart'; import '../depfile.dart';
import '../exceptions.dart';
import '../tools/asset_transformer.dart'; import '../tools/asset_transformer.dart';
import '../tools/scene_importer.dart'; import '../tools/scene_importer.dart';
import '../tools/shader_compiler.dart'; import '../tools/shader_compiler.dart';
...@@ -35,7 +36,7 @@ Future<Depfile> copyAssets( ...@@ -35,7 +36,7 @@ Future<Depfile> copyAssets(
Directory outputDirectory, { Directory outputDirectory, {
Map<String, DevFSContent> additionalContent = const <String, DevFSContent>{}, Map<String, DevFSContent> additionalContent = const <String, DevFSContent>{},
required TargetPlatform targetPlatform, required TargetPlatform targetPlatform,
BuildMode? buildMode, required BuildMode buildMode,
List<File> additionalInputs = const <File>[], List<File> additionalInputs = const <File>[],
String? flavor, String? flavor,
}) async { }) async {
...@@ -101,6 +102,7 @@ Future<Depfile> copyAssets( ...@@ -101,6 +102,7 @@ Future<Depfile> copyAssets(
processManager: environment.processManager, processManager: environment.processManager,
fileSystem: environment.fileSystem, fileSystem: environment.fileSystem,
dartBinaryPath: environment.artifacts.getArtifactPath(Artifact.engineDartBinary), dartBinaryPath: environment.artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: buildMode,
); );
final Map<String, AssetBundleEntry> assetEntries = <String, AssetBundleEntry>{ final Map<String, AssetBundleEntry> assetEntries = <String, AssetBundleEntry>{
...@@ -186,7 +188,7 @@ Future<Depfile> copyAssets( ...@@ -186,7 +188,7 @@ Future<Depfile> copyAssets(
// Copy deferred components assets only for release or profile builds. // Copy deferred components assets only for release or profile builds.
// The assets are included in assetBundle.entries as a normal asset when // The assets are included in assetBundle.entries as a normal asset when
// building as debug. // building as debug.
if (environment.defines[kDeferredComponents] == 'true' && buildMode != null) { if (environment.defines[kDeferredComponents] == 'true') {
await Future.wait<void>(assetBundle.deferredComponentsEntries.entries.map<Future<void>>( await Future.wait<void>(assetBundle.deferredComponentsEntries.entries.map<Future<void>>(
(MapEntry<String, Map<String, AssetBundleEntry>> componentEntries) async { (MapEntry<String, Map<String, AssetBundleEntry>> componentEntries) async {
final Directory componentOutputDir = final Directory componentOutputDir =
...@@ -343,6 +345,11 @@ class CopyAssets extends Target { ...@@ -343,6 +345,11 @@ class CopyAssets extends Target {
@override @override
Future<void> build(Environment environment) async { Future<void> build(Environment environment) async {
final String? buildModeEnvironment = environment.defines[kBuildMode];
if (buildModeEnvironment == null) {
throw MissingDefineException(kBuildMode, name);
}
final BuildMode buildMode = BuildMode.fromCliName(buildModeEnvironment);
final Directory output = environment final Directory output = environment
.buildDir .buildDir
.childDirectory('flutter_assets'); .childDirectory('flutter_assets');
...@@ -351,6 +358,7 @@ class CopyAssets extends Target { ...@@ -351,6 +358,7 @@ class CopyAssets extends Target {
environment, environment,
output, output,
targetPlatform: TargetPlatform.android, targetPlatform: TargetPlatform.android,
buildMode: buildMode,
flavor: environment.defines[kFlavor], flavor: environment.defines[kFlavor],
); );
environment.depFileService.writeToFile( environment.depFileService.writeToFile(
......
...@@ -503,6 +503,7 @@ abstract class IosAssetBundle extends Target { ...@@ -503,6 +503,7 @@ abstract class IosAssetBundle extends Target {
environment, environment,
assetDirectory, assetDirectory,
targetPlatform: TargetPlatform.ios, targetPlatform: TargetPlatform.ios,
buildMode: buildMode,
additionalInputs: <File>[ additionalInputs: <File>[
flutterProject.ios.infoPlist, flutterProject.ios.infoPlist,
flutterProject.ios.appFrameworkInfoPlist, flutterProject.ios.appFrameworkInfoPlist,
......
...@@ -137,6 +137,7 @@ abstract class BundleLinuxAssets extends Target { ...@@ -137,6 +137,7 @@ abstract class BundleLinuxAssets extends Target {
environment, environment,
outputDirectory, outputDirectory,
targetPlatform: targetPlatform, targetPlatform: targetPlatform,
buildMode: buildMode,
additionalContent: <String, DevFSContent>{ additionalContent: <String, DevFSContent>{
'version.json': DevFSStringContent(versionInfo), 'version.json': DevFSStringContent(versionInfo),
}, },
......
...@@ -438,6 +438,7 @@ abstract class MacOSBundleFlutterAssets extends Target { ...@@ -438,6 +438,7 @@ abstract class MacOSBundleFlutterAssets extends Target {
environment, environment,
assetDirectory, assetDirectory,
targetPlatform: TargetPlatform.darwin, targetPlatform: TargetPlatform.darwin,
buildMode: buildMode,
flavor: environment.defines[kFlavor], flavor: environment.defines[kFlavor],
); );
environment.depFileService.writeToFile( environment.depFileService.writeToFile(
......
...@@ -380,13 +380,21 @@ class WebReleaseBundle extends Target { ...@@ -380,13 +380,21 @@ class WebReleaseBundle extends Target {
} }
} }
final String? buildModeEnvironment = environment.defines[kBuildMode];
if (buildModeEnvironment == null) {
throw MissingDefineException(kBuildMode, name);
}
final BuildMode buildMode = BuildMode.fromCliName(buildModeEnvironment);
createVersionFile(environment, environment.defines); createVersionFile(environment, environment.defines);
final Directory outputDirectory = environment.outputDir.childDirectory('assets'); final Directory outputDirectory = environment.outputDir.childDirectory('assets');
outputDirectory.createSync(recursive: true); outputDirectory.createSync(recursive: true);
final Depfile depfile = await copyAssets( final Depfile depfile = await copyAssets(
environment, environment,
environment.outputDir.childDirectory('assets'), environment.outputDir.childDirectory('assets'),
targetPlatform: TargetPlatform.web_javascript, targetPlatform: TargetPlatform.web_javascript,
buildMode: buildMode,
); );
final DepfileService depfileService = environment.depFileService; final DepfileService depfileService = environment.depFileService;
depfileService.writeToFile( depfileService.writeToFile(
......
...@@ -142,6 +142,7 @@ abstract class BundleWindowsAssets extends Target { ...@@ -142,6 +142,7 @@ abstract class BundleWindowsAssets extends Target {
environment, environment,
outputDirectory, outputDirectory,
targetPlatform: targetPlatform, targetPlatform: targetPlatform,
buildMode: buildMode,
); );
environment.depFileService.writeToFile( environment.depFileService.writeToFile(
depfile, depfile,
......
...@@ -12,6 +12,7 @@ import '../../base/error_handling_io.dart'; ...@@ -12,6 +12,7 @@ import '../../base/error_handling_io.dart';
import '../../base/file_system.dart'; import '../../base/file_system.dart';
import '../../base/io.dart'; import '../../base/io.dart';
import '../../base/logger.dart'; import '../../base/logger.dart';
import '../../build_info.dart';
import '../../devfs.dart'; import '../../devfs.dart';
import '../../flutter_manifest.dart'; import '../../flutter_manifest.dart';
import '../build_system.dart'; import '../build_system.dart';
...@@ -22,13 +23,18 @@ final class AssetTransformer { ...@@ -22,13 +23,18 @@ final class AssetTransformer {
required ProcessManager processManager, required ProcessManager processManager,
required FileSystem fileSystem, required FileSystem fileSystem,
required String dartBinaryPath, required String dartBinaryPath,
required BuildMode buildMode,
}) : _processManager = processManager, }) : _processManager = processManager,
_fileSystem = fileSystem, _fileSystem = fileSystem,
_dartBinaryPath = dartBinaryPath; _dartBinaryPath = dartBinaryPath,
_buildMode = buildMode;
static const String buildModeEnvVar = 'FLUTTER_BUILD_MODE';
final ProcessManager _processManager; final ProcessManager _processManager;
final FileSystem _fileSystem; final FileSystem _fileSystem;
final String _dartBinaryPath; final String _dartBinaryPath;
final BuildMode _buildMode;
/// The [Source] inputs that targets using this should depend on. /// The [Source] inputs that targets using this should depend on.
/// ///
...@@ -115,6 +121,9 @@ final class AssetTransformer { ...@@ -115,6 +121,9 @@ final class AssetTransformer {
final ProcessResult result = await _processManager.run( final ProcessResult result = await _processManager.run(
command, command,
workingDirectory: workingDirectory, workingDirectory: workingDirectory,
environment: <String, String>{
AssetTransformer.buildModeEnvVar: _buildMode.cliName,
}
); );
final String stdout = result.stdout as String; final String stdout = result.stdout as String;
final String stderr = result.stderr as String; final String stderr = result.stderr as String;
......
...@@ -442,6 +442,7 @@ class DevFS { ...@@ -442,6 +442,7 @@ class DevFS {
required FileSystem fileSystem, required FileSystem fileSystem,
required ProcessManager processManager, required ProcessManager processManager,
required Artifacts artifacts, required Artifacts artifacts,
required BuildMode buildMode,
HttpClient? httpClient, HttpClient? httpClient,
Duration? uploadRetryThrottle, Duration? uploadRetryThrottle,
StopwatchFactory stopwatchFactory = const StopwatchFactory(), StopwatchFactory stopwatchFactory = const StopwatchFactory(),
...@@ -465,6 +466,7 @@ class DevFS { ...@@ -465,6 +466,7 @@ class DevFS {
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary), dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: buildMode,
), ),
fileSystem: fileSystem, fileSystem: fileSystem,
logger: logger, logger: logger,
......
...@@ -387,6 +387,7 @@ class FlutterDevice { ...@@ -387,6 +387,7 @@ class FlutterDevice {
logger: globals.logger, logger: globals.logger,
processManager: globals.processManager, processManager: globals.processManager,
artifacts: globals.artifacts!, artifacts: globals.artifacts!,
buildMode: buildInfo.mode,
); );
return devFS!.create(); return devFS!.create();
} }
......
...@@ -8,6 +8,7 @@ import 'package:file_testing/file_testing.dart'; ...@@ -8,6 +8,7 @@ import 'package:file_testing/file_testing.dart';
import 'package:flutter_tools/src/artifacts.dart'; import 'package:flutter_tools/src/artifacts.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/base/logger.dart';
import 'package:flutter_tools/src/build_info.dart';
import 'package:flutter_tools/src/build_system/tools/asset_transformer.dart'; import 'package:flutter_tools/src/build_system/tools/asset_transformer.dart';
import 'package:flutter_tools/src/flutter_manifest.dart'; import 'package:flutter_tools/src/flutter_manifest.dart';
...@@ -53,6 +54,7 @@ void main() { ...@@ -53,6 +54,7 @@ void main() {
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary), dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: BuildMode.debug,
); );
final AssetTransformationFailure? transformationFailure = await transformer.transformAsset( final AssetTransformationFailure? transformationFailure = await transformer.transformAsset(
...@@ -112,6 +114,7 @@ void main() { ...@@ -112,6 +114,7 @@ void main() {
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath, dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
); );
final AssetTransformationFailure? failure = await transformer.transformAsset( final AssetTransformationFailure? failure = await transformer.transformAsset(
...@@ -171,6 +174,7 @@ Something went wrong'''); ...@@ -171,6 +174,7 @@ Something went wrong''');
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath, dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
); );
final AssetTransformationFailure? failure = await transformer.transformAsset( final AssetTransformationFailure? failure = await transformer.transformAsset(
...@@ -265,6 +269,7 @@ Transformation failed, but I forgot to exit with a non-zero code.''' ...@@ -265,6 +269,7 @@ Transformation failed, but I forgot to exit with a non-zero code.'''
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath, dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
); );
final AssetTransformationFailure? failure = await transformer.transformAsset( final AssetTransformationFailure? failure = await transformer.transformAsset(
...@@ -331,7 +336,10 @@ Transformation failed, but I forgot to exit with a non-zero code.''' ...@@ -331,7 +336,10 @@ Transformation failed, but I forgot to exit with a non-zero code.'''
onRun: (List<String> args) { onRun: (List<String> args) {
// Do nothing. // Do nothing.
}, },
stderr: 'Transformation failed, but I forgot to exit with a non-zero code.' stderr: 'Transformation failed, but I forgot to exit with a non-zero code.',
environment: const <String, String>{
'FLUTTER_BUILD_MODE': 'debug',
},
), ),
]); ]);
...@@ -339,6 +347,7 @@ Transformation failed, but I forgot to exit with a non-zero code.''' ...@@ -339,6 +347,7 @@ Transformation failed, but I forgot to exit with a non-zero code.'''
processManager: processManager, processManager: processManager,
fileSystem: fileSystem, fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath, dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
); );
final AssetTransformationFailure? failure = await transformer.transformAsset( final AssetTransformationFailure? failure = await transformer.transformAsset(
......
...@@ -38,7 +38,9 @@ void main() { ...@@ -38,7 +38,9 @@ void main() {
fileSystem: fileSystem, fileSystem: fileSystem,
logger: BufferLogger.test(), logger: BufferLogger.test(),
platform: FakePlatform(), platform: FakePlatform(),
defines: <String, String>{}, defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
); );
fileSystem.file(environment.buildDir.childFile('app.dill')).createSync(recursive: true); fileSystem.file(environment.buildDir.childFile('app.dill')).createSync(recursive: true);
fileSystem.file('packages/flutter_tools/lib/src/build_system/targets/assets.dart') fileSystem.file('packages/flutter_tools/lib/src/build_system/targets/assets.dart')
...@@ -178,7 +180,9 @@ flutter: ...@@ -178,7 +180,9 @@ flutter:
fileSystem: fileSystem, fileSystem: fileSystem,
logger: logger, logger: logger,
platform: globals.platform, platform: globals.platform,
defines: <String, String>{}, defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
); );
await fileSystem.file('.packages').create(); await fileSystem.file('.packages').create();
...@@ -262,7 +266,9 @@ flutter: ...@@ -262,7 +266,9 @@ flutter:
fileSystem: fileSystem, fileSystem: fileSystem,
logger: logger, logger: logger,
platform: globals.platform, platform: globals.platform,
defines: <String, String>{}, defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
); );
await fileSystem.file('.packages').create(); await fileSystem.file('.packages').create();
......
...@@ -68,6 +68,7 @@ void main() { ...@@ -68,6 +68,7 @@ void main() {
outputDir: globals.fs.currentDirectory.childDirectory('bar'), outputDir: globals.fs.currentDirectory.childDirectory('bar'),
defines: <String, String>{ defines: <String, String>{
kTargetFile: globals.fs.path.join('foo', 'lib', 'main.dart'), kTargetFile: globals.fs.path.join('foo', 'lib', 'main.dart'),
kBuildMode: BuildMode.debug.cliName,
}, },
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
processManager: processManager, processManager: processManager,
......
...@@ -135,6 +135,7 @@ void main() { ...@@ -135,6 +135,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
expect(() async => devFS.create(), throwsA(isA<DevFSException>())); expect(() async => devFS.create(), throwsA(isA<DevFSException>()));
}); });
...@@ -160,6 +161,7 @@ void main() { ...@@ -160,6 +161,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
expect(await devFS.create(), isNotNull); expect(await devFS.create(), isNotNull);
...@@ -210,6 +212,7 @@ void main() { ...@@ -210,6 +212,7 @@ void main() {
uploadRetryThrottle: Duration.zero, uploadRetryThrottle: Duration.zero,
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -245,6 +248,7 @@ void main() { ...@@ -245,6 +248,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -287,6 +291,7 @@ void main() { ...@@ -287,6 +291,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -331,6 +336,7 @@ void main() { ...@@ -331,6 +336,7 @@ void main() {
httpClient: HttpClient(), httpClient: HttpClient(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -382,6 +388,7 @@ void main() { ...@@ -382,6 +388,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -461,6 +468,7 @@ void main() { ...@@ -461,6 +468,7 @@ void main() {
}), }),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -507,6 +515,7 @@ void main() { ...@@ -507,6 +515,7 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -612,7 +621,8 @@ void main() { ...@@ -612,7 +621,8 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
config: Config.test(), config: Config.test(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -670,7 +680,8 @@ void main() { ...@@ -670,7 +680,8 @@ void main() {
httpClient: FakeHttpClient.any(), httpClient: FakeHttpClient.any(),
config: Config.test(), config: Config.test(),
processManager: FakeProcessManager.empty(), processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(), artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -763,6 +774,7 @@ void main() { ...@@ -763,6 +774,7 @@ void main() {
config: Config.test(), config: Config.test(),
processManager: processManager, processManager: processManager,
artifacts: artifacts, artifacts: artifacts,
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
...@@ -843,6 +855,7 @@ void main() { ...@@ -843,6 +855,7 @@ void main() {
config: Config.test(), config: Config.test(),
processManager: processManager, processManager: processManager,
artifacts: artifacts, artifacts: artifacts,
buildMode: BuildMode.debug,
); );
await devFS.create(); await devFS.create();
......
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