diff options
author | Michaël Zasso <targos@protonmail.com> | 2017-03-21 10:16:54 +0100 |
---|---|---|
committer | Michaël Zasso <targos@protonmail.com> | 2017-03-25 09:44:10 +0100 |
commit | c459d8ea5d402c702948c860d9497b2230ff7e8a (patch) | |
tree | 56c282fc4d40e5cb613b47cf7be3ea0526ed5b6f /deps/v8/test/unittests/cancelable-tasks-unittest.cc | |
parent | e0bc5a7361b1d29c3ed034155fd779ce6f44fb13 (diff) | |
download | node-new-c459d8ea5d402c702948c860d9497b2230ff7e8a.tar.gz |
deps: update V8 to 5.7.492.69
PR-URL: https://github.com/nodejs/node/pull/11752
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Franziska Hinkelmann <franziska.hinkelmann@gmail.com>
Diffstat (limited to 'deps/v8/test/unittests/cancelable-tasks-unittest.cc')
-rw-r--r-- | deps/v8/test/unittests/cancelable-tasks-unittest.cc | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/deps/v8/test/unittests/cancelable-tasks-unittest.cc b/deps/v8/test/unittests/cancelable-tasks-unittest.cc index 37690aaf80..eb5dd91589 100644 --- a/deps/v8/test/unittests/cancelable-tasks-unittest.cc +++ b/deps/v8/test/unittests/cancelable-tasks-unittest.cc @@ -214,5 +214,50 @@ TEST(CancelableTask, RemoveUnmanagedId) { EXPECT_FALSE(manager.TryAbort(3)); } +TEST(CancelableTask, EmptyTryAbortAll) { + CancelableTaskManager manager; + EXPECT_EQ(manager.TryAbortAll(), CancelableTaskManager::kTaskRemoved); +} + +TEST(CancelableTask, ThreadedMultipleTasksNotRunTryAbortAll) { + CancelableTaskManager manager; + ResultType result1 = 0; + ResultType result2 = 0; + TestTask* task1 = new TestTask(&manager, &result1, TestTask::kCheckNotRun); + TestTask* task2 = new TestTask(&manager, &result2, TestTask::kCheckNotRun); + ThreadedRunner runner1(task1); + ThreadedRunner runner2(task2); + EXPECT_EQ(manager.TryAbortAll(), CancelableTaskManager::kTaskAborted); + // Tasks are canceled, hence the runner will bail out and not update result. + runner1.Start(); + runner2.Start(); + runner1.Join(); + runner2.Join(); + EXPECT_EQ(GetValue(&result1), 0); + EXPECT_EQ(GetValue(&result2), 0); +} + +TEST(CancelableTask, ThreadedMultipleTasksStartedTryAbortAll) { + CancelableTaskManager manager; + ResultType result1 = 0; + ResultType result2 = 0; + TestTask* task1 = + new TestTask(&manager, &result1, TestTask::kWaitTillCanceledAgain); + TestTask* task2 = + new TestTask(&manager, &result2, TestTask::kWaitTillCanceledAgain); + ThreadedRunner runner1(task1); + ThreadedRunner runner2(task2); + runner1.Start(); + // Busy wait on result to make sure task1 is done. + while (GetValue(&result1) == 0) { + } + EXPECT_EQ(manager.TryAbortAll(), CancelableTaskManager::kTaskRunning); + runner2.Start(); + runner1.Join(); + runner2.Join(); + EXPECT_EQ(GetValue(&result1), 1); + EXPECT_EQ(GetValue(&result2), 0); +} + } // namespace internal } // namespace v8 |