summaryrefslogtreecommitdiff
path: root/test/js-native-api/test_handle_scope
diff options
context:
space:
mode:
authorGabriel Schulhof <gabriel.schulhof@intel.com>2018-11-17 12:34:54 -0800
committerGabriel Schulhof <gabriel.schulhof@intel.com>2018-12-04 13:58:17 -0800
commit938e11882b96e19b443477571455088baaa054d8 (patch)
treeeb828a60957a2881995ba9a83f44a32a18fbff16 /test/js-native-api/test_handle_scope
parent83ee137c4565112177f22f2c735b266b22262220 (diff)
downloadandroid-node-v8-938e11882b96e19b443477571455088baaa054d8.tar.gz
android-node-v8-938e11882b96e19b443477571455088baaa054d8.tar.bz2
android-node-v8-938e11882b96e19b443477571455088baaa054d8.zip
test: partition N-API tests
Partition test/addons-napi into test/js-native-api and test/node-api to isolate the Node.js-agnostic portion of the N-API tests from the Node.js-specific portion. PR-URL: https://github.com/nodejs/node/pull/24557 Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Daniel Bevenius <daniel.bevenius@gmail.com>
Diffstat (limited to 'test/js-native-api/test_handle_scope')
-rw-r--r--test/js-native-api/test_handle_scope/binding.gyp11
-rw-r--r--test/js-native-api/test_handle_scope/test.js19
-rw-r--r--test/js-native-api/test_handle_scope/test_handle_scope.c85
3 files changed, 115 insertions, 0 deletions
diff --git a/test/js-native-api/test_handle_scope/binding.gyp b/test/js-native-api/test_handle_scope/binding.gyp
new file mode 100644
index 0000000000..842bd5af74
--- /dev/null
+++ b/test/js-native-api/test_handle_scope/binding.gyp
@@ -0,0 +1,11 @@
+{
+ "targets": [
+ {
+ "target_name": "test_handle_scope",
+ "sources": [
+ "../entry_point.c",
+ "test_handle_scope.c"
+ ]
+ }
+ ]
+}
diff --git a/test/js-native-api/test_handle_scope/test.js b/test/js-native-api/test_handle_scope/test.js
new file mode 100644
index 0000000000..53abfe178c
--- /dev/null
+++ b/test/js-native-api/test_handle_scope/test.js
@@ -0,0 +1,19 @@
+'use strict';
+const common = require('../../common');
+const assert = require('assert');
+
+// testing handle scope api calls
+const testHandleScope =
+ require(`./build/${common.buildType}/test_handle_scope`);
+
+testHandleScope.NewScope();
+
+assert.ok(testHandleScope.NewScopeEscape() instanceof Object);
+
+testHandleScope.NewScopeEscapeTwice();
+
+assert.throws(
+ () => {
+ testHandleScope.NewScopeWithException(() => { throw new RangeError(); });
+ },
+ RangeError);
diff --git a/test/js-native-api/test_handle_scope/test_handle_scope.c b/test/js-native-api/test_handle_scope/test_handle_scope.c
new file mode 100644
index 0000000000..e6029398aa
--- /dev/null
+++ b/test/js-native-api/test_handle_scope/test_handle_scope.c
@@ -0,0 +1,85 @@
+#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;
+
+ NAPI_CALL(env, napi_open_handle_scope(env, &scope));
+ NAPI_CALL(env, napi_create_object(env, &output));
+ NAPI_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;
+
+ NAPI_CALL(env, napi_open_escapable_handle_scope(env, &scope));
+ NAPI_CALL(env, napi_create_object(env, &output));
+ NAPI_CALL(env, napi_escape_handle(env, scope, output, &escapee));
+ NAPI_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;
+
+ NAPI_CALL(env, napi_open_escapable_handle_scope(env, &scope));
+ NAPI_CALL(env, napi_create_object(env, &output));
+ NAPI_CALL(env, napi_escape_handle(env, scope, output, &escapee));
+ status = napi_escape_handle(env, scope, output, &escapee);
+ NAPI_ASSERT(env, status == napi_escape_called_twice, "Escaping twice fails");
+ NAPI_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;
+
+ NAPI_CALL(env, napi_open_handle_scope(env, &scope));
+ NAPI_CALL(env, napi_create_object(env, &output));
+
+ argc = 1;
+ NAPI_CALL(env, napi_get_cb_info(
+ env, info, &argc, &exception_function, NULL, NULL));
+
+ status = napi_call_function(
+ env, output, exception_function, 0, NULL, NULL);
+ NAPI_ASSERT(env, status == napi_pending_exception,
+ "Function should have thrown.");
+
+ // Closing a handle scope should still work while an exception is pending.
+ NAPI_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_NAPI_PROPERTY("NewScope", NewScope),
+ DECLARE_NAPI_PROPERTY("NewScopeEscape", NewScopeEscape),
+ DECLARE_NAPI_PROPERTY("NewScopeEscapeTwice", NewScopeEscapeTwice),
+ DECLARE_NAPI_PROPERTY("NewScopeWithException", NewScopeWithException),
+ };
+
+ NAPI_CALL(env, napi_define_properties(
+ env, exports, sizeof(properties) / sizeof(*properties), properties));
+
+ return exports;
+}
+EXTERN_C_END