// 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: > A null value for bufferData throws a TypeError 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. includes: [detachArrayBuffer.js] features: [Atomics.waitAsync, ArrayBuffer, Atomics, TypedArray] ---*/ assert.sameValue(typeof Atomics.waitAsync, 'function', 'The value of `typeof Atomics.waitAsync` is "function"'); const i32a = new Int32Array( new ArrayBuffer(Int32Array.BYTES_PER_ELEMENT * 4) ); const poisoned = { valueOf() { throw new Test262Error('should not evaluate this code'); } }; try { $DETACHBUFFER(i32a.buffer); // Detaching a non-shared ArrayBuffer sets the [[ArrayBufferData]] value to null } catch (error) { throw new Test262Error(`An unexpected error occurred when detaching ArrayBuffer: ${error.message}`); } assert.throws(TypeError, function() { Atomics.waitAsync(i32a, poisoned, poisoned, poisoned); }, '`Atomics.waitAsync(i32a, poisoned, poisoned, poisoned)` throws a TypeError exception');