blob: ddb1c3600b84c39fa297a401ef0a7aa0b89c15f1 [file] [log] [blame]
// Copyright (C) 2020 Rick Waldron. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-atomics.waitasync
description: >
Test Atomics.waitAsync on arrays that allow atomic operations
flags: [async]
includes: [atomicsHelper.js]
features: [Atomics.waitAsync, Atomics]
---*/
assert.sameValue(typeof Atomics.waitAsync, 'function', 'The value of `typeof Atomics.waitAsync` is "function"');
$262.agent.start(`
(async () => {
var sab = new SharedArrayBuffer(1024);
var good_indices = [ (view) => 0/-1, // -0
(view) => '-0',
(view) => view.length - 1,
(view) => ({ valueOf: () => 0 }),
(view) => ({ toString: () => '0', valueOf: false }) // non-callable valueOf triggers invocation of toString
];
var view = new Int32Array(sab, 32, 20);
view[0] = 0;
$262.agent.report("A " + (await Atomics.waitAsync(view, 0, 0, 0).value))
$262.agent.report("B " + (await Atomics.waitAsync(view, 0, 37, 0).value));
const results = [];
// In-bounds boundary cases for indexing
for ( let IdxGen of good_indices ) {
let Idx = IdxGen(view);
view.fill(0);
// Atomics.store() computes an index from Idx in the same way as other
// Atomics operations, not quite like view[Idx].
Atomics.store(view, Idx, 37);
results.push(await Atomics.waitAsync(view, Idx, 0).value);
}
$262.agent.report("C " + results.join(","));
$262.agent.leaving();
})();
`);
(async () => {
const outcomes = [];
for (let i = 0; i < 3; i++) {
outcomes.push(await $262.agent.getReportAsync());
}
assert.sameValue(
outcomes[0],
'A timed-out',
'The value of outcomes[0] is "A timed-out"'
);
assert.sameValue(
outcomes[1],
'B not-equal',
'The value of outcomes[1] is "B not-equal"'
);
assert.sameValue(
outcomes[2],
'C not-equal,not-equal,not-equal,not-equal,not-equal',
'The value of outcomes[2] is "C not-equal,not-equal,not-equal,not-equal,not-equal"'
);
})().then($DONE, $DONE);