Chromium Code Reviews

Unified Diff: test/cctest/compiler/test-run-bytecode-graph-builder.cc

Issue 2343633002: [interpreter] Add a fast path for dynamic local load (Closed)
Patch Set: Fix extension slot word size in equality test Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Index: test/cctest/compiler/test-run-bytecode-graph-builder.cc
diff --git a/test/cctest/compiler/test-run-bytecode-graph-builder.cc b/test/cctest/compiler/test-run-bytecode-graph-builder.cc
index 52d3dcc3144e8a1fafaf6298a3d5d742b3463a7e..4400dad9856fc3d6255f288e988594e88bac3e1a 100644
--- a/test/cctest/compiler/test-run-bytecode-graph-builder.cc
+++ b/test/cctest/compiler/test-run-bytecode-graph-builder.cc
@@ -1067,6 +1067,55 @@ TEST(BytecodeGraphBuilderLookupSlot) {
}
}
+TEST(BytecodeGraphBuilderLookupContextSlot) {
+ HandleAndZoneScope scope;
+ Isolate* isolate = scope.main_isolate();
+ Zone* zone = scope.main_zone();
+ Factory* factory = isolate->factory();
+
+ // Testing with eval called in the current context.
+ const char* inner_eval_prologue = "var x = 0; function inner() {";
+ const char* inner_eval_epilogue = "}; return inner();";
+
+ ExpectedSnippet<0> inner_eval_snippets[] = {
+ {"eval(''); return x;", {factory->NewNumber(0)}},
+ {"eval('var x = 1'); return x;", {factory->NewNumber(1)}},
+ {"'use strict'; eval('var x = 1'); return x;", {factory->NewNumber(0)}}};
+
+ for (size_t i = 0; i < arraysize(inner_eval_snippets); i++) {
+ ScopedVector<char> script(1024);
+ SNPrintF(script, "function %s(p1) { %s %s %s } ; %s() ;", kFunctionName,
+ inner_eval_prologue, inner_eval_snippets[i].code_snippet,
+ inner_eval_epilogue, kFunctionName);
+
+ BytecodeGraphTester tester(isolate, zone, script.start());
+ auto callable = tester.GetCallable<>();
+ Handle<Object> return_value = callable().ToHandleChecked();
+ CHECK(return_value->SameValue(*inner_eval_snippets[i].return_value()));
+ }
+
+ // Testing with eval called in a parent context.
+ const char* outer_eval_prologue = "";
+ const char* outer_eval_epilogue =
+ "function inner() { return x; }; return inner();";
+
+ ExpectedSnippet<0> outer_eval_snippets[] = {
+ {"var x = 0; eval('');", {factory->NewNumber(0)}},
+ {"var x = 0; eval('var x = 1');", {factory->NewNumber(1)}},
+ {"'use strict'; var x = 0; eval('var x = 1');", {factory->NewNumber(0)}}};
+
+ for (size_t i = 0; i < arraysize(outer_eval_snippets); i++) {
+ ScopedVector<char> script(1024);
+ SNPrintF(script, "function %s() { %s %s %s } ; %s() ;", kFunctionName,
+ outer_eval_prologue, outer_eval_snippets[i].code_snippet,
+ outer_eval_epilogue, kFunctionName);
+
+ BytecodeGraphTester tester(isolate, zone, script.start());
+ auto callable = tester.GetCallable<>();
+ Handle<Object> return_value = callable().ToHandleChecked();
+ CHECK(return_value->SameValue(*outer_eval_snippets[i].return_value()));
+ }
+}
TEST(BytecodeGraphBuilderLookupSlotWide) {
HandleAndZoneScope scope;
« no previous file with comments | « src/interpreter/interpreter-assembler.cc ('k') | test/cctest/interpreter/bytecode_expectations/LookupSlot.golden » ('j') | no next file with comments »

Powered by Google App Engine