test262/test/built-ins/Atomics/wait/poisoned-object-for-timeout...

76 lines
2.1 KiB
JavaScript
Raw Normal View History

2018-04-19 16:11:50 +02:00
// Copyright (C) 2018 Amal Hussein. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-atomics.wait
description: >
False timeout arg should result in an +0 timeout
info: |
Atomics.wait( typedArray, index, value, timeout )
4. Let q be ? ToNumber(timeout).
Null -> Return +0.
includes: [atomicsHelper.js]
2018-04-19 16:11:50 +02:00
features: [Atomics, SharedArrayBuffer, TypedArray]
---*/
$262.agent.start(`
const poisonedValueOf = {
valueOf: function() {
throw new Error("should not evaluate this code");
}
};
const poisonedToPrimitive = {
[Symbol.toPrimitive]: function() {
throw new Error("passing a poisoned object using @@ToPrimitive");
}
};
$262.agent.receiveBroadcast(function(sab) {
const i32a = new Int32Array(sab);
const start = $262.agent.monotonicNow();
try {
Atomics.wait(i32a, 0, 0, poisonedValueOf);
} catch (error) {
$262.agent.report("poisonedValueOf");
}
try {
Atomics.wait(i32a, 0, 0, poisonedToPrimitive);
} catch (error) {
$262.agent.report("poisonedToPrimitive");
}
$262.agent.report($262.agent.monotonicNow() - start);
$262.agent.leaving();
});
2018-04-19 16:11:50 +02:00
`);
const i32a = new Int32Array(
new SharedArrayBuffer(Int32Array.BYTES_PER_ELEMENT * 4)
);
2018-04-19 16:11:50 +02:00
$262.agent.broadcast(i32a.buffer);
2018-04-19 16:11:50 +02:00
$262.agent.sleep(150);
assert.sameValue(
$262.agent.getReport(),
'poisonedValueOf',
'$262.agent.getReport() returns "poisonedValueOf"'
);
assert.sameValue(
$262.agent.getReport(),
'poisonedToPrimitive',
'$262.agent.getReport() returns "poisonedToPrimitive"'
);
2018-04-19 16:11:50 +02:00
const lapse = $262.agent.getReport();
2018-04-19 16:11:50 +02:00
assert(lapse >= 0, 'The result of `(lapse >= 0)` is true (The result of `(lapse >= 0)` is true (timeout should be a min of 0ms))');
2018-04-19 16:11:50 +02:00
assert(lapse <= $262.agent.MAX_TIME_EPSILON, 'The result of `(lapse <= $262.agent.MAX_TIME_EPSILON)` is true (The result of `(lapse <= $262.agent.MAX_TIME_EPSILON)` is true (timeout should be a max of $$262.agent.MAX_TIME_EPSILON))');
2018-04-19 16:11:50 +02:00
assert.sameValue(Atomics.wake(i32a, 0), 0, 'Atomics.wake(i32a, 0) returns 0');
2018-04-19 16:11:50 +02:00