diff options
author | Matt Mastracci <matthew@mastracci.com> | 2024-02-12 13:46:50 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-02-12 13:46:50 -0700 |
commit | f60720090c7bd8cdf91d7aebd0c42e01c86b3b83 (patch) | |
tree | 9becb7ff7e40d37769601fa049beccd101d58a98 /tests/napi/src/error.rs | |
parent | bd1358efab8ba7339a8e70034315fa7da840292e (diff) |
chore: move test_ffi and test_nap to tests/ [WIP] (#22394)
Moving some additional NAPI and. FFI tests out of the tree root.
Diffstat (limited to 'tests/napi/src/error.rs')
-rw-r--r-- | tests/napi/src/error.rs | 288 |
1 files changed, 288 insertions, 0 deletions
diff --git a/tests/napi/src/error.rs b/tests/napi/src/error.rs new file mode 100644 index 000000000..e0d79c836 --- /dev/null +++ b/tests/napi/src/error.rs @@ -0,0 +1,288 @@ +// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. + +use crate::assert_napi_ok; +use crate::cstr; +use crate::napi_get_callback_info; +use crate::napi_new_property; +use napi_sys::*; +use std::ptr; + +extern "C" fn check_error( + env: napi_env, + info: napi_callback_info, +) -> napi_value { + let (args, argc, _) = napi_get_callback_info!(env, info, 1); + assert_eq!(argc, 1); + let mut r = false; + assert_napi_ok!(napi_is_error(env, args[0], &mut r)); + let mut result: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_get_boolean(env, r, &mut result)); + result +} + +extern "C" fn create_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("error"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_error( + env, + ptr::null_mut(), + message, + &mut result + )); + result +} + +extern "C" fn create_range_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("range error"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_range_error( + env, + ptr::null_mut(), + message, + &mut result + )); + result +} + +extern "C" fn create_type_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("type error"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_type_error( + env, + ptr::null_mut(), + message, + &mut result + )); + result +} + +extern "C" fn create_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + let mut code: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("Error [error]"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("ERR_TEST_CODE"), + usize::MAX, + &mut code + )); + assert_napi_ok!(napi_create_error(env, code, message, &mut result)); + result +} + +extern "C" fn create_range_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + let mut code: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("RangeError [range error]"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("ERR_TEST_CODE"), + usize::MAX, + &mut code + )); + assert_napi_ok!(napi_create_range_error(env, code, message, &mut result)); + result +} + +extern "C" fn create_type_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut result: napi_value = ptr::null_mut(); + let mut message: napi_value = ptr::null_mut(); + let mut code: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("TypeError [type error]"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("ERR_TEST_CODE"), + usize::MAX, + &mut code + )); + assert_napi_ok!(napi_create_type_error(env, code, message, &mut result)); + result +} + +extern "C" fn throw_existing_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + let mut message: napi_value = ptr::null_mut(); + let mut error: napi_value = ptr::null_mut(); + assert_napi_ok!(napi_create_string_utf8( + env, + cstr!("existing error"), + usize::MAX, + &mut message + )); + assert_napi_ok!(napi_create_error( + env, + std::ptr::null_mut(), + message, + &mut error + )); + assert_napi_ok!(napi_throw(env, error)); + std::ptr::null_mut() +} + +extern "C" fn throw_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_error(env, std::ptr::null_mut(), cstr!("error"),)); + std::ptr::null_mut() +} + +extern "C" fn throw_range_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_range_error( + env, + std::ptr::null_mut(), + cstr!("range error"), + )); + std::ptr::null_mut() +} + +extern "C" fn throw_type_error( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_type_error( + env, + std::ptr::null_mut(), + cstr!("type error"), + )); + std::ptr::null_mut() +} + +extern "C" fn throw_arbitrary( + env: napi_env, + info: napi_callback_info, +) -> napi_value { + let (args, argc, _) = napi_get_callback_info!(env, info, 1); + assert_eq!(argc, 1); + assert_napi_ok!(napi_throw(env, args[0])); + std::ptr::null_mut() +} + +extern "C" fn throw_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_error( + env, + cstr!("ERR_TEST_CODE"), + cstr!("Error [error]"), + )); + std::ptr::null_mut() +} + +extern "C" fn throw_range_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_range_error( + env, + cstr!("ERR_TEST_CODE"), + cstr!("RangeError [range error]"), + )); + std::ptr::null_mut() +} + +extern "C" fn throw_type_error_code( + env: napi_env, + _info: napi_callback_info, +) -> napi_value { + assert_napi_ok!(napi_throw_type_error( + env, + cstr!("ERR_TEST_CODE"), + cstr!("TypeError [type error]"), + )); + std::ptr::null_mut() +} + +pub fn init(env: napi_env, exports: napi_value) { + let properties = &[ + napi_new_property!(env, "checkError", check_error), + napi_new_property!(env, "throwExistingError", throw_existing_error), + napi_new_property!(env, "throwError", throw_error), + napi_new_property!(env, "throwRangeError", throw_range_error), + napi_new_property!(env, "throwTypeError", throw_type_error), + // NOTE(bartlomieju): currently experimental api + // napi_new_property!(env, "throwSyntaxError", throw_syntax_error), + napi_new_property!(env, "throwErrorCode", throw_error_code), + napi_new_property!(env, "throwRangeErrorCode", throw_range_error_code), + napi_new_property!(env, "throwTypeErrorCode", throw_type_error_code), + // NOTE(bartlomieju): currently experimental api + // napi_new_property!(env, "throwSyntaxErrorCode", throw_syntax_error_code), + napi_new_property!(env, "throwArbitrary", throw_arbitrary), + napi_new_property!(env, "createError", create_error), + napi_new_property!(env, "createRangeError", create_range_error), + napi_new_property!(env, "createTypeError", create_type_error), + // NOTE(bartlomieju): currently experimental api + // napi_new_property!(env, "createSyntaxError", create_syntax_error), + napi_new_property!(env, "createErrorCode", create_error_code), + napi_new_property!(env, "createRangeErrorCode", create_range_error_code), + napi_new_property!(env, "createTypeErrorCode", create_type_error_code), + // NOTE(bartlomieju): currently experimental api + // napi_new_property!(env, "createSyntaxErrorCode", create_syntax_error_code), + ]; + + assert_napi_ok!(napi_define_properties( + env, + exports, + properties.len(), + properties.as_ptr() + )); +} |