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…](579912d470). The rest of the change is updating call sites with a new argument.
This commit is contained in:
Andrew Kolos 2024-03-11 13:39:31 -07:00 committed by GitHub
parent d98d842d1f
commit 83fad74535
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
13 changed files with 70 additions and 9 deletions

View file

@ -15,6 +15,7 @@ import '../../devfs.dart';
import '../../flutter_manifest.dart';
import '../build_system.dart';
import '../depfile.dart';
import '../exceptions.dart';
import '../tools/asset_transformer.dart';
import '../tools/scene_importer.dart';
import '../tools/shader_compiler.dart';
@ -35,7 +36,7 @@ Future<Depfile> copyAssets(
Directory outputDirectory, {
Map<String, DevFSContent> additionalContent = const <String, DevFSContent>{},
required TargetPlatform targetPlatform,
BuildMode? buildMode,
required BuildMode buildMode,
List<File> additionalInputs = const <File>[],
String? flavor,
}) async {
@ -101,6 +102,7 @@ Future<Depfile> copyAssets(
processManager: environment.processManager,
fileSystem: environment.fileSystem,
dartBinaryPath: environment.artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: buildMode,
);
final Map<String, AssetBundleEntry> assetEntries = <String, AssetBundleEntry>{
@ -186,7 +188,7 @@ Future<Depfile> copyAssets(
// Copy deferred components assets only for release or profile builds.
// The assets are included in assetBundle.entries as a normal asset when
// 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>>(
(MapEntry<String, Map<String, AssetBundleEntry>> componentEntries) async {
final Directory componentOutputDir =
@ -343,6 +345,11 @@ class CopyAssets extends Target {
@override
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
.buildDir
.childDirectory('flutter_assets');
@ -351,6 +358,7 @@ class CopyAssets extends Target {
environment,
output,
targetPlatform: TargetPlatform.android,
buildMode: buildMode,
flavor: environment.defines[kFlavor],
);
environment.depFileService.writeToFile(

View file

@ -503,6 +503,7 @@ abstract class IosAssetBundle extends Target {
environment,
assetDirectory,
targetPlatform: TargetPlatform.ios,
buildMode: buildMode,
additionalInputs: <File>[
flutterProject.ios.infoPlist,
flutterProject.ios.appFrameworkInfoPlist,

View file

@ -137,6 +137,7 @@ abstract class BundleLinuxAssets extends Target {
environment,
outputDirectory,
targetPlatform: targetPlatform,
buildMode: buildMode,
additionalContent: <String, DevFSContent>{
'version.json': DevFSStringContent(versionInfo),
},

View file

@ -438,6 +438,7 @@ abstract class MacOSBundleFlutterAssets extends Target {
environment,
assetDirectory,
targetPlatform: TargetPlatform.darwin,
buildMode: buildMode,
flavor: environment.defines[kFlavor],
);
environment.depFileService.writeToFile(

View file

@ -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);
final Directory outputDirectory = environment.outputDir.childDirectory('assets');
outputDirectory.createSync(recursive: true);
final Depfile depfile = await copyAssets(
environment,
environment.outputDir.childDirectory('assets'),
targetPlatform: TargetPlatform.web_javascript,
buildMode: buildMode,
);
final DepfileService depfileService = environment.depFileService;
depfileService.writeToFile(

View file

@ -142,6 +142,7 @@ abstract class BundleWindowsAssets extends Target {
environment,
outputDirectory,
targetPlatform: targetPlatform,
buildMode: buildMode,
);
environment.depFileService.writeToFile(
depfile,

View file

@ -12,6 +12,7 @@ import '../../base/error_handling_io.dart';
import '../../base/file_system.dart';
import '../../base/io.dart';
import '../../base/logger.dart';
import '../../build_info.dart';
import '../../devfs.dart';
import '../../flutter_manifest.dart';
import '../build_system.dart';
@ -22,13 +23,18 @@ final class AssetTransformer {
required ProcessManager processManager,
required FileSystem fileSystem,
required String dartBinaryPath,
required BuildMode buildMode,
}) : _processManager = processManager,
_fileSystem = fileSystem,
_dartBinaryPath = dartBinaryPath;
_dartBinaryPath = dartBinaryPath,
_buildMode = buildMode;
static const String buildModeEnvVar = 'FLUTTER_BUILD_MODE';
final ProcessManager _processManager;
final FileSystem _fileSystem;
final String _dartBinaryPath;
final BuildMode _buildMode;
/// The [Source] inputs that targets using this should depend on.
///
@ -115,6 +121,9 @@ final class AssetTransformer {
final ProcessResult result = await _processManager.run(
command,
workingDirectory: workingDirectory,
environment: <String, String>{
AssetTransformer.buildModeEnvVar: _buildMode.cliName,
}
);
final String stdout = result.stdout as String;
final String stderr = result.stderr as String;

View file

@ -442,6 +442,7 @@ class DevFS {
required FileSystem fileSystem,
required ProcessManager processManager,
required Artifacts artifacts,
required BuildMode buildMode,
HttpClient? httpClient,
Duration? uploadRetryThrottle,
StopwatchFactory stopwatchFactory = const StopwatchFactory(),
@ -465,6 +466,7 @@ class DevFS {
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: buildMode,
),
fileSystem: fileSystem,
logger: logger,

View file

@ -387,6 +387,7 @@ class FlutterDevice {
logger: globals.logger,
processManager: globals.processManager,
artifacts: globals.artifacts!,
buildMode: buildInfo.mode,
);
return devFS!.create();
}

View file

@ -8,6 +8,7 @@ import 'package:file_testing/file_testing.dart';
import 'package:flutter_tools/src/artifacts.dart';
import 'package:flutter_tools/src/base/file_system.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/flutter_manifest.dart';
@ -53,6 +54,7 @@ void main() {
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: artifacts.getArtifactPath(Artifact.engineDartBinary),
buildMode: BuildMode.debug,
);
final AssetTransformationFailure? transformationFailure = await transformer.transformAsset(
@ -112,6 +114,7 @@ void main() {
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
);
final AssetTransformationFailure? failure = await transformer.transformAsset(
@ -171,6 +174,7 @@ Something went wrong''');
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
);
final AssetTransformationFailure? failure = await transformer.transformAsset(
@ -265,6 +269,7 @@ Transformation failed, but I forgot to exit with a non-zero code.'''
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
);
final AssetTransformationFailure? failure = await transformer.transformAsset(
@ -331,7 +336,10 @@ Transformation failed, but I forgot to exit with a non-zero code.'''
onRun: (List<String> args) {
// 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.'''
processManager: processManager,
fileSystem: fileSystem,
dartBinaryPath: dartBinaryPath,
buildMode: BuildMode.debug,
);
final AssetTransformationFailure? failure = await transformer.transformAsset(

View file

@ -38,7 +38,9 @@ void main() {
fileSystem: fileSystem,
logger: BufferLogger.test(),
platform: FakePlatform(),
defines: <String, String>{},
defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
);
fileSystem.file(environment.buildDir.childFile('app.dill')).createSync(recursive: true);
fileSystem.file('packages/flutter_tools/lib/src/build_system/targets/assets.dart')
@ -178,7 +180,9 @@ flutter:
fileSystem: fileSystem,
logger: logger,
platform: globals.platform,
defines: <String, String>{},
defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
);
await fileSystem.file('.packages').create();
@ -262,7 +266,9 @@ flutter:
fileSystem: fileSystem,
logger: logger,
platform: globals.platform,
defines: <String, String>{},
defines: <String, String>{
kBuildMode: BuildMode.debug.cliName,
},
);
await fileSystem.file('.packages').create();

View file

@ -68,6 +68,7 @@ void main() {
outputDir: globals.fs.currentDirectory.childDirectory('bar'),
defines: <String, String>{
kTargetFile: globals.fs.path.join('foo', 'lib', 'main.dart'),
kBuildMode: BuildMode.debug.cliName,
},
artifacts: Artifacts.test(),
processManager: processManager,

View file

@ -135,6 +135,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
expect(() async => devFS.create(), throwsA(isA<DevFSException>()));
});
@ -160,6 +161,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
expect(await devFS.create(), isNotNull);
@ -210,6 +212,7 @@ void main() {
uploadRetryThrottle: Duration.zero,
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -245,6 +248,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -287,6 +291,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -331,6 +336,7 @@ void main() {
httpClient: HttpClient(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -382,6 +388,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -461,6 +468,7 @@ void main() {
}),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -507,6 +515,7 @@ void main() {
httpClient: FakeHttpClient.any(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -612,7 +621,8 @@ void main() {
httpClient: FakeHttpClient.any(),
config: Config.test(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -670,7 +680,8 @@ void main() {
httpClient: FakeHttpClient.any(),
config: Config.test(),
processManager: FakeProcessManager.empty(),
artifacts: Artifacts.test(),
artifacts: Artifacts.test(),
buildMode: BuildMode.debug,
);
await devFS.create();
@ -763,6 +774,7 @@ void main() {
config: Config.test(),
processManager: processManager,
artifacts: artifacts,
buildMode: BuildMode.debug,
);
await devFS.create();
@ -843,6 +855,7 @@ void main() {
config: Config.test(),
processManager: processManager,
artifacts: artifacts,
buildMode: BuildMode.debug,
);
await devFS.create();