Unverified Commit 6135091d authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

Revert "[flutter_tools] only copy cached dill after startup (#58188)" (#58454)

This reverts commit 39d1e4b7.
parent cf17e8bc
...@@ -434,7 +434,6 @@ class _ResidentWebRunner extends ResidentWebRunner { ...@@ -434,7 +434,6 @@ class _ResidentWebRunner extends ResidentWebRunner {
return 1; return 1;
} }
device.generator.accept(); device.generator.accept();
cacheInitialDillCompilation();
} else { } else {
await buildWeb( await buildWeb(
flutterProject, flutterProject,
......
...@@ -1099,19 +1099,6 @@ abstract class ResidentRunner { ...@@ -1099,19 +1099,6 @@ abstract class ResidentRunner {
); );
} }
@protected
void cacheInitialDillCompilation() {
globals.logger.printTrace('Caching compiled dill');
final File outputDill = globals.fs.file(dillOutputPath);
if (outputDill.existsSync()) {
final String copyPath = getDefaultCachedKernelPath(
trackWidgetCreation: trackWidgetCreation,
);
globals.fs.file(copyPath).parent.createSync(recursive: true);
outputDill.copySync(copyPath);
}
}
/// If the [reloadSources] parameter is not null the 'reloadSources' service /// If the [reloadSources] parameter is not null the 'reloadSources' service
/// will be registered. /// will be registered.
// //
...@@ -1221,9 +1208,14 @@ abstract class ResidentRunner { ...@@ -1221,9 +1208,14 @@ abstract class ResidentRunner {
@mustCallSuper @mustCallSuper
Future<void> preExit() async { Future<void> preExit() async {
// If _dillOutputPath is null, the tool created a temporary directory for // If _dillOutputPath is null, we created a temporary directory for the dill.
// the dill.
if (_dillOutputPath == null && artifactDirectory.existsSync()) { if (_dillOutputPath == null && artifactDirectory.existsSync()) {
final File outputDill = globals.fs.file(dillOutputPath);
if (outputDill.existsSync()) {
outputDill.copySync(getDefaultCachedKernelPath(
trackWidgetCreation: trackWidgetCreation,
));
}
artifactDirectory.deleteSync(recursive: true); artifactDirectory.deleteSync(recursive: true);
} }
} }
......
...@@ -63,6 +63,7 @@ class DeviceReloadReport { ...@@ -63,6 +63,7 @@ class DeviceReloadReport {
List<vm_service.ReloadReport> reports; // List has one report per Flutter view. List<vm_service.ReloadReport> reports; // List has one report per Flutter view.
} }
// TODO(mklim): Test this, flutter/flutter#23031.
class HotRunner extends ResidentRunner { class HotRunner extends ResidentRunner {
HotRunner( HotRunner(
List<FlutterDevice> devices, { List<FlutterDevice> devices, {
...@@ -387,7 +388,6 @@ class HotRunner extends ResidentRunner { ...@@ -387,7 +388,6 @@ class HotRunner extends ResidentRunner {
if (!results.every((bool passed) => passed)) { if (!results.every((bool passed) => passed)) {
return 1; return 1;
} }
cacheInitialDillCompilation();
} on Exception catch (err) { } on Exception catch (err) {
globals.printError(err.toString()); globals.printError(err.toString());
return 1; return 1;
......
...@@ -521,12 +521,22 @@ void main() { ...@@ -521,12 +521,22 @@ void main() {
expect(otherRunner.artifactDirectory.path, contains('foobar')); expect(otherRunner.artifactDirectory.path, contains('foobar'));
})); }));
test('ResidentRunner deletes artifact directory on preExit', () => testbed.run(() async { test('ResidentRunner copies output dill to cache location during preExit', () => testbed.run(() async {
fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[]); fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[]);
residentRunner.artifactDirectory.childFile('app.dill').createSync(); residentRunner.artifactDirectory.childFile('app.dill').writeAsStringSync('hello');
await residentRunner.preExit(); await residentRunner.preExit();
final File cacheDill = globals.fs.file(globals.fs.path.join(getBuildDirectory(), 'cache.dill'));
expect(residentRunner.artifactDirectory, isNot(exists)); expect(cacheDill, exists);
expect(cacheDill.readAsStringSync(), 'hello');
}));
test('ResidentRunner handles output dill missing during preExit', () => testbed.run(() async {
fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[]);
await residentRunner.preExit();
final File cacheDill = globals.fs.file(globals.fs.path.join(getBuildDirectory(), 'cache.dill'));
expect(cacheDill, isNot(exists));
})); }));
test('ResidentRunner can run source generation', () => testbed.run(() async { test('ResidentRunner can run source generation', () => testbed.run(() async {
...@@ -1050,64 +1060,6 @@ void main() { ...@@ -1050,64 +1060,6 @@ void main() {
expect(await globals.fs.file('foo').readAsString(), testUri.toString()); expect(await globals.fs.file('foo').readAsString(), testUri.toString());
})); }));
test('HotRunner copies compiled app.dill to cache during startup', () => testbed.run(() async {
fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[
listViews,
listViews,
]);
setWsAddress(testUri, fakeVmServiceHost.vmService);
globals.fs.file(globals.fs.path.join('lib', 'main.dart')).createSync(recursive: true);
residentRunner = HotRunner(
<FlutterDevice>[
mockFlutterDevice,
],
stayResident: false,
debuggingOptions: DebuggingOptions.enabled(BuildInfo.debug),
);
residentRunner.artifactDirectory.childFile('app.dill').writeAsStringSync('ABC');
when(mockFlutterDevice.runHot(
hotRunner: anyNamed('hotRunner'),
route: anyNamed('route'),
)).thenAnswer((Invocation invocation) async {
return 0;
});
await residentRunner.run();
expect(await globals.fs.file(globals.fs.path.join('build', 'cache.dill')).readAsString(), 'ABC');
}));
test('HotRunner copies compiled app.dill to cache during startup with --track-widget-creation', () => testbed.run(() async {
fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[
listViews,
listViews,
]);
setWsAddress(testUri, fakeVmServiceHost.vmService);
globals.fs.file(globals.fs.path.join('lib', 'main.dart')).createSync(recursive: true);
residentRunner = HotRunner(
<FlutterDevice>[
mockFlutterDevice,
],
stayResident: false,
debuggingOptions: DebuggingOptions.enabled(const BuildInfo(
BuildMode.debug,
'',
treeShakeIcons: false,
trackWidgetCreation: true,
)),
);
residentRunner.artifactDirectory.childFile('app.dill').writeAsStringSync('ABC');
when(mockFlutterDevice.runHot(
hotRunner: anyNamed('hotRunner'),
route: anyNamed('route'),
)).thenAnswer((Invocation invocation) async {
return 0;
});
await residentRunner.run();
expect(await globals.fs.file(globals.fs.path.join('build', 'cache.dill.track.dill')).readAsString(), 'ABC');
}));
test('HotRunner unforwards device ports', () => testbed.run(() async { test('HotRunner unforwards device ports', () => testbed.run(() async {
fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[ fakeVmServiceHost = FakeVmServiceHost(requests: <VmServiceExpectation>[
listViews, listViews,
......
...@@ -257,21 +257,13 @@ void main() { ...@@ -257,21 +257,13 @@ void main() {
expect(bufferLogger.statusText, contains('Debug service listening on ws://127.0.0.1/abcd/')); expect(bufferLogger.statusText, contains('Debug service listening on ws://127.0.0.1/abcd/'));
expect(debugConnectionInfo.wsUri.toString(), 'ws://127.0.0.1/abcd/'); expect(debugConnectionInfo.wsUri.toString(), 'ws://127.0.0.1/abcd/');
}, overrides: <Type, Generator>{ }, overrides: <Type, Generator>{
Logger: () => DelegateLogger(BufferLogger.test()), Logger: () => DelegateLogger(BufferLogger(
})); terminal: AnsiTerminal(
stdio: null,
test('WebRunner copies compiled app.dill to cache during startup', () => testbed.run(() async { platform: const LocalPlatform(),
fakeVmServiceHost = FakeVmServiceHost(requests: kAttachExpectations.toList()); ),
_setupMocks(); outputPreferences: OutputPreferences.test(),
)),
residentWebRunner.artifactDirectory.childFile('app.dill').writeAsStringSync('ABC');
final Completer<DebugConnectionInfo> connectionInfoCompleter = Completer<DebugConnectionInfo>();
unawaited(residentWebRunner.run(
connectionInfoCompleter: connectionInfoCompleter,
));
await connectionInfoCompleter.future;
expect(await globals.fs.file(globals.fs.path.join('build', 'cache.dill')).readAsString(), 'ABC');
})); }));
test('Can successfully run without an index.html including status warning', () => testbed.run(() async { test('Can successfully run without an index.html including status warning', () => testbed.run(() async {
......
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