out-of-range-index-throws.js (1337B)
1 // |reftest| skip-if(!this.hasOwnProperty('Atomics')||!this.hasOwnProperty('SharedArrayBuffer')||(this.hasOwnProperty('getBuildConfiguration')&&getBuildConfiguration('arm64-simulator'))) -- Atomics,SharedArrayBuffer is not enabled unconditionally, ARM64 Simulator cannot emulate atomics 2 // Copyright (C) 2018 Amal Hussein. All rights reserved. 3 // This code is governed by the BSD license found in the LICENSE file. 4 5 /*--- 6 esid: sec-atomics.wait 7 description: > 8 Throws a RangeError if value of index arg is out of range 9 info: | 10 Atomics.wait( typedArray, index, value, timeout ) 11 12 2.Let i be ? ValidateAtomicAccess(typedArray, index). 13 ... 14 2.Let accessIndex be ? ToIndex(requestIndex). 15 ... 16 5. If accessIndex ≥ length, throw a RangeError exception. 17 features: [Atomics, BigInt, SharedArrayBuffer, TypedArray] 18 ---*/ 19 20 const i64a = new BigInt64Array( 21 new SharedArrayBuffer(BigInt64Array.BYTES_PER_ELEMENT * 4) 22 ); 23 24 const poisoned = { 25 valueOf: function() { 26 throw new Test262Error('should not evaluate this code'); 27 } 28 }; 29 30 assert.throws(RangeError, function() { 31 Atomics.wait(i64a, Infinity, poisoned, poisoned); 32 }); 33 assert.throws(RangeError, function() { 34 Atomics.wait(i64a, 8, poisoned, poisoned); 35 }); 36 assert.throws(RangeError, function() { 37 Atomics.wait(i64a, 200, poisoned, poisoned); 38 }); 39 40 reportCompare(0, 0);