8020357: throw RangeError for too large NativeArrayBuffer size
authorattila
Tue, 16 Jul 2013 15:28:33 +0200
changeset 18883 30a82ef1bdf7
parent 18882 d481e416eb14
child 18884 b2032ab50ac4
8020357: throw RangeError for too large NativeArrayBuffer size Reviewed-by: jlaskey, hannesw, sundar
nashorn/src/jdk/nashorn/internal/objects/ArrayBufferView.java
nashorn/test/script/basic/JDK-8020357.js
nashorn/test/script/basic/JDK-8020357.js.EXPECTED
--- a/nashorn/src/jdk/nashorn/internal/objects/ArrayBufferView.java	Tue Jul 16 09:54:04 2013 +0530
+++ b/nashorn/src/jdk/nashorn/internal/objects/ArrayBufferView.java	Tue Jul 16 15:28:33 2013 +0200
@@ -25,6 +25,8 @@
 
 package jdk.nashorn.internal.objects;
 
+import static jdk.nashorn.internal.runtime.ECMAErrors.rangeError;
+
 import jdk.nashorn.internal.objects.annotations.Attribute;
 import jdk.nashorn.internal.objects.annotations.Getter;
 import jdk.nashorn.internal.objects.annotations.ScriptClass;
@@ -34,8 +36,6 @@
 import jdk.nashorn.internal.runtime.ScriptRuntime;
 import jdk.nashorn.internal.runtime.arrays.ArrayData;
 
-import static jdk.nashorn.internal.runtime.ECMAErrors.rangeError;
-
 @ScriptClass("ArrayBufferView")
 abstract class ArrayBufferView extends ScriptObject {
 
@@ -275,12 +275,17 @@
 
     protected static abstract class Factory {
         final int bytesPerElement;
+        final int maxElementLength;
 
         public Factory(final int bytesPerElement) {
             this.bytesPerElement = bytesPerElement;
+            this.maxElementLength = Integer.MAX_VALUE / bytesPerElement;
         }
 
         public final ArrayBufferView construct(final int elementLength) {
+            if(elementLength > maxElementLength) {
+                throw rangeError("inappropriate.array.buffer.length", JSType.toString(elementLength));
+            }
             return construct(new NativeArrayBuffer(elementLength * bytesPerElement), 0, elementLength);
         }
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/nashorn/test/script/basic/JDK-8020357.js	Tue Jul 16 15:28:33 2013 +0200
@@ -0,0 +1,52 @@
+/*
+ * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ * 
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ * 
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ * 
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ * 
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+/**
+ * JDK-8020357: Return range error for too big native array buffers
+ *
+ * @test
+ * @run
+ */
+
+var UNSIGNED_INT_BITS = 31
+var BYTES_PER_INT_32  =  4
+
+var limit = Math.pow(2, UNSIGNED_INT_BITS)/BYTES_PER_INT_32
+
+try {
+    // A value at or under the limit should either succeed if we have
+    // enough heap, or throw an OutOfMemoryError if we don't.
+    Int32Array(limit - 1)
+} catch(e) {
+    if(!(e instanceof java.lang.OutOfMemoryError)) {
+        // Only print an unexpected result; OutOfMemoryError is expected
+        print(e)
+    }
+}
+
+// A value over the limit should throw a RangeError.
+try {
+    Int32Array(limit)
+} catch(e) {
+    print(e)
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/nashorn/test/script/basic/JDK-8020357.js.EXPECTED	Tue Jul 16 15:28:33 2013 +0200
@@ -0,0 +1,1 @@
+RangeError: inappropriate array buffer length: 536870912