summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js')
-rw-r--r--js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js50
1 files changed, 50 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js b/js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js
new file mode 100644
index 0000000000..1965519971
--- /dev/null
+++ b/js/src/tests/test262/built-ins/DataView/prototype/getInt16/to-boolean-littleendian.js
@@ -0,0 +1,50 @@
+// Copyright (C) 2016 the V8 project authors. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+
+/*---
+esid: sec-dataview.prototype.getint16
+description: >
+ Boolean littleEndian argument coerced in ToBoolean
+info: |
+ 24.2.4.8 DataView.prototype.getInt16 ( byteOffset [ , littleEndian ] )
+
+ 1. Let v be the this value.
+ 2. If littleEndian is not present, let littleEndian be false.
+ 3. Return ? GetViewValue(v, byteOffset, littleEndian, "Int16").
+
+ 24.2.1.1 GetViewValue ( view, requestIndex, isLittleEndian, type )
+
+ ...
+ 14. Let bufferIndex be getIndex + viewOffset.
+ 15. Return GetValueFromBuffer(buffer, bufferIndex, type, isLittleEndian).
+ ...
+
+ 24.1.1.5 GetValueFromBuffer ( arrayBuffer, byteIndex, type [ , isLittleEndian
+ ] )
+
+ ...
+ 8. If isLittleEndian is false, reverse the order of the elements of rawValue.
+ ...
+features: [DataView.prototype.setUint8, Symbol]
+---*/
+
+var buffer = new ArrayBuffer(2);
+var sample = new DataView(buffer, 0);
+
+sample.setUint8(0, 0);
+sample.setUint8(1, 42);
+
+// False
+assert.sameValue(sample.getInt16(0), 42, "no arg");
+assert.sameValue(sample.getInt16(0, undefined), 42, "undefined");
+assert.sameValue(sample.getInt16(0, null), 42, "null");
+assert.sameValue(sample.getInt16(0, 0), 42, "0");
+assert.sameValue(sample.getInt16(0, ""), 42, "the empty string");
+
+// True
+assert.sameValue(sample.getInt16(0, {}), 10752, "{}");
+assert.sameValue(sample.getInt16(0, Symbol("1")), 10752, "symbol");
+assert.sameValue(sample.getInt16(0, 1), 10752, "1");
+assert.sameValue(sample.getInt16(0, "string"), 10752, "string");
+
+reportCompare(0, 0);