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

Unified Diff: test/cctest/test-api.cc

Issue 2578173004: [promisehook] Fire init hook for promise subclass (Closed)
Patch Set: add regression test Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
Download patch
« no previous file with comments | « src/builtins/builtins-promise.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/cctest/test-api.cc
diff --git a/test/cctest/test-api.cc b/test/cctest/test-api.cc
index 2e1304064e0f68352415c9bb3f842253d6c34b66..39c7fc56d08817513fb7f7dfdd821d990d855f6a 100644
--- a/test/cctest/test-api.cc
+++ b/test/cctest/test-api.cc
@@ -18225,15 +18225,27 @@ TEST(PromiseHook) {
v8::Local<v8::Context> context = CcTest::isolate()->GetCurrentContext();
promise_hook_data = new PromiseHookData();
+ isolate->SetPromiseHook(CustomPromiseHook);
+
+ // Test that an initialized promise is passed to init. Other hooks
+ // can not have un initialized promise.
+ promise_hook_data->check_value = false;
+ CompileRun("var p = new Promise(() => {});");
+
+ auto init_promise = global->Get(context, v8_str("init")).ToLocalChecked();
+ CHECK(GetPromise("p")->Equals(env.local(), init_promise).FromJust());
+ auto init_promise_obj = v8::Local<v8::Promise>::Cast(init_promise);
+ CHECK(init_promise_obj->State() == v8::Promise::PromiseState::kPending);
+ CHECK_EQ(false, init_promise_obj->HasHandler());
+
+ promise_hook_data->Reset();
promise_hook_data->promise_hook_value = "fulfilled";
const char* source =
"var resolve, value = ''; \n"
"var p = new Promise(r => resolve = r); \n";
- isolate->SetPromiseHook(CustomPromiseHook);
-
CompileRun(source);
- auto init_promise = global->Get(context, v8_str("init")).ToLocalChecked();
+ init_promise = global->Get(context, v8_str("init")).ToLocalChecked();
CHECK(GetPromise("p")->Equals(env.local(), init_promise).FromJust());
CHECK_EQ(1, promise_hook_data->promise_hook_count);
CHECK_EQ(0, promise_hook_data->parent_promise_count);
@@ -18426,7 +18438,40 @@ TEST(PromiseHook) {
v8_str(promise_hook_data->promise_hook_value.c_str()))
.FromJust());
+ promise_hook_data->Reset();
+ promise_hook_data->promise_hook_value = "subclass";
+ source =
+ "var resolve, value = '';\n"
+ "class MyPromise extends Promise { \n"
+ " then(onFulfilled, onRejected) { \n"
+ " return super.then(onFulfilled, onRejected); \n"
+ " };\n"
+ "};\n"
+ "var p = new MyPromise(r => resolve = r);\n";
+
+ CompileRun(source);
+ // 1) init hook (p)
+ CHECK_EQ(1, promise_hook_data->promise_hook_count);
+
+ CompileRun("var p1 = p.then(() => value = 'subclass');\n");
+ // 2) init hook (p1)
+ CHECK_EQ(2, promise_hook_data->promise_hook_count);
+
+ CompileRun("resolve();\n");
+ resolve_promise = global->Get(context, v8_str("resolve")).ToLocalChecked();
+ before_promise = global->Get(context, v8_str("before")).ToLocalChecked();
+ after_promise = global->Get(context, v8_str("after")).ToLocalChecked();
+ CHECK(GetPromise("p")->Equals(env.local(), before_promise).FromJust());
+ CHECK(GetPromise("p")->Equals(env.local(), after_promise).FromJust());
+ CHECK(GetPromise("p1")->Equals(env.local(), resolve_promise).FromJust());
+ // 3) resolve hook (p)
+ // 4) before hook (p)
+ // 5) after hook (p)
+ // 6) resolve hook (p1)
+ CHECK_EQ(6, promise_hook_data->promise_hook_count);
+
delete promise_hook_data;
+ isolate->SetPromiseHook(nullptr);
}
void AnalyzeStackOfDynamicScriptWithSourceURL(
« no previous file with comments | « src/builtins/builtins-promise.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698