]> git.kaiwu.me - njs.git/commitdiff
Fixed Object.prototype.hasOwnProperty() for non-object properties.
authorDmitry Volyntsev <xeioex@nginx.com>
Fri, 19 Oct 2018 17:55:23 +0000 (20:55 +0300)
committerDmitry Volyntsev <xeioex@nginx.com>
Fri, 19 Oct 2018 17:55:23 +0000 (20:55 +0300)
This fixes #9 issue on Github.

njs/njs_object.c
njs/test/njs_unit_test.c

index 4872650b07f8ec7629b218eec3c754ef59f9a68f..625ed0992ff12cf6934d0241f5874be7919f1b7c 100644 (file)
@@ -2079,45 +2079,38 @@ static njs_ret_t
 njs_object_prototype_has_own_property(njs_vm_t *vm, njs_value_t *args,
     nxt_uint_t nargs, njs_index_t unused)
 {
-    uint32_t            index;
-    nxt_int_t           ret;
-    njs_array_t         *array;
-    const njs_value_t   *value, *prop, *retval;
-    nxt_lvlhsh_query_t  lhq;
+    nxt_int_t             ret;
+    const njs_value_t     *value, *property;
+    njs_property_query_t  pq;
 
-    retval = &njs_value_false;
-    value = &args[0];
+    value = njs_arg(args, nargs, 0);
 
-    if (njs_is_object(value)) {
+    if (njs_is_null_or_void(value)) {
+        njs_type_error(vm, "cannot convert %s argument to object",
+                       njs_type_string(value->type));
+        return NXT_ERROR;
+    }
 
-        prop = njs_arg(args, nargs, 1);
+    property = njs_arg(args, nargs, 1);
 
-        if (njs_is_array(value)) {
-            array = value->data.u.array;
-            index = njs_string_to_index(prop);
+    njs_property_query_init(&pq, NJS_PROPERTY_QUERY_GET, 1);
 
-            if (index < array->length && njs_is_valid(&array->start[index])) {
-                retval = &njs_value_true;
-                goto done;
-            }
-        }
+    ret = njs_property_query(vm, &pq, (njs_value_t *) value, property);
 
-        njs_string_get(prop, &lhq.key);
-        lhq.key_hash = nxt_djb_hash(lhq.key.start, lhq.key.length);
-        lhq.proto = &njs_object_hash_proto;
+    switch (ret) {
+    case NXT_OK:
+        vm->retval = njs_value_true;
+        return NXT_OK;
 
-        ret = nxt_lvlhsh_find(&value->data.u.object->hash, &lhq);
+    case NXT_DECLINED:
+        vm->retval = njs_value_false;
+        return NXT_OK;
 
-        if (ret == NXT_OK) {
-            retval = &njs_value_true;
-        }
+    case NJS_TRAP:
+    case NXT_ERROR:
+    default:
+        return ret;
     }
-
-done:
-
-    vm->retval = *retval;
-
-    return NXT_OK;
 }
 
 
index db134ff0a635a6a70c69fde37426ff38262a3f41..a08443ff9a3e72fc74c7da92800d8cda8f80c218 100644 (file)
@@ -3671,6 +3671,15 @@ static njs_unit_test_t  njs_test[] =
     { nxt_string("'abc'.length"),
       nxt_string("3") },
 
+    { nxt_string("''.hasOwnProperty('length')"),
+      nxt_string("true") },
+
+    { nxt_string("'abc'.hasOwnProperty('length')"),
+      nxt_string("true") },
+
+    { nxt_string("(new String('abc')).hasOwnProperty('length')"),
+      nxt_string("true") },
+
     { nxt_string("'abc'.toUTF8().length"),
       nxt_string("3") },
 
@@ -7103,6 +7112,21 @@ static njs_unit_test_t  njs_test[] =
     { nxt_string("[,].hasOwnProperty()"),
       nxt_string("false") },
 
+    { nxt_string("[1,2].hasOwnProperty('len')"),
+      nxt_string("false") },
+
+    { nxt_string("[].hasOwnProperty('length')"),
+      nxt_string("true") },
+
+    { nxt_string("[1,2].hasOwnProperty('length')"),
+      nxt_string("true") },
+
+    { nxt_string("(new Array()).hasOwnProperty('length')"),
+      nxt_string("true") },
+
+    { nxt_string("(new Array(10)).hasOwnProperty('length')"),
+      nxt_string("true") },
+
     { nxt_string("Object.valueOf.hasOwnProperty()"),
       nxt_string("false") },