mirror of
https://github.com/tc39/test262.git
synced 2025-07-23 14:04:51 +02:00
Ensure typed array length is retrieved early in Atomics.{notify,wait}
This commit is contained in:
parent
37ebe00a15
commit
1049f77ba3
@ -0,0 +1,36 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.notify
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.15 Atomics.notify ( typedArray, index, count )
|
||||||
|
...
|
||||||
|
2. Let byteIndexInBuffer be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics, TypedArray]
|
||||||
|
includes: [detachArrayBuffer.js]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var ab = new ArrayBuffer(4);
|
||||||
|
var ta = new Int32Array(ab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
$DETACHBUFFER(ab);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.sameValue(Atomics.notify(ta, index), 0);
|
||||||
|
|
||||||
|
assert.sameValue(ab.byteLength, 0);
|
@ -0,0 +1,35 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.notify
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.15 Atomics.notify ( typedArray, index, count )
|
||||||
|
...
|
||||||
|
2. Let byteIndexInBuffer be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics, TypedArray, resizable-arraybuffer]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var rab = new ArrayBuffer(4, {maxByteLength: 4});
|
||||||
|
var ta = new Int32Array(rab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
rab.resize(0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.sameValue(Atomics.notify(ta, index), 0);
|
||||||
|
|
||||||
|
assert.sameValue(rab.byteLength, 0);
|
@ -0,0 +1,43 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.notify
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.15 Atomics.notify ( typedArray, index, count )
|
||||||
|
...
|
||||||
|
2. Let byteIndexInBuffer be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics, TypedArray, resizable-arraybuffer]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var rab = new ArrayBuffer(0, {maxByteLength: 4});
|
||||||
|
var ta = new Int32Array(rab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
rab.resize(4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var count = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected count coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.throws(RangeError, function() {
|
||||||
|
Atomics.notify(ta, index, count);
|
||||||
|
});
|
||||||
|
|
||||||
|
assert.sameValue(rab.byteLength, 4);
|
@ -0,0 +1,43 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.notify
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.15 Atomics.notify ( typedArray, index, count )
|
||||||
|
...
|
||||||
|
2. Let byteIndexInBuffer be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics, TypedArray, resizable-arraybuffer]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var gsab = new SharedArrayBuffer(0, {maxByteLength: 4});
|
||||||
|
var ta = new Int32Array(gsab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
gsab.grow(4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var count = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected count coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.throws(RangeError, function() {
|
||||||
|
Atomics.notify(ta, index, count);
|
||||||
|
});
|
||||||
|
|
||||||
|
assert.sameValue(gsab.byteLength, 4);
|
@ -0,0 +1,52 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.wait
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.13 Atomics.wait ( typedArray, index, value, timeout )
|
||||||
|
1. Return ? DoWait(sync, typedArray, index, value, timeout).
|
||||||
|
|
||||||
|
25.4.3.14 DoWait ( mode, typedArray, index, value, timeout )
|
||||||
|
...
|
||||||
|
4. Let i be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics, TypedArray, resizable-arraybuffer]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var gsab = new SharedArrayBuffer(0, {maxByteLength: 4});
|
||||||
|
var ta = new Int32Array(gsab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
gsab.grow(4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var value = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected value coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var timeout = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected timeout coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.throws(RangeError, function() {
|
||||||
|
Atomics.wait(ta, index, value, timeout);
|
||||||
|
});
|
||||||
|
|
||||||
|
assert.sameValue(gsab.byteLength, 4);
|
@ -0,0 +1,52 @@
|
|||||||
|
// Copyright (C) 2025 André Bargull. All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
esid: sec-atomics.waitasync
|
||||||
|
description: >
|
||||||
|
TypedArray length is retrieved before index parameter coercion.
|
||||||
|
info: |
|
||||||
|
25.4.14 Atomics.waitAsync ( typedArray, index, value, timeout )
|
||||||
|
1. Return ? DoWait(async, typedArray, index, value, timeout).
|
||||||
|
|
||||||
|
25.4.3.14 DoWait ( mode, typedArray, index, value, timeout )
|
||||||
|
...
|
||||||
|
4. Let i be ? ValidateAtomicAccess(taRecord, index).
|
||||||
|
...
|
||||||
|
|
||||||
|
25.4.3.2 ValidateAtomicAccess ( taRecord, requestIndex )
|
||||||
|
1. Let length be TypedArrayLength(taRecord).
|
||||||
|
2. Let accessIndex be ? ToIndex(requestIndex).
|
||||||
|
3. Assert: accessIndex ≥ 0.
|
||||||
|
4. If accessIndex ≥ length, throw a RangeError exception.
|
||||||
|
...
|
||||||
|
features: [Atomics.waitAsync, Atomics, TypedArray, resizable-arraybuffer]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
var gsab = new SharedArrayBuffer(0, {maxByteLength: 4});
|
||||||
|
var ta = new Int32Array(gsab);
|
||||||
|
|
||||||
|
var index = {
|
||||||
|
valueOf() {
|
||||||
|
gsab.grow(4);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var value = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected value coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var timeout = {
|
||||||
|
valueOf() {
|
||||||
|
throw new Test262Error("Unexpected timeout coercion");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
assert.throws(RangeError, function() {
|
||||||
|
Atomics.waitAsync(ta, index, value, timeout);
|
||||||
|
});
|
||||||
|
|
||||||
|
assert.sameValue(gsab.byteLength, 4);
|
Loading…
x
Reference in New Issue
Block a user