From 52459faf0b35ed157bb640d24c6107e1ff00aded Mon Sep 17 00:00:00 2001 From: Aaron O'Mullan Date: Sat, 19 Mar 2022 15:59:44 +0100 Subject: fix(ops): throw TypeError on op return failure (#14033) Fixes #14028 --- core/runtime.rs | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) (limited to 'core') diff --git a/core/runtime.rs b/core/runtime.rs index 6ca586997..5b6ce3998 100644 --- a/core/runtime.rs +++ b/core/runtime.rs @@ -2854,4 +2854,24 @@ assertEquals(1, notify_return_value); assert_eq!(2, PROMISE_REJECT.load(Ordering::Relaxed)); assert_eq!(2, UNCAUGHT_EXCEPTION.load(Ordering::Relaxed)); } + + #[test] + fn test_op_return_serde_v8_error() { + #[op] + fn op_err() -> Result, anyhow::Error> { + Ok([(1, 2), (3, 4)].into_iter().collect()) // Maps can't have non-string keys in serde_v8 + } + + let ext = Extension::builder().ops(vec![op_err::decl()]).build(); + let mut runtime = JsRuntime::new(RuntimeOptions { + extensions: vec![ext], + ..Default::default() + }); + assert!(runtime + .execute_script( + "test_op_return_serde_v8_error.js", + "Deno.core.opSync('op_err')" + ) + .is_err()); + } } -- cgit v1.2.3