node/test/js-native-api/test_handle_scope/test_handle_scope.c
Gabriel Schulhof 4b7f23f868 test: rename n-api to node-api
This renames the macros used in the tests from `NAPI_*` to
`NODE_API_*`.

PR-URL: https://github.com/nodejs/node/pull/37217
Reviewed-By: Michael Dawson <midawson@redhat.com>
Reviewed-By: Beth Griggs <bgriggs@redhat.com>
Reviewed-By: Rich Trott <rtrott@gmail.com>
2021-02-06 05:03:38 -08:00

86 lines
2.9 KiB
C

#include <js_native_api.h>
#include "../common.h"
#include <string.h>
// these tests validate the handle scope functions in the normal
// flow. Forcing gc behavior to fully validate they are doing
// the right right thing would be quite hard so we keep it
// simple for now.
static napi_value NewScope(napi_env env, napi_callback_info info) {
napi_handle_scope scope;
napi_value output = NULL;
NODE_API_CALL(env, napi_open_handle_scope(env, &scope));
NODE_API_CALL(env, napi_create_object(env, &output));
NODE_API_CALL(env, napi_close_handle_scope(env, scope));
return NULL;
}
static napi_value NewScopeEscape(napi_env env, napi_callback_info info) {
napi_escapable_handle_scope scope;
napi_value output = NULL;
napi_value escapee = NULL;
NODE_API_CALL(env, napi_open_escapable_handle_scope(env, &scope));
NODE_API_CALL(env, napi_create_object(env, &output));
NODE_API_CALL(env, napi_escape_handle(env, scope, output, &escapee));
NODE_API_CALL(env, napi_close_escapable_handle_scope(env, scope));
return escapee;
}
static napi_value NewScopeEscapeTwice(napi_env env, napi_callback_info info) {
napi_escapable_handle_scope scope;
napi_value output = NULL;
napi_value escapee = NULL;
napi_status status;
NODE_API_CALL(env, napi_open_escapable_handle_scope(env, &scope));
NODE_API_CALL(env, napi_create_object(env, &output));
NODE_API_CALL(env, napi_escape_handle(env, scope, output, &escapee));
status = napi_escape_handle(env, scope, output, &escapee);
NODE_API_ASSERT(env, status == napi_escape_called_twice, "Escaping twice fails");
NODE_API_CALL(env, napi_close_escapable_handle_scope(env, scope));
return NULL;
}
static napi_value NewScopeWithException(napi_env env, napi_callback_info info) {
napi_handle_scope scope;
size_t argc;
napi_value exception_function;
napi_status status;
napi_value output = NULL;
NODE_API_CALL(env, napi_open_handle_scope(env, &scope));
NODE_API_CALL(env, napi_create_object(env, &output));
argc = 1;
NODE_API_CALL(env, napi_get_cb_info(
env, info, &argc, &exception_function, NULL, NULL));
status = napi_call_function(
env, output, exception_function, 0, NULL, NULL);
NODE_API_ASSERT(env, status == napi_pending_exception,
"Function should have thrown.");
// Closing a handle scope should still work while an exception is pending.
NODE_API_CALL(env, napi_close_handle_scope(env, scope));
return NULL;
}
EXTERN_C_START
napi_value Init(napi_env env, napi_value exports) {
napi_property_descriptor properties[] = {
DECLARE_NODE_API_PROPERTY("NewScope", NewScope),
DECLARE_NODE_API_PROPERTY("NewScopeEscape", NewScopeEscape),
DECLARE_NODE_API_PROPERTY("NewScopeEscapeTwice", NewScopeEscapeTwice),
DECLARE_NODE_API_PROPERTY("NewScopeWithException", NewScopeWithException),
};
NODE_API_CALL(env, napi_define_properties(
env, exports, sizeof(properties) / sizeof(*properties), properties));
return exports;
}
EXTERN_C_END