summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js')
-rw-r--r--js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js54
1 files changed, 54 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js b/js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js
new file mode 100644
index 0000000000..7add56c4b5
--- /dev/null
+++ b/js/src/tests/test262/built-ins/Array/prototype/sort/S15.4.4.11_A3_T1.js
@@ -0,0 +1,54 @@
+// Copyright 2009 the Sputnik authors. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+info: |
+ The sort function is intentionally generic.
+ It does not require that its this value be an Array object
+esid: sec-array.prototype.sort
+description: If comparefn is undefined, use SortCompare operator
+---*/
+
+var obj = {
+ valueOf: function() {
+ return 1
+ },
+ toString: function() {
+ return -2
+ }
+};
+var alphabetR = {
+ 0: undefined,
+ 1: 2,
+ 2: 1,
+ 3: "X",
+ 4: -1,
+ 5: "a",
+ 6: true,
+ 7: obj,
+ 8: NaN,
+ 9: Infinity
+};
+alphabetR.sort = Array.prototype.sort;
+alphabetR.length = 10;
+var alphabet = [-1, obj, 1, 2, Infinity, NaN, "X", "a", true, undefined];
+
+alphabetR.sort();
+
+alphabetR.getClass = Object.prototype.toString;
+if (alphabetR.getClass() !== "[object " + "Object" + "]") {
+ throw new Test262Error('#0: alphabetR.sort() is Object object, not Array object');
+}
+
+var result = true;
+for (var i = 0; i < 10; i++) {
+ if (!(isNaN(alphabetR[i]) && isNaN(alphabet[i]))) {
+ if (alphabetR[i] !== alphabet[i]) result = false;
+ }
+}
+
+if (result !== true) {
+ throw new Test262Error('#1: Check ToString operator');
+}
+
+reportCompare(0, 0);