summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/language/expressions/exponentiation
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /js/src/tests/test262/language/expressions/exponentiation
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/language/expressions/exponentiation')
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A1.js30
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A10.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A11.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A12.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A13.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A14.js24
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A15.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A16.js24
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A17.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A18.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A19.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A2.js29
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A20.js24
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A21.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A22.js24
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A23.js37
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A3.js29
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A4.js28
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A5.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A6.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A7.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A8.js23
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A9.js26
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-and-number.js92
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-arithmetic.js77
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-errors.js72
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-negative-exponent-throws.js34
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-toprimitive.js374
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-wrapped-values.js47
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/bigint-zero-base-zero-exponent.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/browser.js0
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-assignment-operator.js27
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-evaluation-order.js34
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-unary-expression-semantics.js68
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-update-expression-semantics.js59
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-bitnot-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-delete-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-logical-not-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-negate-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-plus-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-typeof-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-void-unary-expression-base.js25
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/exp-operator.js22
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/int32_min-exponent.js20
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/order-of-evaluation.js140
-rw-r--r--js/src/tests/test262/language/expressions/exponentiation/shell.js0
46 files changed, 1839 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A1.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A1.js
new file mode 100644
index 0000000000..9120c35e24
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A1.js
@@ -0,0 +1,30 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If exponent is NaN, the result is NaN.
+---*/
+
+var exponent = NaN;
+var bases = [];
+bases[0] = -Infinity;
+bases[1] = -1.7976931348623157E308; //largest (by module) finite number
+bases[2] = -0.000000000000001;
+bases[3] = -0;
+bases[4] = +0
+bases[5] = 0.000000000000001;
+bases[6] = 1.7976931348623157E308; //largest finite number
+bases[7] = +Infinity;
+bases[8] = NaN;
+
+
+for (var i = 0; i < bases.length; i++) {
+ assert.sameValue(
+ bases[i] ** exponent,
+ NaN,
+ bases[i] + " ** " + exponent
+ );
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A10.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A10.js
new file mode 100644
index 0000000000..b38ffcc6ba
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A10.js
@@ -0,0 +1,25 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) < 1 and exponent is −∞, the result is +∞.
+---*/
+
+
+var exponent = -Infinity;
+var bases = [];
+bases[0] = 0.999999999999999;
+bases[1] = 0.5;
+bases[2] = +0;
+bases[3] = -0;
+bases[4] = -0.5;
+bases[5] = -0.999999999999999;
+
+for (var i = 0; i < bases.length; i++) {
+ if (Math.pow(bases[i], exponent) !== +Infinity) {
+ $ERROR("(" + bases[i] + " ** " + exponent + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A11.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A11.js
new file mode 100644
index 0000000000..0f812bcc24
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A11.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is +∞ and exponent > 0, the result is +∞.
+---*/
+
+
+var base = +Infinity;
+var exponents = [];
+exponents[3] = Infinity;
+exponents[2] = 1.7976931348623157E308; //largest (by module) finite number
+exponents[1] = 1;
+exponents[0] = 0.000000000000001;
+
+for (var i = 0; i < exponents.length; i++) {
+ if (base ** exponents[i] !== +Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A12.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A12.js
new file mode 100644
index 0000000000..fcc7829998
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A12.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is +∞ and exponent < 0, the result is +0.
+---*/
+
+
+var base = +Infinity;
+var exponents = [];
+exponents[0] = -Infinity;
+exponents[1] = -1.7976931348623157E308; //largest (by module) finite number
+exponents[2] = -1;
+exponents[3] = -0.000000000000001;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A13.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A13.js
new file mode 100644
index 0000000000..825e38ecf2
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A13.js
@@ -0,0 +1,22 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −∞ and exponent > 0 and exponent is an odd integer, the result is −∞.
+---*/
+
+
+var base = -Infinity;
+var exponents = [];
+exponents[0] = 1;
+exponents[1] = 111;
+exponents[2] = 111111;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== -Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== -Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A14.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A14.js
new file mode 100644
index 0000000000..64be2249e8
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A14.js
@@ -0,0 +1,24 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −∞ and exponent > 0 and exponent is not an odd integer, the result is +∞.
+---*/
+
+
+var base = -Infinity;
+var exponents = [];
+exponents[0] = 0.000000000000001;
+exponents[1] = 2;
+exponents[2] = Math.PI;
+exponents[3] = 1.7976931348623157E308; //largest finite number
+exponents[4] = +Infinity;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A15.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A15.js
new file mode 100644
index 0000000000..c01af6182e
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A15.js
@@ -0,0 +1,22 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −∞ and exponent < 0 and exponent is an odd integer, the result is −0.
+---*/
+
+
+var base = -Infinity;
+var exponents = [];
+exponents[2] = -1;
+exponents[1] = -111;
+exponents[0] = -111111;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== -0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== -0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A16.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A16.js
new file mode 100644
index 0000000000..3ae0bc67d2
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A16.js
@@ -0,0 +1,24 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −∞ and exponent < 0 and exponent is not an odd integer, the result is +0.
+---*/
+
+
+var base = -Infinity;
+var exponents = [];
+exponents[4] = -0.000000000000001;
+exponents[3] = -2;
+exponents[2] = -Math.PI;
+exponents[1] = -1.7976931348623157E308; //largest (by module) finite number
+exponents[0] = -Infinity;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A17.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A17.js
new file mode 100644
index 0000000000..aec31897ae
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A17.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is +0 and exponent > 0, the result is +0.
+---*/
+
+
+var base = +0;
+var exponents = [];
+exponents[3] = Infinity;
+exponents[2] = 1.7976931348623157E308; //largest finite number
+exponents[1] = 1;
+exponents[0] = 0.000000000000001;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A18.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A18.js
new file mode 100644
index 0000000000..649e789ce6
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A18.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is +0 and exponent < 0, the result is +∞.
+---*/
+
+
+var base = +0;
+var exponents = [];
+exponents[0] = -Infinity;
+exponents[1] = -1.7976931348623157E308; //largest (by module) finite number
+exponents[2] = -1;
+exponents[3] = -0.000000000000001;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A19.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A19.js
new file mode 100644
index 0000000000..d4735af33f
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A19.js
@@ -0,0 +1,22 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −0 and exponent > 0 and exponent is an odd integer, the result is −0.
+---*/
+
+
+var base = -0;
+var exponents = [];
+exponents[0] = 1;
+exponents[1] = 111;
+exponents[2] = 111111;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== -0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== -0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A2.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A2.js
new file mode 100644
index 0000000000..899f26337f
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A2.js
@@ -0,0 +1,29 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: >
+ If exponent is +0, the result is 1, even if base is NaN.
+---*/
+
+
+var exponent = +0;
+var bases = [];
+bases[0] = -Infinity;
+bases[1] = -1.7976931348623157E308; //largest (by module) finite number
+bases[2] = -0.000000000000001;
+bases[3] = -0;
+bases[4] = +0
+bases[5] = 0.000000000000001;
+bases[6] = 1.7976931348623157E308; //largest finite number
+bases[7] = +Infinity;
+bases[8] = NaN;
+
+for (var i = 0; i < bases.length; i++) {
+ if ((bases[i] ** exponent) !== 1) {
+ $ERROR("(" + bases[i] + " ** " + exponent + ") !== 1");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A20.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A20.js
new file mode 100644
index 0000000000..c7eaf3ba76
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A20.js
@@ -0,0 +1,24 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −0 and exponent > 0 and exponent is not an odd integer, the result is +0.
+---*/
+
+
+var base = -0;
+var exponents = [];
+exponents[0] = 0.000000000000001;
+exponents[1] = 2;
+exponents[2] = Math.PI;
+exponents[3] = 1.7976931348623157E308; //largest finite number
+exponents[4] = +Infinity;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +0) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A21.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A21.js
new file mode 100644
index 0000000000..aae24849e7
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A21.js
@@ -0,0 +1,22 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −0 and exponent < 0 and exponent is an odd integer, the result is −∞.
+---*/
+
+
+var base = -0;
+var exponents = [];
+exponents[2] = -1;
+exponents[1] = -111;
+exponents[0] = -111111;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== -Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== -Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A22.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A22.js
new file mode 100644
index 0000000000..29485688b0
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A22.js
@@ -0,0 +1,24 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is −0 and exponent < 0 and exponent is not an odd integer, the result is +∞.
+---*/
+
+
+var base = -0;
+var exponents = [];
+exponents[4] = -0.000000000000001;
+exponents[3] = -2;
+exponents[2] = -Math.PI;
+exponents[1] = -1.7976931348623157E308; //largest (by module) finite number
+exponents[0] = -Infinity;
+
+for (var i = 0; i < exponents.length; i++) {
+ if ((base ** exponents[i]) !== +Infinity) {
+ $ERROR("(" + base + " ** " + exponents[i] + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A23.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A23.js
new file mode 100644
index 0000000000..ed167047b4
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A23.js
@@ -0,0 +1,37 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base < 0 and base is finite and exponent is finite and exponent is not an integer, the result is NaN.
+---*/
+
+
+var exponents = [];
+var bases = [];
+bases[0] = -1.7976931348623157E308; //largest (by module) finite number
+bases[1] = -Math.PI;
+bases[2] = -1;
+bases[3] = -0.000000000000001;
+
+exponents[0] = -Math.PI;
+exponents[1] = -Math.E;
+exponents[2] = -1.000000000000001;
+exponents[3] = -0.000000000000001;
+exponents[4] = 0.000000000000001;
+exponents[5] = 1.000000000000001;
+exponents[6] = Math.E;
+exponents[7] = Math.PI;
+
+for (var i = 0; i < bases.length; i++) {
+ for (var j = 0; j < exponents.length; j++) {
+ assert.sameValue(
+ bases[i] ** exponents[j],
+ NaN,
+ bases[i] + " ** " + exponents[j]
+ );
+ }
+}
+
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A3.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A3.js
new file mode 100644
index 0000000000..12a6b79764
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A3.js
@@ -0,0 +1,29 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: >
+ If exponent is −0, the result is 1, even if base is NaN.
+---*/
+
+
+var exponent = -0;
+var bases = [];
+bases[0] = -Infinity;
+bases[1] = -1.7976931348623157E308; //largest (by module) finite number
+bases[2] = -0.000000000000001;
+bases[3] = -0;
+bases[4] = +0
+bases[5] = 0.000000000000001;
+bases[6] = 1.7976931348623157E308; //largest finite number
+bases[7] = +Infinity;
+bases[8] = NaN;
+
+for (var i = 0; i < bases.length; i++) {
+ if ((bases[i] ** exponent) !== 1) {
+ $ERROR("(" + bases[i] + " ** -0) !== 1");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A4.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A4.js
new file mode 100644
index 0000000000..71f4446e01
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A4.js
@@ -0,0 +1,28 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If base is NaN and exponent is nonzero, the result is NaN.
+---*/
+
+
+var base = NaN;
+var exponents = [];
+exponents[0] = -Infinity;
+exponents[1] = -1.7976931348623157E308; //largest (by module) finite number
+exponents[2] = -0.000000000000001;
+exponents[3] = 0.000000000000001;
+exponents[4] = 1.7976931348623157E308; //largest finite number
+exponents[5] = +Infinity;
+exponents[6] = NaN;
+
+for (var i = 0; i < exponents.length; i++) {
+ assert.sameValue(
+ base ** exponents[i],
+ NaN,
+ base + " ** " + exponents[i]
+ );
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A5.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A5.js
new file mode 100644
index 0000000000..b5bbc0ec0f
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A5.js
@@ -0,0 +1,25 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) > 1 and exponent is +∞, the result is +∞.
+---*/
+
+
+var exponent = +Infinity;
+var bases = [];
+bases[0] = -Infinity;
+bases[1] = -1.7976931348623157E308; //largest (by module) finite number
+bases[2] = -1.000000000000001;
+bases[3] = 1.000000000000001;
+bases[4] = 1.7976931348623157E308; //largest finite number
+bases[5] = +Infinity;
+
+for (var i = 0; i < bases.length; i++) {
+ if ((bases[i] ** exponent) !== +Infinity) {
+ $ERROR("(" + bases[i] + " ** " + exponent + ") !== +Infinity");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A6.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A6.js
new file mode 100644
index 0000000000..8a7b3ec1e8
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A6.js
@@ -0,0 +1,25 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) > 1 and exponent is −∞, the result is +0.
+---*/
+
+
+var exponent = -Infinity;
+var bases = [];
+bases[0] = -Infinity;
+bases[1] = -1.7976931348623157E308; //largest (by module) finite number
+bases[2] = -1.000000000000001;
+bases[3] = 1.000000000000001;
+bases[4] = 1.7976931348623157E308; //largest finite number
+bases[5] = +Infinity;
+
+for (var i = 0; i < bases.length; i++) {
+ if ((bases[i] ** exponent) !== +0) {
+ $ERROR("(" + bases[i] + " ** " + exponent + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A7.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A7.js
new file mode 100644
index 0000000000..09f827d1c9
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A7.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) is 1 and exponent is +∞, the result is NaN.
+---*/
+
+
+var exponent = +Infinity;
+var bases = [];
+bases[0] = -1;
+bases[1] = 1
+
+for (var i = 0; i < bases.length; i++) {
+ assert.sameValue(
+ bases[i] ** exponent,
+ NaN,
+ bases[i] + " ** " + exponent
+ );
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A8.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A8.js
new file mode 100644
index 0000000000..da51a18170
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A8.js
@@ -0,0 +1,23 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) is 1 and exponent is −∞, the result is NaN.
+---*/
+
+
+var exponent = -Infinity;
+var bases = [];
+bases[0] = -1;
+bases[1] = 1
+
+for (var i = 0; i < bases.length; i++) {
+ assert.sameValue(
+ bases[i] ** exponent,
+ NaN,
+ bases[i] + " ** " + exponent
+ );
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A9.js b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A9.js
new file mode 100644
index 0000000000..6c8e6977cc
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/applying-the-exp-operator_A9.js
@@ -0,0 +1,26 @@
+// Copyright 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: If abs(base) < 1 and exponent is +∞, the result is +0.
+
+---*/
+
+
+var exponent = +Infinity;
+var bases = [];
+bases[0] = 0.999999999999999;
+bases[1] = 0.5;
+bases[2] = +0;
+bases[3] = -0;
+bases[4] = -0.5;
+bases[5] = -0.999999999999999;
+
+for (var i = 0; i < bases.length; i++) {
+ if ((bases[i] ** exponent) !== +0) {
+ $ERROR("(" + bases[i] + " ** " + exponent + ") !== +0");
+ }
+}
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-and-number.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-and-number.js
new file mode 100644
index 0000000000..401c4e4a1a
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-and-number.js
@@ -0,0 +1,92 @@
+// Copyright (C) 2018 Igalia, S.L. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+esid: sec-exp-operator-runtime-semantics-evaluation
+description: Mixing BigInt and Number produces a TypeError for exponentiation operator
+features: [BigInt]
+info: |
+ Let base be ? ToNumeric(leftValue).
+ Let exponent be ? ToNumeric(rightValue).
+ If Type(base) does not equal Type(exponent), throw a TypeError exception.
+---*/
+assert.throws(TypeError, function() {
+ 1n ** 1;
+}, '1n ** 1 throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1 ** 1n;
+}, '1 ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ Object(1n) ** 1;
+}, 'Object(1n) ** 1 throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1 ** Object(1n);
+}, '1 ** Object(1n) throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** Object(1);
+}, '1n ** Object(1) throws TypeError');
+
+assert.throws(TypeError, function() {
+ Object(1) ** 1n;
+}, 'Object(1) ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ Object(1n) ** Object(1);
+}, 'Object(1n) ** Object(1) throws TypeError');
+
+assert.throws(TypeError, function() {
+ Object(1) ** Object(1n);
+}, 'Object(1) ** Object(1n) throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** NaN;
+}, '1n ** NaN throws TypeError');
+
+assert.throws(TypeError, function() {
+ NaN ** 1n;
+}, 'NaN ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** Infinity;
+}, '1n ** Infinity throws TypeError');
+
+assert.throws(TypeError, function() {
+ Infinity ** 1n;
+}, 'Infinity ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** true;
+}, '1n ** true throws TypeError');
+
+assert.throws(TypeError, function() {
+ true ** 1n;
+}, 'true ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** '1';
+}, '1n ** "1" throws TypeError');
+
+assert.throws(TypeError, function() {
+ '1' ** 1n;
+}, '"1" ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** null;
+}, '1n ** null throws TypeError');
+
+assert.throws(TypeError, function() {
+ null ** 1n;
+}, 'null ** 1n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 1n ** undefined;
+}, '1n ** undefined throws TypeError');
+
+assert.throws(TypeError, function() {
+ undefined ** 1n;
+}, 'undefined ** 1n throws TypeError');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-arithmetic.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-arithmetic.js
new file mode 100644
index 0000000000..46df0be06a
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-arithmetic.js
@@ -0,0 +1,77 @@
+// Copyright (C) 2017 Robin Templeton. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+esid: sec-exp-operator-runtime-semantics-evaluation
+description: BigInt exponentiation arithmetic
+features: [BigInt]
+---*/
+assert.sameValue(
+ 0x123n ** 0x123n,
+ 0x37AA7FAA38F2F6026AABEFE979EA730BA9EA4CB99E2E3F645D515D3BBE2D84BCD89F8A034BADF3E3DC0CF417258371B31F4555DC0883DA96760AB157DB7DFFF5E3E97A3EAAB8328B2B178060B5A5E4C4DD8BC8D66B7F4D9F0E0B1AC3A566FDE0A15EBF8DBDBD0565C5FBDB7C123CF250E271DF5C38BC6746A1327F09C7FB4B96E0EDA45C429799CA80B1DB039692C70DFFE4E66F1D9CAB4270863B09A7918F774D686F685F560FEDC6B7B85CB45DE5EEEF6A5FE2FC8B5037FB421204641909347C91F2DC252F49B8F310E867E56D1CA2E81EE9A3AA568682C7B8B41D709A2E7F8D9A8D8C56D6BE78B6CA8365E362B81A64974C315FB8FA50CED4F7944F28FA3ECA77B8BCB56DC69814328F891E6065D108EEE7B8E695038090CCA10C0E68DD7A36CFAA1C26CDFEC369FBn,
+ 'The result of (0x123n ** 0x123n) is 0x37AA7FAA38F2F6026AABEFE979EA730BA9EA4CB99E2E3F645D515D3BBE2D84BCD89F8A034BADF3E3DC0CF417258371B31F4555DC0883DA96760AB157DB7DFFF5E3E97A3EAAB8328B2B178060B5A5E4C4DD8BC8D66B7F4D9F0E0B1AC3A566FDE0A15EBF8DBDBD0565C5FBDB7C123CF250E271DF5C38BC6746A1327F09C7FB4B96E0EDA45C429799CA80B1DB039692C70DFFE4E66F1D9CAB4270863B09A7918F774D686F685F560FEDC6B7B85CB45DE5EEEF6A5FE2FC8B5037FB421204641909347C91F2DC252F49B8F310E867E56D1CA2E81EE9A3AA568682C7B8B41D709A2E7F8D9A8D8C56D6BE78B6CA8365E362B81A64974C315FB8FA50CED4F7944F28FA3ECA77B8BCB56DC69814328F891E6065D108EEE7B8E695038090CCA10C0E68DD7A36CFAA1C26CDFEC369FBn'
+);
+
+assert.sameValue(
+ 0x123n ** 0xFFn,
+ 0x8D5BB75861377EC967BF78FDF39CE51696FBD34722999943F8865938772B517167CD5ED775A78987F5106831F4978E0709032B26ED8F13F814699DB8AB3ACD5CF631F2D8B8B706FCF5EF441AAEE745A795EC5CB86A5E8D87D09F648EFC557B98F73E750FEC9AED061D47806F269CCCDFB6D513912A82AE79B171D76AF6D926BC4F4C4DA43A6EFB4D9D1672E356CC1F74A29AF80D53A8F27592F6191AB9B3D57FA2C435CB2CE8F18A3B3448F88F4BAD3606A9878DA9528B569BADAC0C1EC0B1A2B06CD4C64DEEC940807DFD05C56E3E17ADB1A88EDAF0D67C87C1F871BFB5C47CAE8365FE33538317EE2DF4EE52636CE1BDA9E41C7DA72826E4C097A53BD73D8D697E10D28Bn,
+ 'The result of (0x123n ** 0xFFn) is 0x8D5BB75861377EC967BF78FDF39CE51696FBD34722999943F8865938772B517167CD5ED775A78987F5106831F4978E0709032B26ED8F13F814699DB8AB3ACD5CF631F2D8B8B706FCF5EF441AAEE745A795EC5CB86A5E8D87D09F648EFC557B98F73E750FEC9AED061D47806F269CCCDFB6D513912A82AE79B171D76AF6D926BC4F4C4DA43A6EFB4D9D1672E356CC1F74A29AF80D53A8F27592F6191AB9B3D57FA2C435CB2CE8F18A3B3448F88F4BAD3606A9878DA9528B569BADAC0C1EC0B1A2B06CD4C64DEEC940807DFD05C56E3E17ADB1A88EDAF0D67C87C1F871BFB5C47CAE8365FE33538317EE2DF4EE52636CE1BDA9E41C7DA72826E4C097A53BD73D8D697E10D28Bn'
+);
+
+assert.sameValue(0x123n ** 0x3n, 0x178027Bn, 'The result of (0x123n ** 0x3n) is 0x178027Bn');
+assert.sameValue(0x123n ** 0x2n, 0x14AC9n, 'The result of (0x123n ** 0x2n) is 0x14AC9n');
+assert.sameValue(0x123n ** 0x1n, 0x123n, 'The result of (0x123n ** 0x1n) is 0x123n');
+
+assert.sameValue(
+ 0xFFn ** 0x123n,
+ 0x51F5CA2E1A36F5FF1ED3D393D76FBC3612B38EB64E00EDAC5E95ADE0D16D0B044C8E9F2B77B3F31AF9159F482205541E9D3BE9D248FF39CE6524874EBCA60E06302E8B505D11EEEEE869C7F801A82B9739C197E6D63A1EB2D29B5AD5EED4773C762106E9F66BFCB6C11450218973C69DED3FE51FF881AD0430675BF54320513EA766117C50C554E86E22A5ACFD8047D5470B4FCBCB9EFC86196CA77C58F1BEB09F76160D641B82E2481BEDAE089207D49FE0FB7DE14B6C4BC82E9C58140746AC8E74C3353AAF5F9CF47ED1F87C52F463C053DB63CD08CC9866EBA274D39B6B357ADADAD4D210167EF7363453D42BC225D90070336861F2D259489D78B7F04B05FE65E29151ADD2B8F4D318011988550CE590DBA4C868AC65AA325051DF613D6C2E22FFn,
+ 'The result of (0xFFn ** 0x123n) is 0x51F5CA2E1A36F5FF1ED3D393D76FBC3612B38EB64E00EDAC5E95ADE0D16D0B044C8E9F2B77B3F31AF9159F482205541E9D3BE9D248FF39CE6524874EBCA60E06302E8B505D11EEEEE869C7F801A82B9739C197E6D63A1EB2D29B5AD5EED4773C762106E9F66BFCB6C11450218973C69DED3FE51FF881AD0430675BF54320513EA766117C50C554E86E22A5ACFD8047D5470B4FCBCB9EFC86196CA77C58F1BEB09F76160D641B82E2481BEDAE089207D49FE0FB7DE14B6C4BC82E9C58140746AC8E74C3353AAF5F9CF47ED1F87C52F463C053DB63CD08CC9866EBA274D39B6B357ADADAD4D210167EF7363453D42BC225D90070336861F2D259489D78B7F04B05FE65E29151ADD2B8F4D318011988550CE590DBA4C868AC65AA325051DF613D6C2E22FFn'
+);
+
+assert.sameValue(
+ 0xFFn ** 0xFFn,
+ 0x5E5C8B0EB95AB08F9D37EF127FC01BD0E33DE52647528396D78D5F8DA31989E67814F6BBA1FB0F0207010FF5F2347B19D5F6598FC91BF5A88F77DAA3D7B382FEC484F3D205C06A34445384C0E7AB0D883788C68C012CB433055EDDA746A48409444EA91147273B79FC3EABB70ECA552AF650C234BB01ED404427F17CDDDD71D08E39EF9C3982E3CE44E670456AA8154C1FDBD9C35947F494636A425C69BF89E9C75AD3B7A0A559AF0F5DA9947C8DEBA64417310713B23E7EF4DE50BB2A3E90BC2AC3DA5201CCA8D6E5DFEA887C4F7A4E92175D9F88BD2779B57F9EB35BE7528F965A06DA0AC41DCB3A34F1D8AB7D8FEE620A94FAA42C395997756B007FFEFFn,
+ 'The result of (0xFFn ** 0xFFn) is 0x5E5C8B0EB95AB08F9D37EF127FC01BD0E33DE52647528396D78D5F8DA31989E67814F6BBA1FB0F0207010FF5F2347B19D5F6598FC91BF5A88F77DAA3D7B382FEC484F3D205C06A34445384C0E7AB0D883788C68C012CB433055EDDA746A48409444EA91147273B79FC3EABB70ECA552AF650C234BB01ED404427F17CDDDD71D08E39EF9C3982E3CE44E670456AA8154C1FDBD9C35947F494636A425C69BF89E9C75AD3B7A0A559AF0F5DA9947C8DEBA64417310713B23E7EF4DE50BB2A3E90BC2AC3DA5201CCA8D6E5DFEA887C4F7A4E92175D9F88BD2779B57F9EB35BE7528F965A06DA0AC41DCB3A34F1D8AB7D8FEE620A94FAA42C395997756B007FFEFFn'
+);
+
+assert.sameValue(0xFFn ** 0x3n, 0xFD02FFn, 'The result of (0xFFn ** 0x3n) is 0xFD02FFn');
+assert.sameValue(0xFFn ** 0x2n, 0xFE01n, 'The result of (0xFFn ** 0x2n) is 0xFE01n');
+assert.sameValue(0xFFn ** 0x1n, 0xFFn, 'The result of (0xFFn ** 0x1n) is 0xFFn');
+
+assert.sameValue(
+ 0x3n ** 0x123n,
+ 0x25609213623D7D6219085CF49D306450BF6519835586C19D3A4F3A2C5F35B44A300C8A76E11708B5495B9C3EE756BBF19E3FD15CE625D3C0539Bn,
+ 'The result of (0x3n ** 0x123n) is 0x25609213623D7D6219085CF49D306450BF6519835586C19D3A4F3A2C5F35B44A300C8A76E11708B5495B9C3EE756BBF19E3FD15CE625D3C0539Bn'
+);
+
+assert.sameValue(
+ 0x3n ** 0xFFn,
+ 0x11F1B08E87EC42C5D83C3218FC83C41DCFD9F4428F4F92AF1AAA80AA46162B1F71E981273601F4AD1DD4709B5ACA650265A6ABn,
+ 'The result of (0x3n ** 0xFFn) is 0x11F1B08E87EC42C5D83C3218FC83C41DCFD9F4428F4F92AF1AAA80AA46162B1F71E981273601F4AD1DD4709B5ACA650265A6ABn'
+);
+
+assert.sameValue(0x3n ** 0x3n, 0x1Bn, 'The result of (0x3n ** 0x3n) is 0x1Bn');
+assert.sameValue(0x3n ** 0x2n, 0x9n, 'The result of (0x3n ** 0x2n) is 0x9n');
+assert.sameValue(0x3n ** 0x1n, 0x3n, 'The result of (0x3n ** 0x1n) is 0x3n');
+
+assert.sameValue(
+ 0x2n ** 0x123n,
+ 0x8000000000000000000000000000000000000000000000000000000000000000000000000n,
+ 'The result of (0x2n ** 0x123n) is 0x8000000000000000000000000000000000000000000000000000000000000000000000000n'
+);
+
+assert.sameValue(
+ 0x2n ** 0xFFn,
+ 0x8000000000000000000000000000000000000000000000000000000000000000n,
+ 'The result of (0x2n ** 0xFFn) is 0x8000000000000000000000000000000000000000000000000000000000000000n'
+);
+
+assert.sameValue(0x2n ** 0x3n, 0x8n, 'The result of (0x2n ** 0x3n) is 0x8n');
+assert.sameValue(0x2n ** 0x2n, 0x4n, 'The result of (0x2n ** 0x2n) is 0x4n');
+assert.sameValue(0x2n ** 0x1n, 0x2n, 'The result of (0x2n ** 0x1n) is 0x2n');
+assert.sameValue(0x1n ** 0x123n, 0x1n, 'The result of (0x1n ** 0x123n) is 0x1n');
+assert.sameValue(0x1n ** 0xFFn, 0x1n, 'The result of (0x1n ** 0xFFn) is 0x1n');
+assert.sameValue(0x1n ** 0x3n, 0x1n, 'The result of (0x1n ** 0x3n) is 0x1n');
+assert.sameValue(0x1n ** 0x2n, 0x1n, 'The result of (0x1n ** 0x2n) is 0x1n');
+assert.sameValue(0x1n ** 0x1n, 0x1n, 'The result of (0x1n ** 0x1n) is 0x1n');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-errors.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-errors.js
new file mode 100644
index 0000000000..8bb4dd298e
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-errors.js
@@ -0,0 +1,72 @@
+// Copyright (C) 2017 Josh Wolfe. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+description: exponentiation operator ToNumeric with BigInt operands
+esid: sec-exp-operator-runtime-semantics-evaluation
+features: [BigInt, Symbol, Symbol.toPrimitive, computed-property-names]
+---*/
+assert.throws(TypeError, function() {
+ Symbol('1') ** 0n;
+}, 'Symbol("1") ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** Symbol('1');
+}, '0n ** Symbol("1") throws TypeError');
+
+assert.throws(TypeError, function() {
+ Object(Symbol('1')) ** 0n;
+}, 'Object(Symbol("1")) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** Object(Symbol('1'));
+}, '0n ** Object(Symbol("1")) throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ [Symbol.toPrimitive]: function() {
+ return Symbol('1');
+ }
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: function() {return Symbol("1");}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: function() {
+ return Symbol('1');
+ }
+ };
+}, '0n ** {[Symbol.toPrimitive]: function() {return Symbol("1");}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: function() {
+ return Symbol('1');
+ }
+ }) ** 0n;
+}, '({valueOf: function() {return Symbol("1");}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: function() {
+ return Symbol('1');
+ }
+ };
+}, '0n ** {valueOf: function() {return Symbol("1");}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ toString: function() {
+ return Symbol('1');
+ }
+ }) ** 0n;
+}, '({toString: function() {return Symbol("1");}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ toString: function() {
+ return Symbol('1');
+ }
+ };
+}, '0n ** {toString: function() {return Symbol("1");}} throws TypeError');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-negative-exponent-throws.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-negative-exponent-throws.js
new file mode 100644
index 0000000000..0733de65cf
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-negative-exponent-throws.js
@@ -0,0 +1,34 @@
+// Copyright (C) 2017 Robin Templeton. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+description: If the BigInt exponent is < 0, throw a RangeError exception
+esid: sec-exp-operator-runtime-semantics-evaluation
+info: |
+ ExponentiationExpression: UpdateExpression ** ExponentiationExpression
+
+ ...
+ 9. Return ? Type(base)::exponentiate(base, exponent).
+
+ BigInt::exponentiate (base, exponent)
+
+ 1. If exponent < 0, throw a RangeError exception.
+ ...
+features: [BigInt]
+---*/
+assert.throws(RangeError, function() {
+ 1n ** -1n;
+}, '1n ** -1n throws RangeError');
+
+assert.throws(RangeError, function() {
+ 0n ** -1n;
+}, '0n ** -1n throws RangeError');
+
+assert.throws(RangeError, function() {
+ (-1n) ** -1n;
+}, '(-1n) ** -1n throws RangeError');
+
+assert.throws(RangeError, function() {
+ 1n ** -100000000000000000n;
+}, '1n ** -100000000000000000n throws RangeError');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-toprimitive.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-toprimitive.js
new file mode 100644
index 0000000000..fe5dd5cd91
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-toprimitive.js
@@ -0,0 +1,374 @@
+// Copyright (C) 2017 Josh Wolfe. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+description: exponentiation operator ToNumeric with BigInt operands
+esid: sec-exp-operator-runtime-semantics-evaluation
+features: [BigInt, Symbol.toPrimitive, computed-property-names]
+---*/
+function err() {
+ throw new Test262Error();
+}
+
+function MyError() {}
+
+assert.sameValue({
+ [Symbol.toPrimitive]: function() {
+ return 2n;
+ },
+
+ valueOf: err,
+ toString: err
+} ** 1n, 2n, 'The result of (({[Symbol.toPrimitive]: function() {return 2n;}, valueOf: err, toString: err}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ [Symbol.toPrimitive]: function() {
+ return 2n;
+ },
+
+ valueOf: err,
+ toString: err
+}, 1n, 'The result of (1n ** {[Symbol.toPrimitive]: function() {return 2n;}, valueOf: err, toString: err}) is 1n');
+
+assert.sameValue({
+ valueOf: function() {
+ return 2n;
+ },
+
+ toString: err
+} ** 1n, 2n, 'The result of (({valueOf: function() {return 2n;}, toString: err}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: function() {
+ return 2n;
+ },
+
+ toString: err
+}, 1n, 'The result of (1n ** {valueOf: function() {return 2n;}, toString: err}) is 1n');
+
+assert.sameValue({
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {toString: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ [Symbol.toPrimitive]: undefined,
+
+ valueOf: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({[Symbol.toPrimitive]: undefined, valueOf: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ [Symbol.toPrimitive]: undefined,
+
+ valueOf: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {[Symbol.toPrimitive]: undefined, valueOf: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ [Symbol.toPrimitive]: null,
+
+ valueOf: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({[Symbol.toPrimitive]: null, valueOf: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ [Symbol.toPrimitive]: null,
+
+ valueOf: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {[Symbol.toPrimitive]: null, valueOf: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: null,
+
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: null, toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: null,
+
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: null, toString: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: 1,
+
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: 1, toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: 1,
+
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: 1, toString: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: {},
+
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: {}, toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: {},
+
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: {}, toString: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: function() {
+ return {};
+ },
+
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: function() {return {};}, toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: function() {
+ return {};
+ },
+
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: function() {return {};}, toString: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: function() {
+ return Object(12345);
+ },
+
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: function() {return Object(12345);}, toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: function() {
+ return Object(12345);
+ },
+
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: function() {return Object(12345);}, toString: function() {return 2n;}}) is 1n');
+
+assert.throws(TypeError, function() {
+ ({
+ [Symbol.toPrimitive]: 1
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: 1}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: 1
+ };
+}, '0n ** {[Symbol.toPrimitive]: 1} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ [Symbol.toPrimitive]: {}
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: {}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: {}
+ };
+}, '0n ** {[Symbol.toPrimitive]: {}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ [Symbol.toPrimitive]: function() {
+ return Object(1);
+ }
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: function() {return Object(1);}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: function() {
+ return Object(1);
+ }
+ };
+}, '0n ** {[Symbol.toPrimitive]: function() {return Object(1);}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ [Symbol.toPrimitive]: function() {
+ return {};
+ }
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: function() {return {};}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: function() {
+ return {};
+ }
+ };
+}, '0n ** {[Symbol.toPrimitive]: function() {return {};}} throws TypeError');
+
+assert.throws(MyError, function() {
+ ({
+ [Symbol.toPrimitive]: function() {
+ throw new MyError();
+ }
+ }) ** 0n;
+}, '({[Symbol.toPrimitive]: function() {throw new MyError();}}) ** 0n throws MyError');
+
+assert.throws(MyError, function() {
+ 0n ** {
+ [Symbol.toPrimitive]: function() {
+ throw new MyError();
+ }
+ };
+}, '0n ** {[Symbol.toPrimitive]: function() {throw new MyError();}} throws MyError');
+
+assert.throws(MyError, function() {
+ ({
+ valueOf: function() {
+ throw new MyError();
+ }
+ }) ** 0n;
+}, '({valueOf: function() {throw new MyError();}}) ** 0n throws MyError');
+
+assert.throws(MyError, function() {
+ 0n ** {
+ valueOf: function() {
+ throw new MyError();
+ }
+ };
+}, '0n ** {valueOf: function() {throw new MyError();}} throws MyError');
+
+assert.throws(MyError, function() {
+ ({
+ toString: function() {
+ throw new MyError();
+ }
+ }) ** 0n;
+}, '({toString: function() {throw new MyError();}}) ** 0n throws MyError');
+
+assert.throws(MyError, function() {
+ 0n ** {
+ toString: function() {
+ throw new MyError();
+ }
+ };
+}, '0n ** {toString: function() {throw new MyError();}} throws MyError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: null,
+ toString: null
+ }) ** 0n;
+}, '({valueOf: null, toString: null}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: null,
+ toString: null
+ };
+}, '0n ** {valueOf: null, toString: null} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: 1,
+ toString: 1
+ }) ** 0n;
+}, '({valueOf: 1, toString: 1}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: 1,
+ toString: 1
+ };
+}, '0n ** {valueOf: 1, toString: 1} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: {},
+ toString: {}
+ }) ** 0n;
+}, '({valueOf: {}, toString: {}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: {},
+ toString: {}
+ };
+}, '0n ** {valueOf: {}, toString: {}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: function() {
+ return Object(1);
+ },
+
+ toString: function() {
+ return Object(1);
+ }
+ }) ** 0n;
+}, '({valueOf: function() {return Object(1);}, toString: function() {return Object(1);}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: function() {
+ return Object(1);
+ },
+
+ toString: function() {
+ return Object(1);
+ }
+ };
+}, '0n ** {valueOf: function() {return Object(1);}, toString: function() {return Object(1);}} throws TypeError');
+
+assert.throws(TypeError, function() {
+ ({
+ valueOf: function() {
+ return {};
+ },
+
+ toString: function() {
+ return {};
+ }
+ }) ** 0n;
+}, '({valueOf: function() {return {};}, toString: function() {return {};}}) ** 0n throws TypeError');
+
+assert.throws(TypeError, function() {
+ 0n ** {
+ valueOf: function() {
+ return {};
+ },
+
+ toString: function() {
+ return {};
+ }
+ };
+}, '0n ** {valueOf: function() {return {};}, toString: function() {return {};}} throws TypeError');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-wrapped-values.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-wrapped-values.js
new file mode 100644
index 0000000000..32a72d1803
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-wrapped-values.js
@@ -0,0 +1,47 @@
+// Copyright (C) 2017 Josh Wolfe. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+description: exponentiation operator ToNumeric with BigInt operands
+esid: sec-exp-operator-runtime-semantics-evaluation
+features: [BigInt, Symbol.toPrimitive, computed-property-names]
+---*/
+assert.sameValue(Object(2n) ** 1n, 2n, 'The result of (Object(2n) ** 1n) is 2n');
+assert.sameValue(1n ** Object(2n), 1n, 'The result of (1n ** Object(2n)) is 1n');
+
+assert.sameValue({
+ [Symbol.toPrimitive]: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({[Symbol.toPrimitive]: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ [Symbol.toPrimitive]: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {[Symbol.toPrimitive]: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ valueOf: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({valueOf: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ valueOf: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {valueOf: function() {return 2n;}}) is 1n');
+
+assert.sameValue({
+ toString: function() {
+ return 2n;
+ }
+} ** 1n, 2n, 'The result of (({toString: function() {return 2n;}}) ** 1n) is 2n');
+
+assert.sameValue(1n ** {
+ toString: function() {
+ return 2n;
+ }
+}, 1n, 'The result of (1n ** {toString: function() {return 2n;}}) is 1n');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/bigint-zero-base-zero-exponent.js b/js/src/tests/test262/language/expressions/exponentiation/bigint-zero-base-zero-exponent.js
new file mode 100644
index 0000000000..cc4558e0f0
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/bigint-zero-base-zero-exponent.js
@@ -0,0 +1,22 @@
+// Copyright (C) 2017 Robin Templeton. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+description: If the BigInt base and exponent are both 0n, return 1n
+esid: sec-exp-operator-runtime-semantics-evaluation
+info: |
+ ExponentiationExpression: UpdateExpression ** ExponentiationExpression
+
+ ...
+ 9. Return ? Type(base)::exponentiate(base, exponent).
+
+ BigInt::exponentiate (base, exponent)
+
+ 1. If exponent < 0, throw a RangeError exception.
+ 2. If base is 0n and exponent is 0n, return 1n.
+ 3. Return a BigInt representing the mathematical value of base raised to the power exponent.
+ ...
+features: [BigInt]
+---*/
+assert.sameValue(0n ** 0n, 1n, 'The result of (0n ** 0n) is 1n');
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/browser.js b/js/src/tests/test262/language/expressions/exponentiation/browser.js
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/browser.js
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-assignment-operator.js b/js/src/tests/test262/language/expressions/exponentiation/exp-assignment-operator.js
new file mode 100644
index 0000000000..a24818f7da
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-assignment-operator.js
@@ -0,0 +1,27 @@
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-assignment-operators-runtime-semantics-evaluation
+description: Compound Exponentiation Assignment Operator
+info: |
+ AssignmentExpression:
+ LeftHandSideExpression AssignmentOperator AssignmentExpression
+
+ 1. Let lref be the result of evaluating LeftHandSideExpression.
+ 2. Let lval be ? GetValue(lref).
+ 3. Let rref be the result of evaluating AssignmentExpression.
+ 4. Let rval be ? GetValue(rref).
+ 5. Let op be the @ where AssignmentOperator is @=.
+ 6. Let r be the result of applying op to lval and rval as if evaluating the expression lval op rval.
+ 7. Perform ? PutValue(lref, r).
+ 8. Return r.
+
+---*/
+
+var base = -3;
+
+assert.sameValue(base **= 3, -27, "(base **= 3) === -27; where base is -3");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-evaluation-order.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-evaluation-order.js
new file mode 100644
index 0000000000..17aca524d5
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-evaluation-order.js
@@ -0,0 +1,34 @@
+// Copyright (C) 2016 Rick Waldron, André Bargull. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron, André Bargull
+esid: sec-exp-operator-runtime-semantics-evaluation
+description: Exponentiation Operator expression order of evaluation
+info: |
+ ExponentiationExpression:
+ UpdateExpression ** ExponentiationExpression
+
+ 1. Let left be the result of evaluating UpdateExpression.
+ 2. Let leftValue be ? GetValue(left).
+ 3. Let right be the result of evaluating ExponentiationExpression.
+ 4. Let rightValue be ? GetValue(right).
+ 5. Let base be ? ToNumber(leftValue).
+ 6. Let exponent be ? ToNumber(rightValue).
+ 7. Return the result of Applying the ** operator with base and exponent as specified in 12.7.3.4.
+---*/
+
+var capture = [];
+var leftValue = { valueOf() { capture.push("leftValue"); return 3; }};
+var rightValue = { valueOf() { capture.push("rightValue"); return 2; }};
+
+(capture.push("left"), leftValue) ** (capture.push("right"), rightValue);
+
+// Expected per operator evaluation order: "left", "right", "leftValue", "rightValue"
+
+assert.sameValue(capture[0], "left", "Expected the 1st element captured to be 'left'");
+assert.sameValue(capture[1], "right", "Expected the 2nd element captured to be 'right'");
+assert.sameValue(capture[2], "leftValue", "Expected the 3rd element captured to be 'leftValue'");
+assert.sameValue(capture[3], "rightValue", "Expected the 4th element captured to be 'rightValue'");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-unary-expression-semantics.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-unary-expression-semantics.js
new file mode 100644
index 0000000000..94015d9f9a
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-unary-expression-semantics.js
@@ -0,0 +1,68 @@
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Operator expression precedence of unary operators
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `delete` UnaryExpression
+ `void` UnaryExpression
+ `typeof` UnaryExpression
+ `+` UnaryExpression
+ `-` UnaryExpression
+ `~` UnaryExpression
+ `!` UnaryExpression
+---*/
+
+assert.sameValue(-(3 ** 2), -9, "-(3 ** 2) === -9");
+assert.sameValue(+(3 ** 2), 9, "+(3 ** 2) === 9");
+assert.sameValue(~(3 ** 2), -10, "~(3 ** 2) === -10");
+assert.sameValue(!(3 ** 2), false, "!(3 ** 2) === false");
+
+
+assert.sameValue(2 ** -2, 0.25);
+
+var o = { p: 1 };
+
+assert.sameValue(2 ** delete o.p, 2, "delete o.p -> true -> ToNumber(true) -> 1");
+assert.sameValue(2 ** void 1, NaN, "void 1 -> undefined -> ToNumber(undefined) -> NaN");
+assert.sameValue(2 ** typeof 1, NaN, "typeof 1 -> 'number' -> ToNumber('number') -> NaN");
+
+var s = "2";
+var n = 2;
+
+assert.sameValue(2 ** +s, 4, "+s -> +'2' -> 2 -> ToNumber(2) -> 2");
+assert.sameValue(2 ** +n, 4, "+s -> +2 -> 2 -> ToNumber(2) -> 2");
+
+assert.sameValue(2 ** -s, 0.25, "-s -> -'2' -> -2 -> ToNumber(-2) -> -2");
+assert.sameValue(2 ** -n, 0.25, "-s -> -2 -> -2 -> ToNumber(-2) -> -2");
+
+assert.sameValue(2 ** ~s, 0.125, "~s -> ~'2' -> -3 -> ToNumber(-3) -> -3");
+assert.sameValue(2 ** ~n, 0.125, "~s -> ~2 -> -3 -> ToNumber(-3) -> -3");
+
+assert.sameValue(2 ** !s, 1, "!s -> !'2' -> false -> ToNumber(false) -> 0");
+assert.sameValue(2 ** !n, 1, "!s -> !2 -> false -> ToNumber(false) -> 0");
+
+
+var capture = [];
+var leftValue = { valueOf() { capture.push("leftValue"); return 3; }};
+var rightValue = { valueOf() { capture.push("rightValue"); return 2; }};
+
+(capture.push("left"), leftValue) ** +(capture.push("right"), rightValue);
+// ^
+// Changes the order
+
+// Expected per operator evaluation order: "left", "right", "rightValue", "leftValue"
+assert.sameValue(capture[0], "left", "Expected the 1st element captured to be 'left'");
+assert.sameValue(capture[1], "right", "Expected the 2nd element captured to be 'right'");
+assert.sameValue(capture[2], "rightValue", "Expected the 3rd element captured to be 'rightValue'");
+assert.sameValue(capture[3], "leftValue", "Expected the 4th element captured to be 'leftValue'");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-update-expression-semantics.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-update-expression-semantics.js
new file mode 100644
index 0000000000..80882b50a2
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-precedence-update-expression-semantics.js
@@ -0,0 +1,59 @@
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-update-expressions
+description: Exponentiation Operator expression precedence of update operators
+info: |
+ ExponentiationExpression :
+ ...
+ UpdateExpression `**` ExponentiationExpression
+
+ UpdateExpression :
+ LeftHandSideExpression `++`
+ LeftHandSideExpression `--`
+ `++` UnaryExpression
+ `--` UnaryExpression
+---*/
+
+var base = 4;
+assert.sameValue(--base ** 2, 9, "(--base ** 2) === 9");
+assert.sameValue(++base ** 2, 16, "(++base ** 2) === 16");
+assert.sameValue(base++ ** 2, 16, "(base++ ** 2) === 16");
+assert.sameValue(base-- ** 2, 25, "(base-- ** 2) === 25");
+
+base = 4;
+
+// --base ** --base ** 2 -> 3 ** 2 ** 2 -> 3 ** (2 ** 2) -> 81
+assert.sameValue(
+ --base ** --base ** 2,
+ Math.pow(3, Math.pow(2, 2)),
+ "(--base ** --base ** 2) === Math.pow(3, Math.pow(2, 2))"
+);
+
+// ++base ** ++base ** 2 -> 3 ** 4 ** 2 -> 3 ** (4 ** 2) -> 43046721
+assert.sameValue(
+ ++base ** ++base ** 2,
+ Math.pow(3, Math.pow(4, 2)),
+ "(++base ** ++base ** 2) === Math.pow(3, Math.pow(4, 2))"
+);
+
+base = 4;
+
+// base-- ** base-- ** 2 -> 4 ** 3 ** 2 -> 4 ** (3 ** 2) -> 262144
+assert.sameValue(
+ base-- ** base-- ** 2,
+ Math.pow(4, Math.pow(3, 2)),
+ "(base-- ** base-- ** 2) === Math.pow(4, Math.pow(3, 2))"
+);
+
+// base++ ** base++ ** 2 -> 2 ** 3 ** 2 -> 2 ** (3 ** 2) -> 262144
+assert.sameValue(
+ base++ ** base++ ** 2,
+ Math.pow(2, Math.pow(3, 2)),
+ "(base++ ** base++ ** 2) === Math.pow(2, Math.pow(3, 2))"
+);
+
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-bitnot-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-bitnot-unary-expression-base.js
new file mode 100644
index 0000000000..031d9df4ba
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-bitnot-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `~` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `~` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+~3 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-delete-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-delete-unary-expression-base.js
new file mode 100644
index 0000000000..5ff943c92b
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-delete-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `delete` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `delete` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+delete o.p ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-logical-not-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-logical-not-unary-expression-base.js
new file mode 100644
index 0000000000..0e81046819
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-logical-not-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `!` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `!` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+!1 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-negate-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-negate-unary-expression-base.js
new file mode 100644
index 0000000000..4d1dee554d
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-negate-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `-` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `-` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+-3 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-plus-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-plus-unary-expression-base.js
new file mode 100644
index 0000000000..09affe672d
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-plus-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `+` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `+` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
++1 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-typeof-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-typeof-unary-expression-base.js
new file mode 100644
index 0000000000..f5f07f38e1
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-typeof-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `typeof` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `typeof` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+typeof 1 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-void-unary-expression-base.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-void-unary-expression-base.js
new file mode 100644
index 0000000000..865f54e3da
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator-syntax-error-void-unary-expression-base.js
@@ -0,0 +1,25 @@
+// |reftest| error:SyntaxError
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-unary-operators
+description: Exponentiation Expression syntax error, `void` UnaryExpression
+info: |
+ ExponentiationExpression :
+ UnaryExpression
+ ...
+
+ UnaryExpression :
+ ...
+ `void` UnaryExpression
+ ...
+
+negative:
+ phase: parse
+ type: SyntaxError
+---*/
+
+$DONOTEVALUATE();
+void 1 ** 2;
diff --git a/js/src/tests/test262/language/expressions/exponentiation/exp-operator.js b/js/src/tests/test262/language/expressions/exponentiation/exp-operator.js
new file mode 100644
index 0000000000..93a4e250ee
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/exp-operator.js
@@ -0,0 +1,22 @@
+// Copyright (C) 2016 Rick Waldron. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+author: Rick Waldron
+esid: sec-exp-operator
+description: >
+ Performs exponential calculation on operands. Same algorithm as %MathPow%(base, exponent)
+---*/
+
+var exponent = 2;
+assert.sameValue(2 ** 3, 8, "(2 ** 3) === 8");
+assert.sameValue(3 * 2 ** 3, 24, "(3 * 2 ** 3) === 24");
+assert.sameValue(2 ** ++exponent, 8, "(2 ** ++exponent) === 8");
+assert.sameValue(2 ** -1 * 2, 1, "(2 ** -1 * 2) === 1");
+assert.sameValue(2 ** 2 * 4, 16, "(2 ** 2 * 4) === 16");
+assert.sameValue(2 ** 2 / 2, 2, "(2 ** 2 / 2) === 2");
+assert.sameValue(2 ** (3 ** 2), 512, "(2 ** (3 ** 2)) === 512");
+assert.sameValue(2 ** 3 ** 2, 512, "(2 ** 3 ** 2) === 512");
+assert.sameValue(16 / 2 ** 2, 4, "(16 / 2 ** 2) === 4");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/int32_min-exponent.js b/js/src/tests/test262/language/expressions/exponentiation/int32_min-exponent.js
new file mode 100644
index 0000000000..dfc25fb8d0
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/int32_min-exponent.js
@@ -0,0 +1,20 @@
+// Copyright (C) 2018 Mozilla Corporation. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-applying-the-exp-operator
+description: >
+ Using -(2**31) as exponent with the exponentiation operator should behave
+ as expected.
+---*/
+
+const INT32_MIN = -2147483648;
+
+assert.sameValue(2**INT32_MIN, +0.0,
+ "2**-(gonzo huge exponent > 1074) should be +0 because " +
+ "2**-1074 is the smallest positive IEEE-754 number");
+
+assert.sameValue(1**INT32_MIN, 1,
+ "1**-(gonzo huge exponent > 1074) should be 1");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/order-of-evaluation.js b/js/src/tests/test262/language/expressions/exponentiation/order-of-evaluation.js
new file mode 100644
index 0000000000..968860b5a1
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/order-of-evaluation.js
@@ -0,0 +1,140 @@
+// Copyright (C) 2018 Igalia, S.L. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+esid: sec-exp-operator-runtime-semantics-evaluation
+description: Type coercion order of operations for exponentiation operator
+features: [Symbol]
+info: |
+ Evaluate lhs
+ Evaluate rhs
+ ToNumeric(lhs)
+ ToNumeric(rhs)
+---*/
+
+function MyError() {}
+var trace;
+
+// ?GetValue(lhs) throws.
+trace = "";
+assert.throws(MyError, function() {
+ (function() {
+ trace += "1";
+ throw new MyError();
+ })() ** (function() {
+ trace += "2";
+ throw new Test262Error("should not be evaluated");
+ })();
+}, "?GetValue(lhs) throws.");
+assert.sameValue(trace, "1", "?GetValue(lhs) throws.");
+
+// ?GetValue(rhs) throws.
+trace = "";
+assert.throws(MyError, function() {
+ (function() {
+ trace += "1";
+ return {
+ valueOf: function() {
+ trace += "3";
+ throw new Test262Error("should not be evaluated");
+ }
+ };
+ })() ** (function() {
+ trace += "2";
+ throw new MyError();
+ })();
+}, "?GetValue(rhs) throws.");
+assert.sameValue(trace, "12", "?GetValue(rhs) throws.");
+
+// ?ToPrimive(lhs) throws.
+trace = "";
+assert.throws(MyError, function() {
+ (function() {
+ trace += "1";
+ return {
+ valueOf: function() {
+ trace += "3";
+ throw new MyError();
+ }
+ };
+ })() ** (function() {
+ trace += "2";
+ return {
+ valueOf: function() {
+ trace += "4";
+ throw new Test262Error("should not be evaluated");
+ }
+ };
+ })();
+}, "?ToPrimive(lhs) throws.");
+assert.sameValue(trace, "123", "?ToPrimive(lhs) throws.");
+
+// ?ToPrimive(rhs) throws.
+trace = "";
+assert.throws(MyError, function() {
+ (function() {
+ trace += "1";
+ return {
+ valueOf: function() {
+ trace += "3";
+ return 1;
+ }
+ };
+ })() ** (function() {
+ trace += "2";
+ return {
+ valueOf: function() {
+ trace += "4";
+ throw new MyError();
+ }
+ };
+ })();
+}, "?ToPrimive(rhs) throws.");
+assert.sameValue(trace, "1234", "?ToPrimive(rhs) throws.");
+
+// ?ToNumeric(lhs) throws.
+trace = "";
+assert.throws(TypeError, function() {
+ (function() {
+ trace += "1";
+ return {
+ valueOf: function() {
+ trace += "3";
+ return Symbol("1");
+ }
+ };
+ })() ** (function() {
+ trace += "2";
+ return {
+ valueOf: function() {
+ trace += "4";
+ throw new Test262Error("should not be evaluated");
+ }
+ };
+ })();
+}, "?ToNumeric(lhs) throws.");
+assert.sameValue(trace, "123", "?ToNumeric(lhs) throws.");
+
+// GetValue(lhs) throws.
+trace = "";
+assert.throws(TypeError, function() {
+ (function() {
+ trace += "1";
+ return {
+ valueOf: function() {
+ trace += "3";
+ return 1;
+ }
+ };
+ })() ** (function() {
+ trace += "2";
+ return {
+ valueOf: function() {
+ trace += "4";
+ return Symbol("1");
+ }
+ };
+ })();
+}, "GetValue(lhs) throws.");
+assert.sameValue(trace, "1234", "GetValue(lhs) throws.");
+
+reportCompare(0, 0);
diff --git a/js/src/tests/test262/language/expressions/exponentiation/shell.js b/js/src/tests/test262/language/expressions/exponentiation/shell.js
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/exponentiation/shell.js