2020-03-19 18:57:57 +01: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 TypeError if typedArray arg is not an Object
|
|
|
|
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).
|
|
|
|
|
|
|
|
ValidateSharedIntegerTypedArray ( typedArray [ , waitable ] )
|
|
|
|
|
|
|
|
2. Perform ? RequireInternalSlot(typedArray, [[TypedArrayName]]).
|
|
|
|
|
|
|
|
RequireInternalSlot ( O, internalSlot )
|
|
|
|
|
|
|
|
1. If Type(O) is not Object, throw a TypeError exception.
|
|
|
|
2. If O does not have an internalSlot internal slot, throw a TypeError exception.
|
|
|
|
|
2020-05-27 21:11:06 +02:00
|
|
|
features: [Atomics.waitAsync, Symbol, arrow-function, Atomics]
|
2020-03-19 18:57:57 +01:00
|
|
|
---*/
|
2020-10-08 21:56:06 +02:00
|
|
|
assert.sameValue(typeof Atomics.waitAsync, 'function', 'The value of `typeof Atomics.waitAsync` is "function"');
|
2020-03-19 18:57:57 +01:00
|
|
|
const poisoned = {
|
|
|
|
valueOf() {
|
|
|
|
throw new Test262Error('should not evaluate this code');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(null, poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(null, poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(undefined, poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(undefined, poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(true, poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(true, poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(false, poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(false, poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync('***string***', poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync("***string***", poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(Number.NEGATIVE_INFINITY, poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(Number.NEGATIVE_INFINITY, poisoned, poisoned, poisoned)` throws a TypeError exception');
|
2020-03-19 18:57:57 +01:00
|
|
|
|
|
|
|
assert.throws(TypeError, () => {
|
|
|
|
Atomics.waitAsync(Symbol('***symbol***'), poisoned, poisoned, poisoned);
|
2020-10-08 21:56:06 +02:00
|
|
|
}, '`Atomics.waitAsync(Symbol("***symbol***"), poisoned, poisoned, poisoned)` throws a TypeError exception');
|