Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(202)

Unified Diff: tests/compiler/dart2js/deferred_inline_restrictions_test.dart

Issue 1117223002: dart2js: Inline across deferred output units if that leads to reduced size. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Comments. Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tests/compiler/dart2js/deferred_inline_restrictions_test.dart
diff --git a/tests/compiler/dart2js/deferred_dont_inline_deferred_globals_test.dart b/tests/compiler/dart2js/deferred_inline_restrictions_test.dart
similarity index 54%
copy from tests/compiler/dart2js/deferred_dont_inline_deferred_globals_test.dart
copy to tests/compiler/dart2js/deferred_inline_restrictions_test.dart
index 2868661fe1ed70914a108876f567b1144993ee92..2bedda3f9cb3778c02a475cfb96e13c874757418 100644
--- a/tests/compiler/dart2js/deferred_dont_inline_deferred_globals_test.dart
+++ b/tests/compiler/dart2js/deferred_inline_restrictions_test.dart
@@ -2,8 +2,8 @@
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
-// Test that the additional runtime type support is output to the right
-// Files when using deferred loading.
+// Test that we do not accidentially leak code from deferred libraries but do
+// allow inlining of empty functions and from main.
import 'package:expect/expect.dart';
import "package:async_helper/async_helper.dart";
@@ -55,44 +55,83 @@ void main() {
return compiler.libraryLoader.lookupLibrary(Uri.parse(name));
}
- var main = compiler.mainApp.find(dart2js.Compiler.MAIN);
- Expect.isNotNull(main, "Could not find 'main'");
- compiler.deferredLoadTask.onResolutionComplete(main);
-
var outputUnitForElement = compiler.deferredLoadTask.outputUnitForElement;
var lib1 = lookupLibrary("memory:lib1.dart");
- var foo1 = lib1.find("finalVar");
- var ou_lib1 = outputUnitForElement(foo1);
+ var inlineMeAway = lib1.find("inlineMeAway");
+ var ou_lib1 = outputUnitForElement(inlineMeAway);
+
+ var lib3 = lookupLibrary("memory:lib3.dart");
+ var sameContextInline = lib3.find("sameContextInline");
+ var ou_lib3 = outputUnitForElement(sameContextInline);
+
+ // Test that we actually got differnt output units.
+ Expect.notEquals(ou_lib1.name, ou_lib3.name);
String mainOutput = outputs["main.js"].mem.toString();
String lib1Output = outputs["out_${ou_lib1.name}.part.js"].mem.toString();
- // Test that the deferred globals are not inlined into the main file.
- RegExp re1 = new RegExp(r"= .string1");
- RegExp re2 = new RegExp(r"= .string2");
- Expect.isTrue(re1.hasMatch(lib1Output));
- Expect.isTrue(re2.hasMatch(lib1Output));
+ String lib3Output = outputs["out_${ou_lib3.name}.part.js"].mem.toString();
+
+ RegExp re1 = new RegExp(r"inlined as empty");
+ RegExp re2 = new RegExp(r"inlined from main");
+ RegExp re3 = new RegExp(r"inlined from lib1");
+ RegExp re4 = new RegExp(r"inline same context");
+
+ // Test that inlineMeAway was inlined and its argument thus dropped.
Expect.isFalse(re1.hasMatch(mainOutput));
+
+ // Test that inlineFromMain was inlined and thus the string moved to lib1.
Expect.isFalse(re2.hasMatch(mainOutput));
+ Expect.isTrue(re2.hasMatch(lib1Output));
+
+ // Test that inlineFromLib1 was not inlined into main.
+ Expect.isFalse(re3.hasMatch(mainOutput));
+ Expect.isTrue(re3.hasMatch(lib1Output));
+
+ // Test that inlineSameContext was inlined into lib1.
+ Expect.isFalse(re4.hasMatch(lib3Output));
+ Expect.isTrue(re4.hasMatch(lib1Output));
}));
}
-// Make sure that deferred constants are not inlined into the main hunk.
+// Make sure that empty functions are inlined and that functions from
+// main also are inlined (assuming normal heuristics).
const Map MEMORY_SOURCE_FILES = const {"main.dart": """
import "dart:async";
import 'lib1.dart' deferred as lib1;
+import 'lib2.dart' deferred as lib2;
+
+inlineFromMain(x) => "inlined from main" + x;
void main() {
lib1.loadLibrary().then((_) {
- print(lib1.finalVar);
- print(lib1.globalVar);
- lib1.globalVar = "foobar";
- print(lib1.globalVar);
+ lib2.loadLibrary().then((_) {
+ lib1.test();
+ lib2.test();
+ print(lib1.inlineMeAway("inlined as empty"));
+ print(lib1.inlineFromLib1("should stay"));
+ });
});
}
""", "lib1.dart": """
import "main.dart" as main;
-final finalVar = "string1";
-var globalVar = "string2";
+import "lib3.dart" as lib3;
+
+inlineMeAway(x) {}
+
+inlineFromLib1(x) => "inlined from lib1" + x;
+
+test() {
+ print(main.inlineFromMain("should be inlined"));
+ print(lib3.sameContextInline("should be inlined"));
+}
+""", "lib2.dart": """
+import "lib3.dart" as lib3;
+
+test() {
+ print(lib3.sameContextInline("should be inlined"));
+}
+""", "lib3.dart": """
+sameContextInline(x) => "inline same context" + x;
"""};
« pkg/compiler/lib/src/ssa/builder.dart ('K') | « pkg/compiler/lib/src/ssa/builder.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698