summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/self-hosting/GetStringDataProperty.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/jit-test/tests/self-hosting/GetStringDataProperty.js')
-rw-r--r--js/src/jit-test/tests/self-hosting/GetStringDataProperty.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/self-hosting/GetStringDataProperty.js b/js/src/jit-test/tests/self-hosting/GetStringDataProperty.js
new file mode 100644
index 000000000..119bedcbc
--- /dev/null
+++ b/js/src/jit-test/tests/self-hosting/GetStringDataProperty.js
@@ -0,0 +1,33 @@
+// Bug 1267364 - GetStringDataProperty should return undefined when the object
+// is non-native.
+
+var GetStringDataProperty = getSelfHostedValue("GetStringDataProperty");
+
+function testProxy() {
+ var obj = new Proxy({"foo": "10"}, {});
+ var v = GetStringDataProperty(obj, "foo");
+ assertEq(v, undefined);
+}
+
+function testMaybeUnboxed() {
+ // Use JSON.parse to create unboxed object if availbale.
+ var obj = JSON.parse("[" + '{"foo": "10"},'.repeat(100) +"{}]");
+
+ // GetStringDataProperty may return "10" or undefined, depending on whether
+ // `obj` is unboxed or not
+ var v = GetStringDataProperty(obj[0], "foo");
+ assertEq(v == undefined || v == "10", true);
+}
+
+function testTypedObject() {
+ var {StructType, string} = TypedObject;
+ var S = new StructType({foo: string});
+ var obj = new S({foo: "10"});
+ var v = GetStringDataProperty(obj, "foo");
+ assertEq(v, undefined);
+}
+
+testProxy();
+testMaybeUnboxed();
+if (typeof TypedObject !== "undefined")
+ testTypedObject();