Bug 1892041 - Part 2: Update test262. r=spidermonkey-reviewers,dminor
[gecko.git] / js / src / tests / test262 / built-ins / Atomics / sub / not-a-constructor.js
blob98563ad324a8be5a37c4301b1548221d5d661e2e
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) 2020 Rick Waldron. All rights reserved.
3 // This code is governed by the BSD license found in the LICENSE file.
5 /*---
6 esid: sec-ecmascript-standard-built-in-objects
7 description: >
8   Atomics.sub does not implement [[Construct]], is not new-able
9 info: |
10   ECMAScript Function Objects
12   Built-in function objects that are not identified as constructors do not
13   implement the [[Construct]] internal method unless otherwise specified in
14   the description of a particular function.
16   sec-evaluatenew
18   ...
19   7. If IsConstructor(constructor) is false, throw a TypeError exception.
20   ...
21 includes: [isConstructor.js]
22 features: [Reflect.construct, Atomics, arrow-function, TypedArray, SharedArrayBuffer]
23 ---*/
25 assert.sameValue(isConstructor(Atomics.sub), false, 'isConstructor(Atomics.sub) must return false');
27 assert.throws(TypeError, () => {
28   new Atomics.sub(new Int32Array(new SharedArrayBuffer(Int32Array.BYTES_PER_ELEMENT)));
29 });
32 reportCompare(0, 0);