| Index: test/mjsunit/external-array.js
 | 
| diff --git a/test/mjsunit/external-array.js b/test/mjsunit/external-array.js
 | 
| index 32f78a72d400639e86a4b19a38c91e2def75341f..d02922006a18842d9bbffc66d29c144094b866d4 100644
 | 
| --- a/test/mjsunit/external-array.js
 | 
| +++ b/test/mjsunit/external-array.js
 | 
| @@ -52,13 +52,53 @@ assertThrows(abfunc1);
 | 
|  // Test derivation from an ArrayBuffer
 | 
|  var ab = new ArrayBuffer(12);
 | 
|  var derived_uint8 = new Uint8Array(ab);
 | 
| +assertSame(ab, derived_uint8.buffer);
 | 
|  assertEquals(12, derived_uint8.length);
 | 
| +assertEquals(12, derived_uint8.byteLength);
 | 
| +assertEquals(0, derived_uint8.byteOffset);
 | 
| +assertEquals(1, derived_uint8.BYTES_PER_ELEMENT);
 | 
| +var derived_uint8_2 = new Uint8Array(ab,7);
 | 
| +assertSame(ab, derived_uint8_2.buffer);
 | 
| +assertEquals(5, derived_uint8_2.length);
 | 
| +assertEquals(5, derived_uint8_2.byteLength);
 | 
| +assertEquals(7, derived_uint8_2.byteOffset);
 | 
| +assertEquals(1, derived_uint8_2.BYTES_PER_ELEMENT);
 | 
| +var derived_int16 = new Int16Array(ab);
 | 
| +assertSame(ab, derived_int16.buffer);
 | 
| +assertEquals(6, derived_int16.length);
 | 
| +assertEquals(12, derived_int16.byteLength);
 | 
| +assertEquals(0, derived_int16.byteOffset);
 | 
| +assertEquals(2, derived_int16.BYTES_PER_ELEMENT);
 | 
| +var derived_int16_2 = new Int16Array(ab,6);
 | 
| +assertSame(ab, derived_int16_2.buffer);
 | 
| +assertEquals(3, derived_int16_2.length);
 | 
| +assertEquals(6, derived_int16_2.byteLength);
 | 
| +assertEquals(6, derived_int16_2.byteOffset);
 | 
| +assertEquals(2, derived_int16_2.BYTES_PER_ELEMENT);
 | 
|  var derived_uint32 = new Uint32Array(ab);
 | 
| +assertSame(ab, derived_uint32.buffer);
 | 
|  assertEquals(3, derived_uint32.length);
 | 
| +assertEquals(12, derived_uint32.byteLength);
 | 
| +assertEquals(0, derived_uint32.byteOffset);
 | 
| +assertEquals(4, derived_uint32.BYTES_PER_ELEMENT);
 | 
|  var derived_uint32_2 = new Uint32Array(ab,4);
 | 
| +assertSame(ab, derived_uint32_2.buffer);
 | 
|  assertEquals(2, derived_uint32_2.length);
 | 
| +assertEquals(8, derived_uint32_2.byteLength);
 | 
| +assertEquals(4, derived_uint32_2.byteOffset);
 | 
| +assertEquals(4, derived_uint32_2.BYTES_PER_ELEMENT);
 | 
|  var derived_uint32_3 = new Uint32Array(ab,4,1);
 | 
| +assertSame(ab, derived_uint32_3.buffer);
 | 
|  assertEquals(1, derived_uint32_3.length);
 | 
| +assertEquals(4, derived_uint32_3.byteLength);
 | 
| +assertEquals(4, derived_uint32_3.byteOffset);
 | 
| +assertEquals(4, derived_uint32_3.BYTES_PER_ELEMENT);
 | 
| +var derived_float64 = new Float64Array(ab,0,1);
 | 
| +assertSame(ab, derived_float64.buffer);
 | 
| +assertEquals(1, derived_float64.length);
 | 
| +assertEquals(8, derived_float64.byteLength);
 | 
| +assertEquals(0, derived_float64.byteOffset);
 | 
| +assertEquals(8, derived_float64.BYTES_PER_ELEMENT);
 | 
|  
 | 
|  // If a given byteOffset and length references an area beyond the end of the
 | 
|  // ArrayBuffer an exception is raised.
 | 
| @@ -87,6 +127,24 @@ function abfunc6() {
 | 
|  }
 | 
|  assertThrows(abfunc6);
 | 
|  
 | 
| +// Test that an array constructed without an array buffer creates one properly.
 | 
| +a = new Uint8Array(31);
 | 
| +assertEquals(a.byteLength, a.buffer.byteLength);
 | 
| +assertEquals(a.length, a.buffer.byteLength);
 | 
| +assertEquals(a.length * a.BYTES_PER_ELEMENT, a.buffer.byteLength);
 | 
| +a = new Int16Array(5);
 | 
| +assertEquals(a.byteLength, a.buffer.byteLength);
 | 
| +assertEquals(a.length * a.BYTES_PER_ELEMENT, a.buffer.byteLength);
 | 
| +a = new Float64Array(7);
 | 
| +assertEquals(a.byteLength, a.buffer.byteLength);
 | 
| +assertEquals(a.length * a.BYTES_PER_ELEMENT, a.buffer.byteLength);
 | 
| +
 | 
| +// Test that an implicitly created buffer is a valid buffer.
 | 
| +a = new Float64Array(7);
 | 
| +assertSame(a.buffer, (new Uint16Array(a.buffer)).buffer);
 | 
| +assertSame(a.buffer, (new Float32Array(a.buffer,4)).buffer);
 | 
| +assertSame(a.buffer, (new Int8Array(a.buffer,3,51)).buffer);
 | 
| +
 | 
|  // Test the correct behavior of the |BYTES_PER_ELEMENT| property (which is
 | 
|  // "constant", but not read-only).
 | 
|  a = new Int32Array(2);
 | 
| @@ -351,3 +409,25 @@ assertTrue(isNaN(float64_array[0]));
 | 
|  %OptimizeFunctionOnNextCall(store_float64_undefined);
 | 
|  store_float64_undefined(float64_array);
 | 
|  assertTrue(isNaN(float64_array[0]));
 | 
| +
 | 
| +
 | 
| +// Check handling of 0-sized buffers and arrays.
 | 
| +
 | 
| +ab = new ArrayBuffer(0);
 | 
| +assertEquals(0, ab.byteLength);
 | 
| +a = new Int8Array(ab);
 | 
| +assertEquals(0, a.byteLength);
 | 
| +assertEquals(0, a.length);
 | 
| +a[0] = 1;
 | 
| +assertEquals(undefined, a[0])
 | 
| +ab = new ArrayBuffer(16);
 | 
| +a = new Float32Array(ab,4,0);
 | 
| +assertEquals(0, a.byteLength);
 | 
| +assertEquals(0, a.length);
 | 
| +a[0] = 1;
 | 
| +assertEquals(undefined, a[0])
 | 
| +a = new Uint16Array(0);
 | 
| +assertEquals(0, a.byteLength);
 | 
| +assertEquals(0, a.length);
 | 
| +a[0] = 1;
 | 
| +assertEquals(undefined, a[0])
 | 
| 
 |