nodejs/deps/v8/test/mjsunit/shared-memory/mutex-async-lock.js
Michaël Zasso 9d7cd9b864
deps: update V8 to 12.8.374.13
PR-URL: https://github.com/nodejs/node/pull/54077
Reviewed-By: Jiawen Geng <technicalcute@gmail.com>
Reviewed-By: Richard Lau <rlau@redhat.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com>
2024-08-16 16:03:01 +02:00

33 lines
1.3 KiB
JavaScript

// Copyright 2024 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// Flags: --harmony-struct --allow-natives-syntax
(function TestAsyncLock() {
let mutex = new Atomics.Mutex;
let lockPromise = Atomics.Mutex.lockAsync(mutex, function() {
return 42;
})
// Lock is taken but the callback won't be executed until the next microtask.
assertFalse(Atomics.Mutex.tryLock(mutex, function() {}).success);
assertEquals(1, %AtomicsSychronizationNumAsyncWaitersInIsolateForTesting());
let resolverExecuted = false;
lockPromise.then((result) => {
// The lock was released before the then callback is executed.
assertTrue(Atomics.Mutex.tryLock(mutex, function() {}).success);
// Ensure the promise's result value property is set to the return
// value of the callback.
assertEquals(42, result.value);
assertEquals(true, result.success);
resolverExecuted = true;
});
setTimeout(() => {
// The lock and then callbacks will be executed when the microtask queue
// is flushed, before proceeding to the next task.
assertEquals(resolverExecuted, true);
assertEquals(0, %AtomicsSychronizationNumAsyncWaitersInIsolateForTesting());
}, 0);
})();