Commit b996f0a5 authored by Maya Lekova's avatar Maya Lekova Committed by Commit Bot

[test] Add tests that all Calls are handled by the serializer

R=neis@chromium.org

Bug: v8:7790
Change-Id: I41d212129fbdafbf7bc0fdf238f734c6f45ae5df
Reviewed-on: https://chromium-review.googlesource.com/c/1445811
Commit-Queue: Maya Lekova <mslekova@chromium.org>
Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#59210}
parent b645a259
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "src/api-inl.h" #include "src/api-inl.h"
#include "src/compiler/serializer-for-background-compilation.h" #include "src/compiler/serializer-for-background-compilation.h"
#include "src/compiler/zone-stats.h" #include "src/compiler/zone-stats.h"
#include "src/optimized-compilation-info.h"
#include "src/zone/zone.h" #include "src/zone/zone.h"
namespace v8 { namespace v8 {
...@@ -33,7 +34,15 @@ SerializerTester::SerializerTester(const char* source) ...@@ -33,7 +34,15 @@ SerializerTester::SerializerTester(const char* source)
function_string += " })();"; function_string += " })();";
Handle<JSFunction> function = Handle<JSFunction>::cast(v8::Utils::OpenHandle( Handle<JSFunction> function = Handle<JSFunction>::cast(v8::Utils::OpenHandle(
*v8::Local<v8::Function>::Cast(CompileRun(function_string.c_str())))); *v8::Local<v8::Function>::Cast(CompileRun(function_string.c_str()))));
Optimize(function, main_zone(), main_isolate(), 0, &broker_); uint32_t flags = i::OptimizedCompilationInfo::kInliningEnabled |
i::OptimizedCompilationInfo::kFunctionContextSpecializing |
i::OptimizedCompilationInfo::kAccessorInliningEnabled |
i::OptimizedCompilationInfo::kLoopPeelingEnabled |
i::OptimizedCompilationInfo::kBailoutOnUninitialized |
i::OptimizedCompilationInfo::kAllocationFoldingEnabled |
i::OptimizedCompilationInfo::kSplittingEnabled |
i::OptimizedCompilationInfo::kAnalyzeEnvironmentLiveness;
Optimize(function, main_zone(), main_isolate(), flags, &broker_);
function_ = JSFunctionRef(broker_, function); function_ = JSFunctionRef(broker_, function);
} }
...@@ -45,14 +54,15 @@ TEST(SerializeEmptyFunction) { ...@@ -45,14 +54,15 @@ TEST(SerializeEmptyFunction) {
// This helper function allows for testing weather an inlinee candidate // This helper function allows for testing weather an inlinee candidate
// was properly serialized. It expects that the top-level function (that is // was properly serialized. It expects that the top-level function (that is
// run through the SerializerTester) will return its inlinee candidate. // run through the SerializerTester) will return its inlinee candidate.
void CheckForSerializedInlinee(const char* source) { void CheckForSerializedInlinee(const char* source, int argc = 0,
Handle<Object> argv[] = {}) {
SerializerTester tester(source); SerializerTester tester(source);
JSFunctionRef f = tester.function(); JSFunctionRef f = tester.function();
CHECK(f.IsSerializedForCompilation()); CHECK(f.IsSerializedForCompilation());
MaybeHandle<Object> g_obj = Execution::Call( MaybeHandle<Object> g_obj = Execution::Call(
tester.isolate(), tester.function().object(), tester.isolate(), tester.function().object(),
tester.isolate()->factory()->undefined_value(), 0, nullptr); tester.isolate()->factory()->undefined_value(), argc, argv);
Handle<Object> g; Handle<Object> g;
CHECK(g_obj.ToHandle(&g)); CHECK(g_obj.ToHandle(&g));
...@@ -78,6 +88,80 @@ TEST(SerializeInlinedFunction) { ...@@ -78,6 +88,80 @@ TEST(SerializeInlinedFunction) {
" g(); return g;" " g(); return g;"
"}; f(); return f;"); "}; f(); return f;");
} }
TEST(SerializeCallUndefinedReceiver) {
CheckForSerializedInlinee(
"function g(a,b,c) {};"
"function f() {"
" g(1,2,3); return g;"
"}; f(); return f;");
}
TEST(SerializeCallUndefinedReceiver2) {
CheckForSerializedInlinee(
"function g(a,b) {};"
"function f() {"
" g(1,2); return g;"
"}; f(); return f;");
}
TEST(SerializeCallProperty) {
CheckForSerializedInlinee(
"let obj = {"
" g: function g(a,b,c) {}"
"};"
"function f() {"
" obj.g(1,2,3); return obj.g;"
"}; f(); return f;");
}
TEST(SerializeCallProperty2) {
CheckForSerializedInlinee(
"let obj = {"
" g: function g(a,b) {}"
"};"
"function f() {"
" obj.g(1,2); return obj.g;"
"}; f(); return f;");
}
TEST(SerializeCallAnyReceiver) {
CheckForSerializedInlinee(
"let obj = {"
" g: function g() {}"
"};"
"function f() {"
" with(obj) {"
" g(); return g;"
" };"
"};"
"f(); return f;");
}
TEST(SerializeCallWithSpread) {
CheckForSerializedInlinee(
"function g(args) {};"
"const arr = [1,2,3];"
"function f() {"
" g(...arr); return g;"
"}; f(); return f;");
}
// The following test causes the CallIC of `g` to turn megamorphic,
// thus allowing us to test if we forward arguments hints (`callee` in this
// example) and correctly serialize the inlining candidate `j`.
TEST(SerializeCallArguments) {
CheckForSerializedInlinee(
"function g(callee) { callee(); };"
"function h() {};"
"function i() {};"
"g(h); g(i);"
"function f() {"
" function j() {};"
" g(j);"
" return j;"
"}; f(); return f;");
}
} // namespace compiler } // namespace compiler
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
......
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