test: cover napi_get/set/has_named_property()
Add test coverage for these N-APIs. PR-URL: https://github.com/nodejs/node/pull/26947 Reviewed-By: Daniel Bevenius <daniel.bevenius@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
This commit is contained in:
parent
e3032708e0
commit
baa54a5ae7
@ -17,12 +17,14 @@ const object = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
assert.strictEqual(test_object.Get(object, 'hello'), 'world');
|
assert.strictEqual(test_object.Get(object, 'hello'), 'world');
|
||||||
|
assert.strictEqual(test_object.GetNamed(object, 'hello'), 'world');
|
||||||
assert.deepStrictEqual(test_object.Get(object, 'array'),
|
assert.deepStrictEqual(test_object.Get(object, 'array'),
|
||||||
[ 1, 94, 'str', 12.321, { test: 'obj in arr' } ]);
|
[ 1, 94, 'str', 12.321, { test: 'obj in arr' } ]);
|
||||||
assert.deepStrictEqual(test_object.Get(object, 'newObject'),
|
assert.deepStrictEqual(test_object.Get(object, 'newObject'),
|
||||||
{ test: 'obj in obj' });
|
{ test: 'obj in obj' });
|
||||||
|
|
||||||
assert(test_object.Has(object, 'hello'));
|
assert(test_object.Has(object, 'hello'));
|
||||||
|
assert(test_object.HasNamed(object, 'hello'));
|
||||||
assert(test_object.Has(object, 'array'));
|
assert(test_object.Has(object, 'array'));
|
||||||
assert(test_object.Has(object, 'newObject'));
|
assert(test_object.Has(object, 'newObject'));
|
||||||
|
|
||||||
@ -113,8 +115,10 @@ assert.strictEqual(newObject.test_string, 'test string');
|
|||||||
assert.strictEqual(test_object.Get(object2, sym1), '@@iterator');
|
assert.strictEqual(test_object.Get(object2, sym1), '@@iterator');
|
||||||
assert.strictEqual(test_object.Get(object2, sym2), sym3);
|
assert.strictEqual(test_object.Get(object2, sym2), sym3);
|
||||||
assert(test_object.Set(object2, 'string', 'value'));
|
assert(test_object.Set(object2, 'string', 'value'));
|
||||||
|
assert(test_object.SetNamed(object2, 'named_string', 'value'));
|
||||||
assert(test_object.Set(object2, sym4, 123));
|
assert(test_object.Set(object2, sym4, 123));
|
||||||
assert(test_object.Has(object2, 'string'));
|
assert(test_object.Has(object2, 'string'));
|
||||||
|
assert(test_object.HasNamed(object2, 'named_string'));
|
||||||
assert(test_object.Has(object2, sym4));
|
assert(test_object.Has(object2, sym4));
|
||||||
assert.strictEqual(test_object.Get(object2, 'string'), 'value');
|
assert.strictEqual(test_object.Get(object2, 'string'), 'value');
|
||||||
assert.strictEqual(test_object.Get(object2, sym4), 123);
|
assert.strictEqual(test_object.Get(object2, sym4), 123);
|
||||||
|
@ -30,6 +30,39 @@ static napi_value Get(napi_env env, napi_callback_info info) {
|
|||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static napi_value GetNamed(napi_env env, napi_callback_info info) {
|
||||||
|
size_t argc = 2;
|
||||||
|
napi_value args[2];
|
||||||
|
char key[256] = "";
|
||||||
|
size_t key_length;
|
||||||
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, argc >= 2, "Wrong number of arguments");
|
||||||
|
|
||||||
|
napi_valuetype value_type0;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[0], &value_type0));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type0 == napi_object,
|
||||||
|
"Wrong type of arguments. Expects an object as first argument.");
|
||||||
|
|
||||||
|
napi_valuetype value_type1;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[1], &value_type1));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type1 == napi_string,
|
||||||
|
"Wrong type of arguments. Expects a string as second.");
|
||||||
|
|
||||||
|
napi_value object = args[0];
|
||||||
|
NAPI_CALL(env,
|
||||||
|
napi_get_value_string_utf8(env, args[1], key, 255, &key_length));
|
||||||
|
key[255] = 0;
|
||||||
|
NAPI_ASSERT(env, key_length <= 255,
|
||||||
|
"Cannot accommodate keys longer than 255 bytes");
|
||||||
|
napi_value output;
|
||||||
|
NAPI_CALL(env, napi_get_named_property(env, object, key, &output));
|
||||||
|
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
static napi_value Set(napi_env env, napi_callback_info info) {
|
static napi_value Set(napi_env env, napi_callback_info info) {
|
||||||
size_t argc = 3;
|
size_t argc = 3;
|
||||||
napi_value args[3];
|
napi_value args[3];
|
||||||
@ -57,6 +90,41 @@ static napi_value Set(napi_env env, napi_callback_info info) {
|
|||||||
return valuetrue;
|
return valuetrue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static napi_value SetNamed(napi_env env, napi_callback_info info) {
|
||||||
|
size_t argc = 3;
|
||||||
|
napi_value args[3];
|
||||||
|
char key[256] = "";
|
||||||
|
size_t key_length;
|
||||||
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, argc >= 3, "Wrong number of arguments");
|
||||||
|
|
||||||
|
napi_valuetype value_type0;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[0], &value_type0));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type0 == napi_object,
|
||||||
|
"Wrong type of arguments. Expects an object as first argument.");
|
||||||
|
|
||||||
|
napi_valuetype value_type1;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[1], &value_type1));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type1 == napi_string,
|
||||||
|
"Wrong type of arguments. Expects a string as second.");
|
||||||
|
|
||||||
|
NAPI_CALL(env,
|
||||||
|
napi_get_value_string_utf8(env, args[1], key, 255, &key_length));
|
||||||
|
key[255] = 0;
|
||||||
|
NAPI_ASSERT(env, key_length <= 255,
|
||||||
|
"Cannot accommodate keys longer than 255 bytes");
|
||||||
|
|
||||||
|
NAPI_CALL(env, napi_set_named_property(env, args[0], key, args[2]));
|
||||||
|
|
||||||
|
napi_value value_true;
|
||||||
|
NAPI_CALL(env, napi_get_boolean(env, true, &value_true));
|
||||||
|
|
||||||
|
return value_true;
|
||||||
|
}
|
||||||
|
|
||||||
static napi_value Has(napi_env env, napi_callback_info info) {
|
static napi_value Has(napi_env env, napi_callback_info info) {
|
||||||
size_t argc = 2;
|
size_t argc = 2;
|
||||||
napi_value args[2];
|
napi_value args[2];
|
||||||
@ -85,6 +153,42 @@ static napi_value Has(napi_env env, napi_callback_info info) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static napi_value HasNamed(napi_env env, napi_callback_info info) {
|
||||||
|
size_t argc = 2;
|
||||||
|
napi_value args[2];
|
||||||
|
char key[256] = "";
|
||||||
|
size_t key_length;
|
||||||
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, argc >= 2, "Wrong number of arguments");
|
||||||
|
|
||||||
|
napi_valuetype value_type0;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[0], &value_type0));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type0 == napi_object,
|
||||||
|
"Wrong type of arguments. Expects an object as first argument.");
|
||||||
|
|
||||||
|
napi_valuetype value_type1;
|
||||||
|
NAPI_CALL(env, napi_typeof(env, args[1], &value_type1));
|
||||||
|
|
||||||
|
NAPI_ASSERT(env, value_type1 == napi_string || value_type1 == napi_symbol,
|
||||||
|
"Wrong type of arguments. Expects a string as second.");
|
||||||
|
|
||||||
|
NAPI_CALL(env,
|
||||||
|
napi_get_value_string_utf8(env, args[1], key, 255, &key_length));
|
||||||
|
key[255] = 0;
|
||||||
|
NAPI_ASSERT(env, key_length <= 255,
|
||||||
|
"Cannot accommodate keys longer than 255 bytes");
|
||||||
|
|
||||||
|
bool has_property;
|
||||||
|
NAPI_CALL(env, napi_has_named_property(env, args[0], key, &has_property));
|
||||||
|
|
||||||
|
napi_value ret;
|
||||||
|
NAPI_CALL(env, napi_get_boolean(env, has_property, &ret));
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static napi_value HasOwn(napi_env env, napi_callback_info info) {
|
static napi_value HasOwn(napi_env env, napi_callback_info info) {
|
||||||
size_t argc = 2;
|
size_t argc = 2;
|
||||||
napi_value args[2];
|
napi_value args[2];
|
||||||
@ -220,8 +324,11 @@ EXTERN_C_START
|
|||||||
napi_value Init(napi_env env, napi_value exports) {
|
napi_value Init(napi_env env, napi_value exports) {
|
||||||
napi_property_descriptor descriptors[] = {
|
napi_property_descriptor descriptors[] = {
|
||||||
DECLARE_NAPI_PROPERTY("Get", Get),
|
DECLARE_NAPI_PROPERTY("Get", Get),
|
||||||
|
DECLARE_NAPI_PROPERTY("GetNamed", GetNamed),
|
||||||
DECLARE_NAPI_PROPERTY("Set", Set),
|
DECLARE_NAPI_PROPERTY("Set", Set),
|
||||||
|
DECLARE_NAPI_PROPERTY("SetNamed", SetNamed),
|
||||||
DECLARE_NAPI_PROPERTY("Has", Has),
|
DECLARE_NAPI_PROPERTY("Has", Has),
|
||||||
|
DECLARE_NAPI_PROPERTY("HasNamed", HasNamed),
|
||||||
DECLARE_NAPI_PROPERTY("HasOwn", HasOwn),
|
DECLARE_NAPI_PROPERTY("HasOwn", HasOwn),
|
||||||
DECLARE_NAPI_PROPERTY("Delete", Delete),
|
DECLARE_NAPI_PROPERTY("Delete", Delete),
|
||||||
DECLARE_NAPI_PROPERTY("New", New),
|
DECLARE_NAPI_PROPERTY("New", New),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user