summaryrefslogtreecommitdiff
path: root/test/js-native-api
diff options
context:
space:
mode:
authorlegendecas <legendecas@gmail.com>2021-05-24 23:39:36 +0800
committerMichaƫl Zasso <targos@protonmail.com>2021-06-11 07:24:54 +0200
commit74f5e30d692e9559ee2d7521c9feddf55f941cc7 (patch)
tree590938b5550c7780ba115202079897780ec18038 /test/js-native-api
parent8115e6ee6d71beb683a447aeada5b924fb90c5d4 (diff)
downloadnode-new-74f5e30d692e9559ee2d7521c9feddf55f941cc7.tar.gz
node-api: rtn pending excep on napi_new_instance
When there are any JavaScript exceptions pending, `napi_pending_exception` should be returned. PR-URL: https://github.com/nodejs/node/pull/38798 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Michael Dawson <midawson@redhat.com>
Diffstat (limited to 'test/js-native-api')
-rw-r--r--test/js-native-api/test_exception/test.js47
-rw-r--r--test/js-native-api/test_exception/test_exception.c31
2 files changed, 78 insertions, 0 deletions
diff --git a/test/js-native-api/test_exception/test.js b/test/js-native-api/test_exception/test.js
index ff11b70219..38e8fd1d6b 100644
--- a/test/js-native-api/test_exception/test.js
+++ b/test/js-native-api/test_exception/test.js
@@ -48,6 +48,34 @@ const test_exception = (function() {
` thrown, but ${returnedError} was passed`);
}
+
+{
+ const throwTheError = class { constructor() { throw theError; } };
+
+ // Test that the native side successfully captures the exception
+ let returnedError = test_exception.constructReturnException(throwTheError);
+ assert.strictEqual(returnedError, theError);
+
+ // Test that the native side passes the exception through
+ assert.throws(
+ () => { test_exception.constructAllowException(throwTheError); },
+ (err) => err === theError
+ );
+
+ // Test that the exception thrown above was marked as pending
+ // before it was handled on the JS side
+ const exception_pending = test_exception.wasPending();
+ assert.strictEqual(exception_pending, true,
+ 'Exception not pending as expected,' +
+ ` .wasPending() returned ${exception_pending}`);
+
+ // Test that the native side does not capture a non-existing exception
+ returnedError = test_exception.constructReturnException(common.mustCall());
+ assert.strictEqual(returnedError, undefined,
+ 'Returned error should be undefined when no exception is' +
+ ` thrown, but ${returnedError} was passed`);
+}
+
{
// Test that no exception appears that was not thrown by us
let caughtError;
@@ -66,3 +94,22 @@ const test_exception = (function() {
'Exception state did not remain clear as expected,' +
` .wasPending() returned ${exception_pending}`);
}
+
+{
+ // Test that no exception appears that was not thrown by us
+ let caughtError;
+ try {
+ test_exception.constructAllowException(common.mustCall());
+ } catch (anError) {
+ caughtError = anError;
+ }
+ assert.strictEqual(caughtError, undefined,
+ 'No exception originated on the native side, but' +
+ ` ${caughtError} was passed`);
+
+ // Test that the exception state remains clear when no exception is thrown
+ const exception_pending = test_exception.wasPending();
+ assert.strictEqual(exception_pending, false,
+ 'Exception state did not remain clear as expected,' +
+ ` .wasPending() returned ${exception_pending}`);
+}
diff --git a/test/js-native-api/test_exception/test_exception.c b/test/js-native-api/test_exception/test_exception.c
index 791f5219fc..844f4475ac 100644
--- a/test/js-native-api/test_exception/test_exception.c
+++ b/test/js-native-api/test_exception/test_exception.c
@@ -22,6 +22,22 @@ static napi_value returnException(napi_env env, napi_callback_info info) {
return NULL;
}
+static napi_value constructReturnException(napi_env env, napi_callback_info info) {
+ size_t argc = 1;
+ napi_value args[1];
+ NODE_API_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
+
+ napi_value result;
+ napi_status status = napi_new_instance(env, args[0], 0, 0, &result);
+ if (status == napi_pending_exception) {
+ napi_value ex;
+ NODE_API_CALL(env, napi_get_and_clear_last_exception(env, &ex));
+ return ex;
+ }
+
+ return NULL;
+}
+
static napi_value allowException(napi_env env, napi_callback_info info) {
size_t argc = 1;
napi_value args[1];
@@ -38,6 +54,19 @@ static napi_value allowException(napi_env env, napi_callback_info info) {
return NULL;
}
+static napi_value constructAllowException(napi_env env, napi_callback_info info) {
+ size_t argc = 1;
+ napi_value args[1];
+ NODE_API_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
+
+ napi_value result;
+ napi_new_instance(env, args[0], 0, 0, &result);
+ // Ignore status and check napi_is_exception_pending() instead.
+
+ NODE_API_CALL(env, napi_is_exception_pending(env, &exceptionWasPending));
+ return NULL;
+}
+
static napi_value wasPending(napi_env env, napi_callback_info info) {
napi_value result;
NODE_API_CALL(env, napi_get_boolean(env, exceptionWasPending, &result));
@@ -64,6 +93,8 @@ napi_value Init(napi_env env, napi_value exports) {
napi_property_descriptor descriptors[] = {
DECLARE_NODE_API_PROPERTY("returnException", returnException),
DECLARE_NODE_API_PROPERTY("allowException", allowException),
+ DECLARE_NODE_API_PROPERTY("constructReturnException", constructReturnException),
+ DECLARE_NODE_API_PROPERTY("constructAllowException", constructAllowException),
DECLARE_NODE_API_PROPERTY("wasPending", wasPending),
DECLARE_NODE_API_PROPERTY("createExternal", createExternal),
};