Skip to content

Commit 66b139d

Browse files
node-api: test promise null-checks
Also adds a missing check for deferred being NULL during resolution.
1 parent 5273947 commit 66b139d

File tree

6 files changed

+118
-0
lines changed

6 files changed

+118
-0
lines changed

src/js_native_api_v8.cc

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -164,6 +164,7 @@ inline napi_status ConcludeDeferred(napi_env env,
164164
napi_value result,
165165
bool is_resolved) {
166166
NAPI_PREAMBLE(env);
167+
CHECK_ARG(env, deferred);
167168
CHECK_ARG(env, result);
168169

169170
v8::Local<v8::Context> context = env->context();

test/js-native-api/test_promise/binding.gyp

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,9 @@
33
{
44
"target_name": "test_promise",
55
"sources": [
6+
"../common.c",
67
"../entry_point.c",
8+
"test_null.c",
79
"test_promise.c"
810
]
911
}
Lines changed: 83 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,83 @@
1+
#include <js_native_api.h>
2+
3+
#include "../common.h"
4+
#include "test_null.h"
5+
6+
static napi_value CreatePromise(napi_env env, napi_callback_info info) {
7+
napi_value return_value, promise;
8+
napi_deferred deferred;
9+
10+
NODE_API_CALL(env, napi_create_object(env, &return_value));
11+
12+
add_returned_status(env,
13+
"envIsNull",
14+
return_value,
15+
"Invalid argument",
16+
napi_invalid_arg,
17+
napi_create_promise(NULL, &deferred, &promise));
18+
19+
napi_create_promise(env, NULL, &promise);
20+
add_last_status(env, "deferredIsNull", return_value);
21+
22+
napi_create_promise(env, &deferred, NULL);
23+
add_last_status(env, "promiseIsNull", return_value);
24+
25+
return return_value;
26+
}
27+
28+
static napi_value test_resolution_api(napi_env env,
29+
napi_callback_info info,
30+
napi_status (*api)(napi_env,
31+
napi_deferred,
32+
napi_value)) {
33+
napi_value return_value, promise, undefined;
34+
napi_deferred deferred;
35+
36+
NODE_API_CALL(env, napi_create_object(env, &return_value));
37+
NODE_API_CALL(env, napi_create_promise(env, &deferred, &promise));
38+
NODE_API_CALL(env, napi_get_undefined(env, &undefined));
39+
40+
add_returned_status(env,
41+
"envIsNull",
42+
return_value,
43+
"Invalid argument",
44+
napi_invalid_arg,
45+
api(NULL, deferred, undefined));
46+
47+
api(env, NULL, undefined);
48+
add_last_status(env, "deferredIsNull", return_value);
49+
50+
api(env, deferred, NULL);
51+
add_last_status(env, "valueIsNull", return_value);
52+
53+
return return_value;
54+
}
55+
56+
static napi_value ResolveDeferred(napi_env env, napi_callback_info info) {
57+
return test_resolution_api(env, info, napi_resolve_deferred);
58+
}
59+
60+
static napi_value RejectDeferred(napi_env env, napi_callback_info info) {
61+
return test_resolution_api(env, info, napi_reject_deferred);
62+
}
63+
64+
void init_test_null(napi_env env, napi_value exports) {
65+
napi_value test_null;
66+
67+
const napi_property_descriptor test_null_props[] = {
68+
DECLARE_NODE_API_PROPERTY("createPromise", CreatePromise),
69+
DECLARE_NODE_API_PROPERTY("resolveDeferred", ResolveDeferred),
70+
DECLARE_NODE_API_PROPERTY("rejectDeferred", RejectDeferred),
71+
};
72+
73+
NODE_API_CALL_RETURN_VOID(env, napi_create_object(env, &test_null));
74+
NODE_API_CALL_RETURN_VOID(
75+
env,
76+
napi_define_properties(env,
77+
test_null,
78+
sizeof(test_null_props) / sizeof(*test_null_props),
79+
test_null_props));
80+
81+
NODE_API_CALL_RETURN_VOID(
82+
env, napi_set_named_property(env, exports, "testNull", test_null));
83+
}
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#ifndef TEST_JS_NATIVE_API_TEST_OBJECT_TEST_NULL_H_
2+
#define TEST_JS_NATIVE_API_TEST_OBJECT_TEST_NULL_H_
3+
4+
#include <js_native_api.h>
5+
6+
void init_test_null(napi_env env, napi_value exports);
7+
8+
#endif // TEST_JS_NATIVE_API_TEST_OBJECT_TEST_NULL_H_
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
'use strict';
2+
const common = require('../../common');
3+
const assert = require('assert');
4+
5+
// Test passing NULL to object-related N-APIs.
6+
const { testNull } = require(`./build/${common.buildType}/test_promise`);
7+
8+
const expectedForCreatePromise = {
9+
envIsNull: 'Invalid argument',
10+
deferredIsNull: 'Invalid argument',
11+
promiseIsNull: 'Invalid argument',
12+
};
13+
assert.deepStrictEqual(testNull.createPromise(), expectedForCreatePromise);
14+
15+
const expectedForResolution = {
16+
envIsNull: 'Invalid argument',
17+
deferredIsNull: 'Invalid argument',
18+
valueIsNull: 'Invalid argument',
19+
};
20+
assert.deepStrictEqual(testNull.resolveDeferred(), expectedForResolution);
21+
assert.deepStrictEqual(testNull.rejectDeferred(), expectedForResolution);

test/js-native-api/test_promise/test_promise.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
#include <js_native_api.h>
22
#include "../common.h"
3+
#include "test_null.h"
34

45
napi_deferred deferred = NULL;
56

@@ -58,6 +59,8 @@ napi_value Init(napi_env env, napi_value exports) {
5859
NODE_API_CALL(env, napi_define_properties(
5960
env, exports, sizeof(descriptors) / sizeof(*descriptors), descriptors));
6061

62+
init_test_null(env, exports);
63+
6164
return exports;
6265
}
6366
EXTERN_C_END

0 commit comments

Comments
 (0)