summaryrefslogtreecommitdiff
path: root/tests/napi/src/object.rs
diff options
context:
space:
mode:
authorhaturau <135221985+haturatu@users.noreply.github.com>2024-11-20 01:20:47 +0900
committerGitHub <noreply@github.com>2024-11-20 01:20:47 +0900
commit85719a67e59c7aa45bead26e4942d7df8b1b42d4 (patch)
treeface0aecaac53e93ce2f23b53c48859bcf1a36ec /tests/napi/src/object.rs
parent67697bc2e4a62a9670699fd18ad0dd8efc5bd955 (diff)
parent186b52731c6bb326c4d32905c5e732d082e83465 (diff)
Merge branch 'denoland:main' into main
Diffstat (limited to 'tests/napi/src/object.rs')
-rw-r--r--tests/napi/src/object.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/napi/src/object.rs b/tests/napi/src/object.rs
index aa34133dc..9876f4dae 100644
--- a/tests/napi/src/object.rs
+++ b/tests/napi/src/object.rs
@@ -40,10 +40,39 @@ extern "C" fn test_object_get(
obj
}
+extern "C" fn test_object_attr_property(
+ env: napi_env,
+ info: napi_callback_info,
+) -> napi_value {
+ let (args, argc, _) = napi_get_callback_info!(env, info, 1);
+ assert_eq!(argc, 1);
+
+ let obj = args[0];
+ let mut property = napi_new_property!(env, "self", test_object_new);
+ property.attributes = PropertyAttributes::enumerable;
+ property.method = None;
+ property.value = obj;
+ let mut method_property = napi_new_property!(env, "method", test_object_new);
+ method_property.attributes = PropertyAttributes::enumerable;
+ let properties = &[property, method_property];
+ assert_napi_ok!(napi_define_properties(
+ env,
+ obj,
+ properties.len(),
+ properties.as_ptr()
+ ));
+ obj
+}
+
pub fn init(env: napi_env, exports: napi_value) {
let properties = &[
napi_new_property!(env, "test_object_new", test_object_new),
napi_new_property!(env, "test_object_get", test_object_get),
+ napi_new_property!(
+ env,
+ "test_object_attr_property",
+ test_object_attr_property
+ ),
];
assert_napi_ok!(napi_define_properties(