Unverified Commit 6c88b2e9 authored by Jonah Williams's avatar Jonah Williams Committed by GitHub

restore compileExpressionService (#24063)

parent fe6798bd
...@@ -28,6 +28,7 @@ import '../bundle.dart'; ...@@ -28,6 +28,7 @@ import '../bundle.dart';
import '../compile.dart'; import '../compile.dart';
import '../dart/package_map.dart'; import '../dart/package_map.dart';
import '../globals.dart'; import '../globals.dart';
import '../vmservice.dart';
import 'watcher.dart'; import 'watcher.dart';
/// The timeout we give the test process to connect to the test harness /// The timeout we give the test process to connect to the test harness
...@@ -450,6 +451,22 @@ class _FlutterPlatform extends PlatformPlugin { ...@@ -450,6 +451,22 @@ class _FlutterPlatform extends PlatformPlugin {
return remoteChannel; return remoteChannel;
} }
Future<String> _compileExpressionService(String isolateId, String expression,
List<String> definitions, List<String> typeDefinitions,
String libraryUri, String klass, bool isStatic,
) async {
if (compiler == null || compiler.compiler == null) {
throw 'Compiler is not set up properly to compile $expression';
}
final CompilerOutput compilerOutput =
await compiler.compiler.compileExpression(expression, definitions,
typeDefinitions, libraryUri, klass, isStatic);
if (compilerOutput != null && compilerOutput.outputFilename != null) {
return base64.encode(fs.file(compilerOutput.outputFilename).readAsBytesSync());
}
throw 'Failed to compile $expression';
}
Future<_AsyncError> _startTest( Future<_AsyncError> _startTest(
String testPath, String testPath,
StreamChannel<dynamic> controller, StreamChannel<dynamic> controller,
...@@ -573,6 +590,14 @@ class _FlutterPlatform extends PlatformPlugin { ...@@ -573,6 +590,14 @@ class _FlutterPlatform extends PlatformPlugin {
printTrace('test $ourTestCount: using observatory uri $detectedUri from pid ${process.pid}'); printTrace('test $ourTestCount: using observatory uri $detectedUri from pid ${process.pid}');
} }
processObservatoryUri = detectedUri; processObservatoryUri = detectedUri;
{
printTrace('Connecting to service protocol: $processObservatoryUri');
final Future<VMService> localVmService = VMService.connect(processObservatoryUri,
compileExpression: _compileExpressionService);
localVmService.then((VMService vmservice) {
printTrace('Successfully connected to service protocol: $processObservatoryUri');
});
}
gotProcessObservatoryUri.complete(); gotProcessObservatoryUri.complete();
watcher?.handleStartedProcess( watcher?.handleStartedProcess(
ProcessEvent(ourTestCount, process, processObservatoryUri)); ProcessEvent(ourTestCount, process, processObservatoryUri));
......
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