Index: pkg/kernel/test/interpreter/suite.dart |
diff --git a/pkg/kernel/test/interpreter/suite.dart b/pkg/kernel/test/interpreter/suite.dart |
index 6d4f7dcb26eab37e0a3696a08ea6b5d65dc583b1..8c84abd1e2e05d1c7fac4e0369963828ff0bb87e 100644 |
--- a/pkg/kernel/test/interpreter/suite.dart |
+++ b/pkg/kernel/test/interpreter/suite.dart |
@@ -8,99 +8,34 @@ import 'dart:async' show Future; |
import 'dart:io' show File; |
-import 'package:front_end/physical_file_system.dart' show PhysicalFileSystem; |
- |
import 'package:testing/testing.dart' |
- show Chain, ChainContext, Result, Step, TestDescription, runMe; |
- |
-import 'package:front_end/src/fasta/testing/patched_sdk_location.dart' |
- show computePatchedSdk; |
+ show Chain, ChainContext, Result, Step, runMe; |
import 'package:kernel/ast.dart' show Program, Library; |
-import 'package:front_end/src/fasta/testing/kernel_chain.dart' show runDiff; |
- |
-import 'package:front_end/src/fasta/ticker.dart' show Ticker; |
- |
-import 'package:front_end/src/fasta/dill/dill_target.dart' show DillTarget; |
- |
-import 'package:front_end/src/fasta/kernel/kernel_target.dart' |
- show KernelTarget; |
- |
-import 'package:front_end/src/fasta/translate_uri.dart' show TranslateUri; |
- |
-import 'package:front_end/src/fasta/errors.dart' show InputError; |
- |
-import 'package:front_end/src/fasta/testing/patched_sdk_location.dart'; |
- |
-import 'package:kernel/kernel.dart' show loadProgramFromBinary; |
- |
-import 'package:kernel/target/targets.dart' show TargetFlags; |
- |
-import 'package:kernel/target/vm_fasta.dart' show VmFastaTarget; |
+import 'package:front_end/src/fasta/testing/kernel_chain.dart' |
+ show runDiff, Compile, CompileContext; |
import 'package:kernel/interpreter/interpreter.dart'; |
const String STRONG_MODE = " strong mode "; |
-class InterpreterContext extends ChainContext { |
+class InterpreterContext extends ChainContext implements CompileContext { |
final bool strongMode; |
- final TranslateUri uriTranslator; |
- |
final List<Step> steps; |
- Future<Program> platform; |
- |
- InterpreterContext(this.strongMode, this.uriTranslator) |
+ InterpreterContext(this.strongMode) |
: steps = <Step>[ |
- const FastaCompile(), |
+ const Compile(), |
const Interpret(), |
const MatchLogExpectation(".expect"), |
]; |
- Future<Program> loadPlatform() async { |
- Uri sdk = await computePatchedSdk(); |
- return loadProgramFromBinary(sdk.resolve('platform.dill').toFilePath()); |
- } |
- |
static Future<InterpreterContext> create( |
Chain suite, Map<String, String> environment) async { |
- Uri sdk = await computePatchedSdk(); |
- Uri packages = Uri.base.resolve(".packages"); |
bool strongMode = environment.containsKey(STRONG_MODE); |
- TranslateUri uriTranslator = await TranslateUri |
- .parse(PhysicalFileSystem.instance, sdk, packages: packages); |
- return new InterpreterContext(strongMode, uriTranslator); |
- } |
-} |
- |
-class FastaCompile extends Step<TestDescription, Program, InterpreterContext> { |
- const FastaCompile(); |
- |
- String get name => "fasta compile"; |
- |
- Future<Result<Program>> run( |
- TestDescription description, InterpreterContext context) async { |
- Program platform = await context.loadPlatform(); |
- Ticker ticker = new Ticker(); |
- DillTarget dillTarget = new DillTarget(ticker, context.uriTranslator, |
- new VmFastaTarget(new TargetFlags(strongMode: context.strongMode))); |
- platform.unbindCanonicalNames(); |
- dillTarget.loader.appendLibraries(platform); |
- KernelTarget sourceTarget = new KernelTarget( |
- PhysicalFileSystem.instance, dillTarget, context.uriTranslator); |
- |
- Program p; |
- try { |
- sourceTarget.read(description.uri); |
- await dillTarget.buildOutlines(); |
- await sourceTarget.buildOutlines(); |
- p = await sourceTarget.buildProgram(); |
- } on InputError catch (e, s) { |
- return fail(null, e.error, s); |
- } |
- return pass(p); |
+ return new InterpreterContext(strongMode); |
} |
} |