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 d8e60a771be277922e90471f776df12eb29ba492..c47db851d28ad059e849fa9f25b81327e4c30852 100644 |
--- a/test/cctest/compiler/test-run-bytecode-graph-builder.cc |
+++ b/test/cctest/compiler/test-run-bytecode-graph-builder.cc |
@@ -64,6 +64,7 @@ class BytecodeGraphTester { |
: isolate_(isolate), zone_(zone), script_(script) { |
i::FLAG_ignition = true; |
i::FLAG_always_opt = false; |
+ i::FLAG_allow_natives_syntax = true; |
// Set ignition filter flag via SetFlagsFromString to avoid double-free |
// (or potential leak with StrDup() based on ownership confusion). |
ScopedVector<char> ignition_filter(64); |
@@ -535,6 +536,74 @@ TEST(BytecodeGraphBuilderPropertyCall) { |
} |
+TEST(BytecodeGraphBuilderCallNew) { |
+ HandleAndZoneScope scope; |
+ Isolate* isolate = scope.main_isolate(); |
+ Zone* zone = scope.main_zone(); |
+ Factory* factory = isolate->factory(); |
+ |
+ ExpectedSnippet<0> snippets[] = { |
+ {"function counter() { this.count = 20; }\n" |
+ "function f() {\n" |
+ " var c = new counter();\n" |
+ " return c.count;\n" |
+ "}; f()", |
+ {factory->NewNumberFromInt(20)}}, |
+ {"function counter(arg0) { this.count = 17; this.x = arg0; }\n" |
+ "function f() {\n" |
+ " var c = new counter(6);\n" |
+ " return c.count + c.x;\n" |
+ "}; f()", |
+ {factory->NewNumberFromInt(23)}}, |
+ {"function counter(arg0, arg1) {\n" |
+ " this.count = 17; this.x = arg0; this.y = arg1;\n" |
+ "}\n" |
+ "function f() {\n" |
+ " var c = new counter(3, 5);\n" |
+ " return c.count + c.x + c.y;\n" |
+ "}; f()", |
+ {factory->NewNumberFromInt(25)}}, |
+ }; |
+ |
+ size_t num_snippets = sizeof(snippets) / sizeof(snippets[0]); |
+ for (size_t i = 0; i < num_snippets; i++) { |
+ BytecodeGraphTester tester(isolate, zone, snippets[i].code_snippet); |
+ auto callable = tester.GetCallable<>(); |
+ Handle<Object> return_value = callable().ToHandleChecked(); |
+ CHECK(return_value->SameValue(*snippets[i].return_value())); |
+ } |
+} |
+ |
+ |
+TEST(BytecodeGraphBuilderCallRuntime) { |
+ HandleAndZoneScope scope; |
+ Isolate* isolate = scope.main_isolate(); |
+ Zone* zone = scope.main_zone(); |
+ Factory* factory = isolate->factory(); |
+ |
+ ExpectedSnippet<1> snippets[] = { |
+ {"function f(arg0) { return %MaxSmi(); }\nf()", |
+ {factory->NewNumberFromInt(Smi::kMaxValue), factory->undefined_value()}}, |
+ {"function f(arg0) { return %IsArray(arg0) }\nf(undefined)", |
+ {factory->true_value(), BytecodeGraphTester::NewObject("[1, 2, 3]")}}, |
+ {"function f(arg0) { return %Add(arg0, 2) }\nf(1)", |
+ {factory->NewNumberFromInt(5), factory->NewNumberFromInt(3)}}, |
+ {"function f(arg0) { return %spread_arguments(arg0).length }\nf([])", |
+ {factory->NewNumberFromInt(3), |
+ BytecodeGraphTester::NewObject("[1, 2, 3]")}}, |
+ }; |
+ |
+ size_t num_snippets = sizeof(snippets) / sizeof(snippets[0]); |
+ for (size_t i = 0; i < num_snippets; i++) { |
+ BytecodeGraphTester tester(isolate, zone, snippets[i].code_snippet); |
+ auto callable = tester.GetCallable<Handle<Object>>(); |
+ Handle<Object> return_value = |
+ callable(snippets[i].parameter(0)).ToHandleChecked(); |
+ CHECK(return_value->SameValue(*snippets[i].return_value())); |
+ } |
+} |
+ |
+ |
TEST(BytecodeGraphBuilderGlobals) { |
HandleAndZoneScope scope; |
Isolate* isolate = scope.main_isolate(); |