Unverified Commit 028b7dce authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

[flutter_tools] remove context from WebWorkflow (#52613)

parent 48fc1350
...@@ -197,7 +197,10 @@ Future<T> runInContext<T>( ...@@ -197,7 +197,10 @@ Future<T> runInContext<T>(
processManager: globals.processManager, processManager: globals.processManager,
) )
), ),
WebWorkflow: () => const WebWorkflow(), WebWorkflow: () => WebWorkflow(
featureFlags: featureFlags,
platform: globals.platform,
),
WindowsWorkflow: () => const WindowsWorkflow(), WindowsWorkflow: () => const WindowsWorkflow(),
Xcode: () => Xcode( Xcode: () => Xcode(
logger: globals.logger, logger: globals.logger,
......
...@@ -56,6 +56,16 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider { ...@@ -56,6 +56,16 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider {
List<DoctorValidator> _validators; List<DoctorValidator> _validators;
List<Workflow> _workflows; List<Workflow> _workflows;
final LinuxWorkflow linuxWorkflow = LinuxWorkflow(
platform: globals.platform,
featureFlags: featureFlags,
);
final WebWorkflow webWorkflow = WebWorkflow(
platform: globals.platform,
featureFlags: featureFlags,
);
@override @override
List<DoctorValidator> get validators { List<DoctorValidator> get validators {
if (_validators != null) { if (_validators != null) {
...@@ -67,11 +77,6 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider { ...@@ -67,11 +77,6 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider {
...IntelliJValidator.installedValidators, ...IntelliJValidator.installedValidators,
...VsCodeValidator.installedValidators, ...VsCodeValidator.installedValidators,
]; ];
final LinuxWorkflow linuxWorkflow = LinuxWorkflow(
platform: globals.platform,
featureFlags: featureFlags,
);
_validators = <DoctorValidator>[ _validators = <DoctorValidator>[
FlutterValidator(), FlutterValidator(),
if (androidWorkflow.appliesToHostPlatform) if (androidWorkflow.appliesToHostPlatform)
...@@ -119,10 +124,6 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider { ...@@ -119,10 +124,6 @@ class _DefaultDoctorValidatorsProvider implements DoctorValidatorsProvider {
_workflows.add(fuchsiaWorkflow); _workflows.add(fuchsiaWorkflow);
} }
final LinuxWorkflow linuxWorkflow = LinuxWorkflow(
platform: globals.platform,
featureFlags: featureFlags,
);
if (linuxWorkflow.appliesToHostPlatform) { if (linuxWorkflow.appliesToHostPlatform) {
_workflows.add(linuxWorkflow); _workflows.add(linuxWorkflow);
} }
......
...@@ -2,25 +2,33 @@ ...@@ -2,25 +2,33 @@
// 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 '../base/context.dart'; import 'package:meta/meta.dart';
import 'package:platform/platform.dart';
import '../doctor.dart'; import '../doctor.dart';
import '../features.dart'; import '../features.dart';
import '../globals.dart' as globals;
/// The web workflow instance.
WebWorkflow get webWorkflow => context.get<WebWorkflow>();
class WebWorkflow extends Workflow { class WebWorkflow extends Workflow {
const WebWorkflow(); const WebWorkflow({
@required Platform platform,
@required FeatureFlags featureFlags,
}) : _platform = platform,
_featureFlags = featureFlags;
final Platform _platform;
final FeatureFlags _featureFlags;
@override @override
bool get appliesToHostPlatform => featureFlags.isWebEnabled && (globals.platform.isWindows || globals.platform.isMacOS || globals.platform.isLinux); bool get appliesToHostPlatform => _featureFlags.isWebEnabled &&
(_platform.isWindows ||
_platform.isMacOS ||
_platform.isLinux);
@override @override
bool get canLaunchDevices => featureFlags.isWebEnabled; bool get canLaunchDevices => _featureFlags.isWebEnabled;
@override @override
bool get canListDevices => featureFlags.isWebEnabled; bool get canListDevices => _featureFlags.isWebEnabled;
@override @override
bool get canListEmulators => false; bool get canListEmulators => false;
......
...@@ -722,7 +722,8 @@ void main() { ...@@ -722,7 +722,8 @@ void main() {
testUsingContext('WebWorkflow is a part of validator workflows if enabled', () async { testUsingContext('WebWorkflow is a part of validator workflows if enabled', () async {
when(globals.processManager.canRun(any)).thenReturn(true); when(globals.processManager.canRun(any)).thenReturn(true);
expect(DoctorValidatorsProvider.defaultInstance.workflows.contains(webWorkflow), true); expect(DoctorValidatorsProvider.defaultInstance.workflows,
contains(isA<WebWorkflow>()));
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
FeatureFlags: () => TestFeatureFlags(isWebEnabled: true), FeatureFlags: () => TestFeatureFlags(isWebEnabled: true),
ProcessManager: () => MockProcessManager(), ProcessManager: () => MockProcessManager(),
......
...@@ -2,115 +2,67 @@ ...@@ -2,115 +2,67 @@
// 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 'package:flutter_tools/src/features.dart';
import 'package:flutter_tools/src/web/chrome.dart';
import 'package:flutter_tools/src/web/workflow.dart';
import 'package:flutter_tools/src/globals.dart' as globals;
import 'package:mockito/mockito.dart';
import 'package:process/process.dart';
import 'package:platform/platform.dart'; import 'package:platform/platform.dart';
import 'package:flutter_tools/src/web/workflow.dart';
import '../../src/common.dart'; import '../../src/common.dart';
import '../../src/context.dart';
import '../../src/testbed.dart'; import '../../src/testbed.dart';
void main() { void main() {
group('WebWorkflow', () { testWithoutContext('WebWorkflow applies on Linux', () {
Testbed testbed; final WebWorkflow workflow = WebWorkflow(
MockPlatform notSupported; platform: FakePlatform(operatingSystem: 'linux'),
MockPlatform windows; featureFlags: TestFeatureFlags(isWebEnabled: true),
MockPlatform linux; );
MockPlatform macos;
MockProcessManager mockProcessManager;
WebWorkflow workflow;
setUpAll(() {
notSupported = MockPlatform(linux: false, windows: false, macos: false);
windows = MockPlatform(windows: true);
linux = MockPlatform(linux: true);
macos = MockPlatform(macos: true);
workflow = const WebWorkflow();
mockProcessManager = MockProcessManager();
testbed = Testbed(setup: () async {
globals.fs.file('chrome').createSync();
when(mockProcessManager.canRun('chrome')).thenReturn(true);
}, overrides: <Type, Generator>{
FeatureFlags: () => TestFeatureFlags(isWebEnabled: true),
ProcessManager: () => mockProcessManager,
});
});
test('Applies on Linux', () => testbed.run(() {
expect(workflow.appliesToHostPlatform, true); expect(workflow.appliesToHostPlatform, true);
expect(workflow.canLaunchDevices, true); expect(workflow.canLaunchDevices, true);
expect(workflow.canListDevices, true); expect(workflow.canListDevices, true);
expect(workflow.canListEmulators, false); expect(workflow.canListEmulators, false);
}, overrides: <Type, Generator>{ });
Platform: () => linux,
})); testWithoutContext('WebWorkflow applies on macOS', () {
final WebWorkflow workflow = WebWorkflow(
platform: FakePlatform(operatingSystem: 'macos'),
featureFlags: TestFeatureFlags(isWebEnabled: true),
);
test('Applies on macOS', () => testbed.run(() {
expect(workflow.appliesToHostPlatform, true); expect(workflow.appliesToHostPlatform, true);
expect(workflow.canLaunchDevices, true); expect(workflow.canLaunchDevices, true);
expect(workflow.canListDevices, true); expect(workflow.canListDevices, true);
expect(workflow.canListEmulators, false); expect(workflow.canListEmulators, false);
}, overrides: <Type, Generator>{ });
Platform: () => macos,
})); testWithoutContext('WebWorkflow applies on Windows', () {
final WebWorkflow workflow = WebWorkflow(
platform: FakePlatform(operatingSystem: 'windows'),
featureFlags: TestFeatureFlags(isWebEnabled: true),
);
test('Applies on Windows', () => testbed.run(() {
expect(workflow.appliesToHostPlatform, true); expect(workflow.appliesToHostPlatform, true);
expect(workflow.canLaunchDevices, true); expect(workflow.canLaunchDevices, true);
expect(workflow.canListDevices, true); expect(workflow.canListDevices, true);
expect(workflow.canListEmulators, false); expect(workflow.canListEmulators, false);
}, overrides: <Type, Generator>{ });
Platform: () => windows,
})); testWithoutContext('WebWorkflow does not apply on other platforms', () {
final WebWorkflow workflow = WebWorkflow(
platform: FakePlatform(operatingSystem: 'fuchsia'),
featureFlags: TestFeatureFlags(isWebEnabled: true),
);
test('does not apply on other platforms', () => testbed.run(() {
expect(workflow.appliesToHostPlatform, false); expect(workflow.appliesToHostPlatform, false);
}, overrides: <Type, Generator>{ });
Platform: () => notSupported,
})); testWithoutContext('WebWorkflow does not apply if feature flag is disabled', () {
final WebWorkflow workflow = WebWorkflow(
platform: FakePlatform(operatingSystem: 'linux'),
featureFlags: TestFeatureFlags(),
);
test('does not apply if feature flag is disabled', () => testbed.run(() {
expect(workflow.appliesToHostPlatform, false); expect(workflow.appliesToHostPlatform, false);
expect(workflow.canLaunchDevices, false); expect(workflow.canLaunchDevices, false);
expect(workflow.canListDevices, false); expect(workflow.canListDevices, false);
expect(workflow.canListEmulators, false); expect(workflow.canListEmulators, false);
}, overrides: <Type, Generator>{
Platform: () => macos,
FeatureFlags: () => TestFeatureFlags(isWebEnabled: false),
}));
});
}
class MockProcessManager extends Mock implements ProcessManager {}
class MockPlatform extends Mock implements Platform {
MockPlatform({
this.windows = false,
this.macos = false,
this.linux = false,
this.environment = const <String, String>{
kChromeEnvironment: 'chrome',
},
}); });
final bool windows;
final bool macos;
final bool linux;
@override
final Map<String, String> environment;
@override
bool get isLinux => linux;
@override
bool get isMacOS => macos;
@override
bool get isWindows => windows;
} }
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