[api] Deprecate v8::ScriptCompiler::CompileFunctionInContext

- Introduce v8::ScriptCompiler::CompileFunction
- Deprecate v8::ScriptCompiler::CompileFunctionInContext
- Add v8::Function::GetUnboundScript
- Add v8::Script::GetResourceName

The ScriptOrModule out-parameter is only used by NodeJS since we don't
allow arbitrary objects has host-defined options and they need a way to
keep the options alive.

This CL deprecates the out-parameter and adds helper methods to
address the most common use-cases.

The final fix still requires more fundamental changes on how host-defined
options are handled.

Bug: chromium:1244145
Change-Id: Id29de53521ad626c41391b8300146ee37a1b8a51
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3245117
Reviewed-by: Victor Gomes <victorgomes@chromium.org>
Reviewed-by: Jakob Gruber <jgruber@chromium.org>
Commit-Queue: Jakob Gruber <jgruber@chromium.org>
Auto-Submit: Camillo Bruni <cbruni@chromium.org>
Cr-Commit-Position: refs/heads/main@{#77564}
This commit is contained in:
Camillo Bruni 2021-10-26 15:36:11 +02:00 committed by V8 LUCI CQ
parent 91475f958a
commit 78387ca75d
9 changed files with 120 additions and 75 deletions

View File

@ -18,6 +18,7 @@
namespace v8 { namespace v8 {
class Context; class Context;
class UnboundScript;
/** /**
* A JavaScript function object (ECMA-262, 15.3). * A JavaScript function object (ECMA-262, 15.3).
@ -58,6 +59,8 @@ class V8_EXPORT Function : public Object {
void SetName(Local<String> name); void SetName(Local<String> name);
Local<Value> GetName() const; Local<Value> GetName() const;
MaybeLocal<UnboundScript> GetUnboundScript() const;
/** /**
* Name inferred from variable or property assignment of this function. * Name inferred from variable or property assignment of this function.
* Used to facilitate debugging and profiling of JavaScript code written * Used to facilitate debugging and profiling of JavaScript code written

View File

@ -345,6 +345,12 @@ class V8_EXPORT Script {
* Returns the corresponding context-unbound script. * Returns the corresponding context-unbound script.
*/ */
Local<UnboundScript> GetUnboundScript(); Local<UnboundScript> GetUnboundScript();
/**
* The name that was passed by the embedder as ResourceName to the
* ScriptOrigin. This can be either a v8::String or v8::Undefined.
*/
Local<Value> GetResourceName();
}; };
enum class ScriptType { kClassic, kModule }; enum class ScriptType { kClassic, kModule };
@ -682,6 +688,7 @@ class V8_EXPORT ScriptCompiler {
* It is possible to specify multiple context extensions (obj in the above * It is possible to specify multiple context extensions (obj in the above
* example). * example).
*/ */
V8_DEPRECATE_SOON("Use CompileFunction")
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInContext( static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInContext(
Local<Context> context, Source* source, size_t arguments_count, Local<Context> context, Source* source, size_t arguments_count,
Local<String> arguments[], size_t context_extension_count, Local<String> arguments[], size_t context_extension_count,
@ -689,6 +696,12 @@ class V8_EXPORT ScriptCompiler {
CompileOptions options = kNoCompileOptions, CompileOptions options = kNoCompileOptions,
NoCacheReason no_cache_reason = kNoCacheNoReason, NoCacheReason no_cache_reason = kNoCacheNoReason,
Local<ScriptOrModule>* script_or_module_out = nullptr); Local<ScriptOrModule>* script_or_module_out = nullptr);
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunction(
Local<Context> context, Source* source, size_t arguments_count = 0,
Local<String> arguments[] = nullptr, size_t context_extension_count = 0,
Local<Object> context_extensions[] = nullptr,
CompileOptions options = kNoCompileOptions,
NoCacheReason no_cache_reason = kNoCacheNoReason);
/** /**
* Creates and returns code cache for the specified unbound_script. * Creates and returns code cache for the specified unbound_script.
@ -707,7 +720,7 @@ class V8_EXPORT ScriptCompiler {
/** /**
* Creates and returns code cache for the specified function that was * Creates and returns code cache for the specified function that was
* previously produced by CompileFunctionInContext. * previously produced by CompileFunction.
* This will return nullptr if the script cannot be serialized. The * This will return nullptr if the script cannot be serialized. The
* CachedData returned by this function should be owned by the caller. * CachedData returned by this function should be owned by the caller.
*/ */
@ -717,6 +730,13 @@ class V8_EXPORT ScriptCompiler {
static V8_WARN_UNUSED_RESULT MaybeLocal<UnboundScript> CompileUnboundInternal( static V8_WARN_UNUSED_RESULT MaybeLocal<UnboundScript> CompileUnboundInternal(
Isolate* isolate, Source* source, CompileOptions options, Isolate* isolate, Source* source, CompileOptions options,
NoCacheReason no_cache_reason); NoCacheReason no_cache_reason);
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInternal(
Local<Context> context, Source* source, size_t arguments_count,
Local<String> arguments[], size_t context_extension_count,
Local<Object> context_extensions[], CompileOptions options,
NoCacheReason no_cache_reason,
Local<ScriptOrModule>* script_or_module_out);
}; };
ScriptCompiler::Source::Source(Local<String> string, const ScriptOrigin& origin, ScriptCompiler::Source::Source(Local<String> string, const ScriptOrigin& origin,

View File

@ -2127,12 +2127,23 @@ Local<PrimitiveArray> ScriptOrModule::GetHostDefinedOptions() {
} }
Local<UnboundScript> Script::GetUnboundScript() { Local<UnboundScript> Script::GetUnboundScript() {
i::Handle<i::Object> obj = Utils::OpenHandle(this); i::DisallowGarbageCollection no_gc;
i::SharedFunctionInfo sfi = i::JSFunction::cast(*obj).shared(); i::Handle<i::JSFunction> obj = Utils::OpenHandle(this);
i::SharedFunctionInfo sfi = (*obj).shared();
i::Isolate* isolate = sfi.GetIsolate(); i::Isolate* isolate = sfi.GetIsolate();
return ToApiHandle<UnboundScript>(i::handle(sfi, isolate)); return ToApiHandle<UnboundScript>(i::handle(sfi, isolate));
} }
Local<Value> Script::GetResourceName() {
i::DisallowGarbageCollection no_gc;
i::Handle<i::JSFunction> func = Utils::OpenHandle(this);
i::SharedFunctionInfo sfi = (*func).shared();
i::Isolate* isolate = func->GetIsolate();
CHECK(sfi.script().IsScript());
return ToApiHandle<Value>(
i::handle(i::Script::cast(sfi.script()).name(), isolate));
}
// static // static
Local<PrimitiveArray> PrimitiveArray::New(Isolate* v8_isolate, int length) { Local<PrimitiveArray> PrimitiveArray::New(Isolate* v8_isolate, int length) {
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate); i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate);
@ -2594,9 +2605,32 @@ bool IsIdentifier(i::Isolate* isolate, i::Handle<i::String> string) {
} }
return true; return true;
} }
} // anonymous namespace } // namespace
// static
V8_WARN_UNUSED_RESULT MaybeLocal<Function> ScriptCompiler::CompileFunction(
Local<Context> context, Source* source, size_t arguments_count,
Local<String> arguments[], size_t context_extension_count,
Local<Object> context_extensions[], CompileOptions options,
NoCacheReason no_cache_reason) {
return CompileFunctionInternal(context, source, arguments_count, arguments,
context_extension_count, context_extensions,
options, no_cache_reason, nullptr);
}
// static
MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext( MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext(
Local<Context> context, Source* source, size_t arguments_count,
Local<String> arguments[], size_t context_extension_count,
Local<Object> context_extensions[], CompileOptions options,
NoCacheReason no_cache_reason,
Local<ScriptOrModule>* script_or_module_out) {
return CompileFunctionInternal(
context, source, arguments_count, arguments, context_extension_count,
context_extensions, options, no_cache_reason, script_or_module_out);
}
MaybeLocal<Function> ScriptCompiler::CompileFunctionInternal(
Local<Context> v8_context, Source* source, size_t arguments_count, Local<Context> v8_context, Source* source, size_t arguments_count,
Local<String> arguments[], size_t context_extension_count, Local<String> arguments[], size_t context_extension_count,
Local<Object> context_extensions[], CompileOptions options, Local<Object> context_extensions[], CompileOptions options,
@ -2605,7 +2639,7 @@ MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext(
Local<Function> result; Local<Function> result;
{ {
PREPARE_FOR_EXECUTION(v8_context, ScriptCompiler, CompileFunctionInContext, PREPARE_FOR_EXECUTION(v8_context, ScriptCompiler, CompileFunction,
Function); Function);
TRACE_EVENT_CALL_STATS_SCOPED(isolate, "v8", "V8.ScriptCompiler"); TRACE_EVENT_CALL_STATS_SCOPED(isolate, "v8", "V8.ScriptCompiler");
@ -5288,6 +5322,14 @@ int Function::GetScriptColumnNumber() const {
return kLineOffsetNotFound; return kLineOffsetNotFound;
} }
MaybeLocal<UnboundScript> Function::GetUnboundScript() const {
i::Handle<i::Object> self = Utils::OpenHandle(this);
if (!self->IsJSFunction()) return MaybeLocal<UnboundScript>();
i::SharedFunctionInfo sfi = i::JSFunction::cast(*self).shared();
i::Isolate* isolate = sfi.GetIsolate();
return ToApiHandle<UnboundScript>(i::handle(sfi, isolate));
}
int Function::ScriptId() const { int Function::ScriptId() const {
i::JSReceiver self = *Utils::OpenHandle(this); i::JSReceiver self = *Utils::OpenHandle(this);
if (!self.IsJSFunction()) return v8::UnboundScript::kNoScriptId; if (!self.IsJSFunction()) return v8::UnboundScript::kNoScriptId;

View File

@ -2160,7 +2160,7 @@ namespace {
debug::Location GetDebugLocation(Handle<Script> script, int source_position) { debug::Location GetDebugLocation(Handle<Script> script, int source_position) {
Script::PositionInfo info; Script::PositionInfo info;
Script::GetPositionInfo(script, source_position, &info, Script::WITH_OFFSET); Script::GetPositionInfo(script, source_position, &info, Script::WITH_OFFSET);
// V8 provides ScriptCompiler::CompileFunctionInContext method which takes // V8 provides ScriptCompiler::CompileFunction method which takes
// expression and compile it as anonymous function like (function() .. // expression and compile it as anonymous function like (function() ..
// expression ..). To produce correct locations for stmts inside of this // expression ..). To produce correct locations for stmts inside of this
// expression V8 compile this function with negative offset. Instead of stmt // expression V8 compile this function with negative offset. Instead of stmt

View File

@ -245,7 +245,7 @@ class RuntimeCallTimer final {
V(RegExp_Exec) \ V(RegExp_Exec) \
V(RegExp_New) \ V(RegExp_New) \
V(ScriptCompiler_Compile) \ V(ScriptCompiler_Compile) \
V(ScriptCompiler_CompileFunctionInContext) \ V(ScriptCompiler_CompileFunction) \
V(ScriptCompiler_CompileUnbound) \ V(ScriptCompiler_CompileUnbound) \
V(Script_Run) \ V(Script_Run) \
V(Set_Add) \ V(Set_Add) \

View File

@ -441,7 +441,7 @@ TEST(OptimizedCodeSharing1) {
} }
} }
TEST(CompileFunctionInContext) { TEST(CompileFunction) {
if (i::FLAG_always_opt) return; if (i::FLAG_always_opt) return;
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
@ -454,8 +454,8 @@ TEST(CompileFunctionInContext) {
"x = r * cos(PI);" "x = r * cos(PI);"
"y = r * sin(PI / 2);")); "y = r * sin(PI / 2);"));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source, v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 0,
0, nullptr, 1, &math) nullptr, 1, &math)
.ToLocalChecked(); .ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
@ -478,8 +478,7 @@ TEST(CompileFunctionInContext) {
CHECK_EQ(10.0, y->NumberValue(env.local()).FromJust()); CHECK_EQ(10.0, y->NumberValue(env.local()).FromJust());
} }
TEST(CompileFunctionComplex) {
TEST(CompileFunctionInContextComplex) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
@ -496,8 +495,8 @@ TEST(CompileFunctionInContextComplex) {
env->Global()->Get(env.local(), v8_str("b")).ToLocalChecked()); env->Global()->Get(env.local(), v8_str("b")).ToLocalChecked());
v8::ScriptCompiler::Source script_source(v8_str("result = x + y + z")); v8::ScriptCompiler::Source script_source(v8_str("result = x + y + z"));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source, v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 0,
0, nullptr, 2, ext) nullptr, 2, ext)
.ToLocalChecked(); .ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked(); fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
@ -508,8 +507,7 @@ TEST(CompileFunctionInContextComplex) {
CHECK_EQ(52.0, result->NumberValue(env.local()).FromJust()); CHECK_EQ(52.0, result->NumberValue(env.local()).FromJust());
} }
TEST(CompileFunctionArgs) {
TEST(CompileFunctionInContextArgs) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
@ -520,8 +518,8 @@ TEST(CompileFunctionInContextArgs) {
v8::ScriptCompiler::Source script_source(v8_str("result = x + abc")); v8::ScriptCompiler::Source script_source(v8_str("result = x + abc"));
v8::Local<v8::String> arg = v8_str("abc"); v8::Local<v8::String> arg = v8_str("abc");
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source, v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg,
1, &arg, 1, ext) 1, ext)
.ToLocalChecked(); .ToLocalChecked();
CHECK_EQ(1, fun->Get(env.local(), v8_str("length")) CHECK_EQ(1, fun->Get(env.local(), v8_str("length"))
.ToLocalChecked() .ToLocalChecked()
@ -537,8 +535,7 @@ TEST(CompileFunctionInContextArgs) {
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust()); CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
} }
TEST(CompileFunctionComments) {
TEST(CompileFunctionInContextComments) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
@ -551,8 +548,8 @@ TEST(CompileFunctionInContextComments) {
v8::ScriptCompiler::Source script_source(source); v8::ScriptCompiler::Source script_source(source);
v8::Local<v8::String> arg = CompileRun("'a\\u4e00'").As<v8::String>(); v8::Local<v8::String> arg = CompileRun("'a\\u4e00'").As<v8::String>();
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source, v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg,
1, &arg, 1, ext) 1, ext)
.ToLocalChecked(); .ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
v8::Local<v8::Value> arg_value = v8::Number::New(CcTest::isolate(), 42.0); v8::Local<v8::Value> arg_value = v8::Number::New(CcTest::isolate(), 42.0);
@ -564,19 +561,18 @@ TEST(CompileFunctionInContextComments) {
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust()); CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
} }
TEST(CompileFunctionNonIdentifierArgs) {
TEST(CompileFunctionInContextNonIdentifierArgs) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
v8::ScriptCompiler::Source script_source(v8_str("result = 1")); v8::ScriptCompiler::Source script_source(v8_str("result = 1"));
v8::Local<v8::String> arg = v8_str("b }"); v8::Local<v8::String> arg = v8_str("b }");
CHECK(v8::ScriptCompiler::CompileFunctionInContext( CHECK(
env.local(), &script_source, 1, &arg, 0, nullptr) v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg)
.IsEmpty()); .IsEmpty());
} }
TEST(CompileFunctionInContextRenderCallSite) { TEST(CompileFunctionRenderCallSite) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
@ -601,8 +597,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
{ {
v8::ScriptCompiler::Source script_source(v8_str(source1)); v8::ScriptCompiler::Source script_source(v8_str(source1));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
v8::Local<v8::Value> result = v8::Local<v8::Value> result =
@ -615,8 +610,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
{ {
v8::ScriptCompiler::Source script_source(v8_str(source2)); v8::ScriptCompiler::Source script_source(v8_str(source2));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
v8::Local<v8::Value> result = v8::Local<v8::Value> result =
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked(); fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
@ -627,7 +621,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
} }
} }
TEST(CompileFunctionInContextQuirks) { TEST(CompileFunctionQuirks) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
LocalContext env; LocalContext env;
@ -638,8 +632,7 @@ TEST(CompileFunctionInContextQuirks) {
static const char* expect = "abcd"; static const char* expect = "abcd";
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
v8::Local<v8::Value> result = v8::Local<v8::Value> result =
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked(); fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
@ -652,8 +645,7 @@ TEST(CompileFunctionInContextQuirks) {
static const char* source = "'use strict'; var a = 077"; static const char* source = "'use strict'; var a = 077";
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
CHECK(v8::ScriptCompiler::CompileFunctionInContext( CHECK(v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.IsEmpty()); .IsEmpty());
CHECK(try_catch.HasCaught()); CHECK(try_catch.HasCaught());
} }
@ -661,30 +653,27 @@ TEST(CompileFunctionInContextQuirks) {
static const char* source = "{ let x; { var x } }"; static const char* source = "{ let x; { var x } }";
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
CHECK(v8::ScriptCompiler::CompileFunctionInContext( CHECK(v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.IsEmpty()); .IsEmpty());
CHECK(try_catch.HasCaught()); CHECK(try_catch.HasCaught());
} }
} }
TEST(CompileFunctionInContextScriptOrigin) { TEST(CompileFunctionScriptOrigin) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::Isolate* isolate = CcTest::isolate(); v8::Isolate* isolate = CcTest::isolate();
v8::HandleScope scope(isolate); v8::HandleScope scope(isolate);
LocalContext env; LocalContext env;
v8::ScriptOrigin origin(isolate, v8_str("test"), 22, 41); v8::ScriptOrigin origin(isolate, v8_str("test"), 22, 41);
v8::ScriptCompiler::Source script_source(v8_str("throw new Error()"), origin); v8::ScriptCompiler::Source script_source(v8_str("throw new Error()"), origin);
Local<v8::ScriptOrModule> script;
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr,
v8::ScriptCompiler::CompileOptions::kNoCompileOptions,
v8::ScriptCompiler::NoCacheReason::kNoCacheNoReason, &script)
.ToLocalChecked(); .ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
v8::Local<v8::UnboundScript> script =
fun->GetUnboundScript().ToLocalChecked();
CHECK(!script.IsEmpty()); CHECK(!script.IsEmpty());
CHECK(script->GetResourceName()->StrictEquals(v8_str("test"))); CHECK(script->GetScriptName()->StrictEquals(v8_str("test")));
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
CcTest::isolate()->SetCaptureStackTraceForUncaughtExceptions(true); CcTest::isolate()->SetCaptureStackTraceForUncaughtExceptions(true);
CHECK(fun->Call(env.local(), env->Global(), 0, nullptr).IsEmpty()); CHECK(fun->Call(env.local(), env->Global(), 0, nullptr).IsEmpty());
@ -699,7 +688,7 @@ TEST(CompileFunctionInContextScriptOrigin) {
CHECK_EQ(42 + strlen("throw "), static_cast<unsigned>(frame->GetColumn())); CHECK_EQ(42 + strlen("throw "), static_cast<unsigned>(frame->GetColumn()));
} }
void TestCompileFunctionInContextToStringImpl() { void TestCompileFunctionToStringImpl() {
#define CHECK_NOT_CAUGHT(__local_context__, try_catch, __op__) \ #define CHECK_NOT_CAUGHT(__local_context__, try_catch, __op__) \
do { \ do { \
const char* op = (__op__); \ const char* op = (__op__); \
@ -726,12 +715,11 @@ void TestCompileFunctionInContextToStringImpl() {
v8::Local<v8::String> params[] = {v8_str("event")}; v8::Local<v8::String> params[] = {v8_str("event")};
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
v8::MaybeLocal<v8::Function> maybe_fun = v8::MaybeLocal<v8::Function> maybe_fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source,
env.local(), &script_source, arraysize(params), params, 0, arraysize(params), params);
nullptr);
CHECK_NOT_CAUGHT(env.local(), try_catch, CHECK_NOT_CAUGHT(env.local(), try_catch,
"v8::ScriptCompiler::CompileFunctionInContext"); "v8::ScriptCompiler::CompileFunction");
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked(); v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
@ -752,11 +740,10 @@ void TestCompileFunctionInContextToStringImpl() {
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
v8::MaybeLocal<v8::Function> maybe_fun = v8::MaybeLocal<v8::Function> maybe_fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source);
env.local(), &script_source, 0, nullptr, 0, nullptr);
CHECK_NOT_CAUGHT(env.local(), try_catch, CHECK_NOT_CAUGHT(env.local(), try_catch,
"v8::ScriptCompiler::CompileFunctionInContext"); "v8::ScriptCompiler::CompileFunction");
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked(); v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
@ -777,11 +764,10 @@ void TestCompileFunctionInContextToStringImpl() {
v8::TryCatch try_catch(CcTest::isolate()); v8::TryCatch try_catch(CcTest::isolate());
v8::MaybeLocal<v8::Function> maybe_fun = v8::MaybeLocal<v8::Function> maybe_fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source);
env.local(), &script_source, 0, nullptr, 0, nullptr);
CHECK_NOT_CAUGHT(env.local(), try_catch, CHECK_NOT_CAUGHT(env.local(), try_catch,
"v8::ScriptCompiler::CompileFunctionInContext"); "v8::ScriptCompiler::CompileFunction");
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked(); v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
CHECK(!fun.IsEmpty()); CHECK(!fun.IsEmpty());
@ -801,9 +787,7 @@ void TestCompileFunctionInContextToStringImpl() {
#undef CHECK_NOT_CAUGHT #undef CHECK_NOT_CAUGHT
} }
TEST(CompileFunctionInContextFunctionToString) { TEST(CompileFunctionFunctionToString) { TestCompileFunctionToStringImpl(); }
TestCompileFunctionInContextToStringImpl();
}
TEST(InvocationCount) { TEST(InvocationCount) {
if (FLAG_lite_mode) return; if (FLAG_lite_mode) return;

View File

@ -3038,8 +3038,7 @@ TEST(DebugBreakInWrappedScript) {
{ {
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
v8::Local<v8::Value> result = v8::Local<v8::Value> result =
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked(); fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
@ -5373,8 +5372,7 @@ TEST(TerminateOnResumeAtException) {
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::Local<v8::Function> foo = v8::Local<v8::Function> foo =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
v8::MaybeLocal<v8::Value> val = v8::MaybeLocal<v8::Value> val =
@ -5620,8 +5618,7 @@ TEST(TerminateOnResumeFromOtherThread) {
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::Local<v8::Function> foo = v8::Local<v8::Function> foo =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
v8::MaybeLocal<v8::Value> val = v8::MaybeLocal<v8::Value> val =
@ -5675,8 +5672,7 @@ TEST(TerminateOnResumeAtInterruptFromOtherThread) {
v8::ScriptCompiler::Source script_source(v8_str(source)); v8::ScriptCompiler::Source script_source(v8_str(source));
v8::Local<v8::Function> foo = v8::Local<v8::Function> foo =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
env.local(), &script_source, 0, nullptr, 0, nullptr)
.ToLocalChecked(); .ToLocalChecked();
CHECK(timeout_thread.Start()); CHECK(timeout_thread.Start());

View File

@ -633,8 +633,8 @@ UNINITIALIZED_TEST(LogInterpretedFramesNativeStackWithSerialization) {
v8::ScriptCompiler::Source script_source(source, origin, cache); v8::ScriptCompiler::Source script_source(source, origin, cache);
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(context, &script_source, 1,
context, &script_source, 1, &arg_str, 0, nullptr, options) &arg_str, 0, nullptr, options)
.ToLocalChecked(); .ToLocalChecked();
if (has_cache) { if (has_cache) {
logger.StopLogging(); logger.StopLogging();

View File

@ -4255,7 +4255,7 @@ TEST(WeakArraySerializationInCodeCache) {
delete cache; delete cache;
} }
TEST(CachedCompileFunctionInContext) { TEST(CachedCompileFunction) {
DisableAlwaysOpt(); DisableAlwaysOpt();
LocalContext env; LocalContext env;
Isolate* isolate = CcTest::i_isolate(); Isolate* isolate = CcTest::i_isolate();
@ -4270,8 +4270,8 @@ TEST(CachedCompileFunctionInContext) {
{ {
v8::ScriptCompiler::Source script_source(source); v8::ScriptCompiler::Source script_source(source);
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1,
env.local(), &script_source, 1, &arg_str, 0, nullptr, &arg_str, 0, nullptr,
v8::ScriptCompiler::kEagerCompile) v8::ScriptCompiler::kEagerCompile)
.ToLocalChecked(); .ToLocalChecked();
cache = v8::ScriptCompiler::CreateCodeCacheForFunction(fun); cache = v8::ScriptCompiler::CreateCodeCacheForFunction(fun);
@ -4281,7 +4281,7 @@ TEST(CachedCompileFunctionInContext) {
DisallowCompilation no_compile_expected(isolate); DisallowCompilation no_compile_expected(isolate);
v8::ScriptCompiler::Source script_source(source, cache); v8::ScriptCompiler::Source script_source(source, cache);
v8::Local<v8::Function> fun = v8::Local<v8::Function> fun =
v8::ScriptCompiler::CompileFunctionInContext( v8::ScriptCompiler::CompileFunction(
env.local(), &script_source, 1, &arg_str, 0, nullptr, env.local(), &script_source, 1, &arg_str, 0, nullptr,
v8::ScriptCompiler::kConsumeCodeCache) v8::ScriptCompiler::kConsumeCodeCache)
.ToLocalChecked(); .ToLocalChecked();