Unverified Commit 32917500 authored by Lau Ching Jun's avatar Lau Ching Jun Committed by GitHub

Use the new `getIsolatePauseEvent` method from VM service to check for pause event. (#128834)

The `getIsolate` method returns the full list of libraries which can be huge for large apps. Using the more speficic API to only fetch what we need improves hot reload performance.

*Replace this paragraph with a description of what this PR is changing or adding, and why. Consider including before/after screenshots.*

*List which issues are fixed by this PR. You must list at least one issue.*

*If you had to change anything in the [flutter/tests] repo, include a link to the migration guide as per the [breaking change policy].*
parent 80935ad9
...@@ -1298,9 +1298,8 @@ Future<ReassembleResult> _defaultReassembleHelper( ...@@ -1298,9 +1298,8 @@ Future<ReassembleResult> _defaultReassembleHelper(
for (final FlutterView view in views) { for (final FlutterView view in views) {
// Check if the isolate is paused, and if so, don't reassemble. Ignore the // Check if the isolate is paused, and if so, don't reassemble. Ignore the
// PostPauseEvent event - the client requesting the pause will resume the app. // PostPauseEvent event - the client requesting the pause will resume the app.
final vm_service.Isolate? isolate = await device!.vmService! final vm_service.Event? pauseEvent = await device!.vmService!
.getIsolateOrNull(view.uiIsolate!.id!); .getIsolatePauseEventOrNull(view.uiIsolate!.id!);
final vm_service.Event? pauseEvent = isolate?.pauseEvent;
if (pauseEvent != null if (pauseEvent != null
&& isPauseEvent(pauseEvent.kind!) && isPauseEvent(pauseEvent.kind!)
&& pauseEvent.kind != vm_service.EventKind.kPausePostRequest) { && pauseEvent.kind != vm_service.EventKind.kPausePostRequest) {
...@@ -1364,16 +1363,13 @@ Future<ReassembleResult> _defaultReassembleHelper( ...@@ -1364,16 +1363,13 @@ Future<ReassembleResult> _defaultReassembleHelper(
int postReloadPausedIsolatesFound = 0; int postReloadPausedIsolatesFound = 0;
String? serviceEventKind; String? serviceEventKind;
for (final FlutterView view in reassembleViews.keys) { for (final FlutterView view in reassembleViews.keys) {
final vm_service.Isolate? isolate = await reassembleViews[view]! final vm_service.Event? pauseEvent = await reassembleViews[view]!
.getIsolateOrNull(view.uiIsolate!.id!); .getIsolatePauseEventOrNull(view.uiIsolate!.id!);
if (isolate == null) { if (pauseEvent != null && isPauseEvent(pauseEvent.kind!)) {
continue;
}
if (isolate.pauseEvent != null && isPauseEvent(isolate.pauseEvent!.kind!)) {
postReloadPausedIsolatesFound += 1; postReloadPausedIsolatesFound += 1;
if (serviceEventKind == null) { if (serviceEventKind == null) {
serviceEventKind = isolate.pauseEvent!.kind; serviceEventKind = pauseEvent.kind;
} else if (serviceEventKind != isolate.pauseEvent!.kind) { } else if (serviceEventKind != pauseEvent.kind) {
serviceEventKind = ''; // many kinds serviceEventKind = ''; // many kinds
} }
} }
......
...@@ -1110,6 +1110,22 @@ class FlutterVmService { ...@@ -1110,6 +1110,22 @@ class FlutterVmService {
}); });
} }
/// Attempt to retrieve the isolate pause event with id [isolateId], or `null` if it has
/// been collected.
Future<vm_service.Event?> getIsolatePauseEventOrNull(String isolateId) async {
return service.getIsolatePauseEvent(isolateId)
.then<vm_service.Event?>(
(vm_service.Event event) => event,
onError: (Object? error, StackTrace stackTrace) {
if (error is vm_service.SentinelException ||
error == null ||
(error is vm_service.RPCError && error.code == RPCErrorCodes.kServiceDisappeared)) {
return null;
}
return Future<vm_service.Event?>.error(error, stackTrace);
});
}
/// Create a new development file system on the device. /// Create a new development file system on the device.
Future<vm_service.Response> createDevFS(String fsName) { Future<vm_service.Response> createDevFS(String fsName) {
// Call the unchecked version of `callServiceExtension` because the caller // Call the unchecked version of `callServiceExtension` because the caller
......
...@@ -45,12 +45,19 @@ import '../src/fake_vm_services.dart'; ...@@ -45,12 +45,19 @@ import '../src/fake_vm_services.dart';
import '../src/fakes.dart'; import '../src/fakes.dart';
import '../src/testbed.dart'; import '../src/testbed.dart';
final vm_service.Event fakeUnpausedEvent = vm_service.Event(
kind: vm_service.EventKind.kResume,
timestamp: 0
);
final vm_service.Event fakePausedEvent = vm_service.Event(
kind: vm_service.EventKind.kPauseException,
timestamp: 0
);
final vm_service.Isolate fakeUnpausedIsolate = vm_service.Isolate( final vm_service.Isolate fakeUnpausedIsolate = vm_service.Isolate(
id: '1', id: '1',
pauseEvent: vm_service.Event( pauseEvent: fakeUnpausedEvent,
kind: vm_service.EventKind.kResume,
timestamp: 0
),
breakpoints: <vm_service.Breakpoint>[], breakpoints: <vm_service.Breakpoint>[],
extensionRPCs: <String>[], extensionRPCs: <String>[],
libraries: <vm_service.LibraryRef>[ libraries: <vm_service.LibraryRef>[
...@@ -72,10 +79,7 @@ final vm_service.Isolate fakeUnpausedIsolate = vm_service.Isolate( ...@@ -72,10 +79,7 @@ final vm_service.Isolate fakeUnpausedIsolate = vm_service.Isolate(
final vm_service.Isolate fakePausedIsolate = vm_service.Isolate( final vm_service.Isolate fakePausedIsolate = vm_service.Isolate(
id: '1', id: '1',
pauseEvent: vm_service.Event( pauseEvent: fakePausedEvent,
kind: vm_service.EventKind.kPauseException,
timestamp: 0
),
breakpoints: <vm_service.Breakpoint>[ breakpoints: <vm_service.Breakpoint>[
vm_service.Breakpoint( vm_service.Breakpoint(
breakpointNumber: 123, breakpointNumber: 123,
...@@ -537,11 +541,11 @@ void main() { ...@@ -537,11 +541,11 @@ void main() {
listViews, listViews,
listViews, listViews,
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'getIsolate', method: 'getIsolatePauseEvent',
args: <String, Object>{ args: <String, Object>{
'isolateId': '1', 'isolateId': '1',
}, },
jsonResponse: fakeUnpausedIsolate.toJson(), jsonResponse: fakeUnpausedEvent.toJson(),
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'ext.flutter.reassemble', method: 'ext.flutter.reassemble',
...@@ -604,11 +608,11 @@ void main() { ...@@ -604,11 +608,11 @@ void main() {
}, },
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'getIsolate', method: 'getIsolatePauseEvent',
args: <String, Object>{ args: <String, Object>{
'isolateId': '1', 'isolateId': '1',
}, },
jsonResponse: fakeUnpausedIsolate.toJson(), jsonResponse: fakeUnpausedEvent.toJson(),
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'ext.flutter.reassemble', method: 'ext.flutter.reassemble',
...@@ -728,11 +732,11 @@ void main() { ...@@ -728,11 +732,11 @@ void main() {
}, },
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'getIsolate', method: 'getIsolatePauseEvent',
args: <String, Object>{ args: <String, Object>{
'isolateId': '1', 'isolateId': '1',
}, },
jsonResponse: fakeUnpausedIsolate.toJson(), jsonResponse: fakeUnpausedEvent.toJson(),
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'ext.flutter.reassemble', method: 'ext.flutter.reassemble',
...@@ -791,11 +795,11 @@ void main() { ...@@ -791,11 +795,11 @@ void main() {
}, },
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'getIsolate', method: 'getIsolatePauseEvent',
args: <String, Object>{ args: <String, Object>{
'isolateId': '1', 'isolateId': '1',
}, },
jsonResponse: fakeUnpausedIsolate.toJson(), jsonResponse: fakeUnpausedEvent.toJson(),
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'ext.flutter.fastReassemble', method: 'ext.flutter.fastReassemble',
...@@ -882,11 +886,11 @@ void main() { ...@@ -882,11 +886,11 @@ void main() {
}, },
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'getIsolate', method: 'getIsolatePauseEvent',
args: <String, Object>{ args: <String, Object>{
'isolateId': '1', 'isolateId': '1',
}, },
jsonResponse: fakeUnpausedIsolate.toJson(), jsonResponse: fakeUnpausedEvent.toJson(),
), ),
FakeVmServiceRequest( FakeVmServiceRequest(
method: 'ext.flutter.fastReassemble', method: 'ext.flutter.fastReassemble',
......
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