2020-06-12 18:57:14 +02:00
|
|
|
// 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: >
|
|
|
|
Throws a RangeError is index < 0
|
|
|
|
info: |
|
|
|
|
Atomics.waitAsync( typedArray, index, value, timeout )
|
|
|
|
|
|
|
|
1. Return DoWait(async, typedArray, index, value, timeout).
|
|
|
|
|
|
|
|
DoWait ( mode, typedArray, index, value, timeout )
|
|
|
|
|
|
|
|
1. Let buffer be ? ValidateSharedIntegerTypedArray(typedArray, true).
|
|
|
|
2. Let i be ? ValidateAtomicAccess(typedArray, index).
|
|
|
|
|
|
|
|
features: [Atomics.waitAsync, SharedArrayBuffer, TypedArray, Atomics, BigInt]
|
|
|
|
---*/
|
2020-10-08 21:56:06 +02:00
|
|
|
assert.sameValue(typeof Atomics.waitAsync, 'function', 'The value of `typeof Atomics.waitAsync` is "function"');
|
2020-06-12 18:57:14 +02:00
|
|
|
const i64a = new BigInt64Array(
|
|
|
|
new SharedArrayBuffer(BigInt64Array.BYTES_PER_ELEMENT * 4)
|
|
|
|
);
|
|
|
|
|
|
|
|
const poisoned = {
|
|
|
|
valueOf() {
|
|
|
|
throw new Test262Error('should not evaluate this code');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
assert.throws(RangeError, function() {
|
|
|
|
Atomics.waitAsync(i64a, -Infinity, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(i64a, -Infinity, poisoned, poisoned)` throws a RangeError exception');
|
2020-06-12 18:57:14 +02:00
|
|
|
assert.throws(RangeError, function() {
|
|
|
|
Atomics.waitAsync(i64a, -7.999, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(i64a, -7.999, poisoned, poisoned)` throws a RangeError exception');
|
2020-06-12 18:57:14 +02:00
|
|
|
assert.throws(RangeError, function() {
|
|
|
|
Atomics.waitAsync(i64a, -1, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(i64a, -1, poisoned, poisoned)` throws a RangeError exception');
|
2020-06-12 18:57:14 +02:00
|
|
|
assert.throws(RangeError, function() {
|
|
|
|
Atomics.waitAsync(i64a, -300, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(i64a, -300, poisoned, poisoned)` throws a RangeError exception');
|
2020-06-12 18:57:14 +02:00
|
|
|
|