Unverified Commit b491f16d authored by Andrew Kolos's avatar Andrew Kolos Committed by GitHub

instead of exiting the tool, print a warning when using --flavor with an...

instead of exiting the tool, print a warning when using --flavor with an incompatible device (#143735)

Fixes https://github.com/flutter/flutter/issues/143574 by printing a warning (instead of exiting) when `--flavor` is used with a target platform that doesn't have flavors support.
parent 7a4c2465
...@@ -640,7 +640,11 @@ class RunCommand extends RunCommandBase { ...@@ -640,7 +640,11 @@ class RunCommand extends RunCommandBase {
final bool flavorsSupportedOnEveryDevice = devices! final bool flavorsSupportedOnEveryDevice = devices!
.every((Device device) => device.supportsFlavors); .every((Device device) => device.supportsFlavors);
if (flavor != null && !flavorsSupportedOnEveryDevice) { if (flavor != null && !flavorsSupportedOnEveryDevice) {
throwToolExit('--flavor is only supported for Android, macOS, and iOS devices.'); globals.printWarning(
'--flavor is only supported for Android, macOS, and iOS devices. '
'Flavor-related features may not function properly and could '
'behave differently in a future release.'
);
} }
} }
......
...@@ -48,11 +48,13 @@ void main() { ...@@ -48,11 +48,13 @@ void main() {
}); });
group('run', () { group('run', () {
late BufferLogger logger;
late TestDeviceManager testDeviceManager; late TestDeviceManager testDeviceManager;
late FileSystem fileSystem; late FileSystem fileSystem;
setUp(() { setUp(() {
testDeviceManager = TestDeviceManager(logger: BufferLogger.test()); logger = BufferLogger.test();
testDeviceManager = TestDeviceManager(logger: logger);
fileSystem = MemoryFileSystem.test(); fileSystem = MemoryFileSystem.test();
}); });
...@@ -65,7 +67,7 @@ void main() { ...@@ -65,7 +67,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
}); });
testUsingContext('does not support --no-sound-null-safety by default', () async { testUsingContext('does not support --no-sound-null-safety by default', () async {
...@@ -89,7 +91,7 @@ void main() { ...@@ -89,7 +91,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
}); });
testUsingContext('supports --no-sound-null-safety with an overridden NonNullSafeBuilds', () async { testUsingContext('supports --no-sound-null-safety with an overridden NonNullSafeBuilds', () async {
...@@ -109,7 +111,7 @@ void main() { ...@@ -109,7 +111,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
Logger: () => BufferLogger.test(), Logger: () => logger,
NonNullSafeBuilds: () => NonNullSafeBuilds.allowed, NonNullSafeBuilds: () => NonNullSafeBuilds.allowed,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
}); });
...@@ -137,7 +139,7 @@ void main() { ...@@ -137,7 +139,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
}); });
testUsingContext('Walks upward looking for a pubspec.yaml and succeeds if found', () async { testUsingContext('Walks upward looking for a pubspec.yaml and succeeds if found', () async {
...@@ -165,7 +167,7 @@ void main() { ...@@ -165,7 +167,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
}); });
testUsingContext('Walks upward looking for a pubspec.yaml and exits if missing', () async { testUsingContext('Walks upward looking for a pubspec.yaml and exits if missing', () async {
...@@ -185,7 +187,7 @@ void main() { ...@@ -185,7 +187,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
}); });
group('run app', () { group('run app', () {
...@@ -487,7 +489,7 @@ void main() { ...@@ -487,7 +489,7 @@ void main() {
Cache: () => Cache.test(processManager: FakeProcessManager.any()), Cache: () => Cache.test(processManager: FakeProcessManager.any()),
}); });
testUsingContext('fails when --flavor is used with an unsupported target platform', () async { testUsingContext('prints warning when --flavor is used with an unsupported target platform', () async {
const List<String> runCommand = <String>[ const List<String> runCommand = <String>[
'run', 'run',
'--no-pub', '--no-pub',
...@@ -496,24 +498,25 @@ void main() { ...@@ -496,24 +498,25 @@ void main() {
'-d', '-d',
'all', 'all',
]; ];
// Useful for test readability. // Useful for test readability.
// ignore: avoid_redundant_argument_values // ignore: avoid_redundant_argument_values
final FakeDevice deviceWithoutFlavorSupport = FakeDevice(supportsFlavors: false); final FakeDevice deviceWithoutFlavorSupport = FakeDevice(supportsFlavors: false);
final FakeDevice deviceWithFlavorSupport = FakeDevice(supportsFlavors: true); final FakeDevice deviceWithFlavorSupport = FakeDevice(supportsFlavors: true);
testDeviceManager.devices = <Device>[deviceWithoutFlavorSupport, deviceWithFlavorSupport]; testDeviceManager.devices = <Device>[deviceWithoutFlavorSupport, deviceWithFlavorSupport];
await expectLater( await createTestCommandRunner(TestRunCommandThatOnlyValidates()).run(runCommand);
() => createTestCommandRunner(RunCommand()).run(runCommand),
throwsToolExit( expect(logger.warningText, contains(
message: '--flavor is only supported for Android, macOS, and iOS devices.', '--flavor is only supported for Android, macOS, and iOS devices. '
), 'Flavor-related features may not function properly and could '
); 'behave differently in a future release.'
));
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
FileSystem: () => fs, FileSystem: () => fs,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Cache: () => Cache.test(processManager: FakeProcessManager.any()), Cache: () => Cache.test(processManager: FakeProcessManager.any()),
Logger: () => logger,
}); });
testUsingContext('forwards --uninstall-only to DebuggingOptions', () async { testUsingContext('forwards --uninstall-only to DebuggingOptions', () async {
...@@ -678,7 +681,7 @@ void main() { ...@@ -678,7 +681,7 @@ void main() {
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Usage: () => usage, Usage: () => usage,
Stdio: () => FakeStdio(), Stdio: () => FakeStdio(),
Logger: () => AppRunLogger(parent: BufferLogger.test()), Logger: () => AppRunLogger(parent: logger),
}); });
testUsingContext('can disable devtools with --no-devtools', () async { testUsingContext('can disable devtools with --no-devtools', () async {
...@@ -706,7 +709,7 @@ void main() { ...@@ -706,7 +709,7 @@ void main() {
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Usage: () => usage, Usage: () => usage,
Stdio: () => FakeStdio(), Stdio: () => FakeStdio(),
Logger: () => AppRunLogger(parent: BufferLogger.test()), Logger: () => AppRunLogger(parent: logger),
}); });
}); });
}); });
...@@ -1015,7 +1018,7 @@ void main() { ...@@ -1015,7 +1018,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
}); });
...@@ -1036,7 +1039,7 @@ void main() { ...@@ -1036,7 +1039,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
}); });
...@@ -1060,7 +1063,7 @@ void main() { ...@@ -1060,7 +1063,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
}); });
...@@ -1080,7 +1083,7 @@ void main() { ...@@ -1080,7 +1083,7 @@ void main() {
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FileSystem: () => fileSystem, FileSystem: () => fileSystem,
ProcessManager: () => FakeProcessManager.any(), ProcessManager: () => FakeProcessManager.any(),
Logger: () => BufferLogger.test(), Logger: () => logger,
DeviceManager: () => testDeviceManager, DeviceManager: () => testDeviceManager,
}); });
}); });
......
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