mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 00:54:02 -05:00
fix: Deno.emit crashes with BorrowMutError (#12627)
Warn on await_holding_refcell_ref clippy rule to avoid this in the future. Fixes #12453
This commit is contained in:
parent
95b2955712
commit
7c2abb9d57
7 changed files with 47 additions and 7 deletions
|
@ -88,9 +88,15 @@ async fn op_emit(
|
||||||
) -> Result<EmitResult, AnyError> {
|
) -> Result<EmitResult, AnyError> {
|
||||||
deno_runtime::ops::check_unstable2(&state, "Deno.emit");
|
deno_runtime::ops::check_unstable2(&state, "Deno.emit");
|
||||||
let root_specifier = args.root_specifier;
|
let root_specifier = args.root_specifier;
|
||||||
let state = state.borrow();
|
let ps = {
|
||||||
let ps = state.borrow::<ProcState>();
|
let state = state.borrow();
|
||||||
let mut runtime_permissions = { state.borrow::<Permissions>().clone() };
|
state.borrow::<ProcState>().clone()
|
||||||
|
};
|
||||||
|
let mut runtime_permissions = {
|
||||||
|
let state = state.borrow();
|
||||||
|
state.borrow::<Permissions>().clone()
|
||||||
|
};
|
||||||
|
|
||||||
let mut cache: Box<dyn cache::CacherLoader> =
|
let mut cache: Box<dyn cache::CacherLoader> =
|
||||||
if let Some(sources) = &args.sources {
|
if let Some(sources) = &args.sources {
|
||||||
Box::new(cache::MemoryCacher::new(sources.clone()))
|
Box::new(cache::MemoryCacher::new(sources.clone()))
|
||||||
|
|
|
@ -2148,3 +2148,21 @@ itest!(eval_context_throw_dom_exception {
|
||||||
args: "run eval_context_throw_dom_exception.js",
|
args: "run eval_context_throw_dom_exception.js",
|
||||||
output: "eval_context_throw_dom_exception.js.out",
|
output: "eval_context_throw_dom_exception.js.out",
|
||||||
});
|
});
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn issue12453() {
|
||||||
|
let _g = util::http_server();
|
||||||
|
let deno_dir = util::new_deno_dir();
|
||||||
|
let mut deno_cmd = util::deno_cmd_with_deno_dir(deno_dir.path());
|
||||||
|
let status = deno_cmd
|
||||||
|
.current_dir(util::testdata_path())
|
||||||
|
.arg("run")
|
||||||
|
.arg("--unstable")
|
||||||
|
.arg("--allow-net")
|
||||||
|
.arg("issue12453.js")
|
||||||
|
.spawn()
|
||||||
|
.unwrap()
|
||||||
|
.wait()
|
||||||
|
.unwrap();
|
||||||
|
assert!(status.success());
|
||||||
|
}
|
||||||
|
|
4
cli/tests/testdata/issue12453.js
vendored
Normal file
4
cli/tests/testdata/issue12453.js
vendored
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
const i = setInterval(() => {
|
||||||
|
Deno.emit("http://localhost:4545/subdir/mt_text_typescript.t1.ts");
|
||||||
|
clearInterval(i);
|
||||||
|
}, 1);
|
|
@ -2317,11 +2317,14 @@ assertEquals(1, notify_return_value);
|
||||||
_: (),
|
_: (),
|
||||||
_: (),
|
_: (),
|
||||||
) -> Result<(), AnyError> {
|
) -> Result<(), AnyError> {
|
||||||
let op_state = op_state.borrow();
|
let n = {
|
||||||
let inner_state = op_state.borrow::<InnerState>();
|
let op_state = op_state.borrow();
|
||||||
|
let inner_state = op_state.borrow::<InnerState>();
|
||||||
|
inner_state.0
|
||||||
|
};
|
||||||
// Future must be Poll::Pending on first call
|
// Future must be Poll::Pending on first call
|
||||||
tokio::time::sleep(std::time::Duration::from_millis(1)).await;
|
tokio::time::sleep(std::time::Duration::from_millis(1)).await;
|
||||||
if inner_state.0 != 42 {
|
if n != 42 {
|
||||||
unreachable!();
|
unreachable!();
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -48,6 +48,7 @@ impl MessagePort {
|
||||||
&self,
|
&self,
|
||||||
state: Rc<RefCell<OpState>>,
|
state: Rc<RefCell<OpState>>,
|
||||||
) -> Result<Option<JsMessageData>, AnyError> {
|
) -> Result<Option<JsMessageData>, AnyError> {
|
||||||
|
#![allow(clippy::await_holding_refcell_ref)] // TODO(ry) remove!
|
||||||
let mut rx = self
|
let mut rx = self
|
||||||
.rx
|
.rx
|
||||||
.try_borrow_mut()
|
.try_borrow_mut()
|
||||||
|
|
|
@ -198,6 +198,7 @@ impl WebWorkerHandle {
|
||||||
pub async fn get_control_event(
|
pub async fn get_control_event(
|
||||||
&self,
|
&self,
|
||||||
) -> Result<Option<WorkerControlEvent>, AnyError> {
|
) -> Result<Option<WorkerControlEvent>, AnyError> {
|
||||||
|
#![allow(clippy::await_holding_refcell_ref)] // TODO(ry) remove!
|
||||||
let mut receiver = self.receiver.borrow_mut();
|
let mut receiver = self.receiver.borrow_mut();
|
||||||
Ok(receiver.next().await)
|
Ok(receiver.next().await)
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,7 +109,14 @@ async function clippy() {
|
||||||
}
|
}
|
||||||
|
|
||||||
const p = Deno.run({
|
const p = Deno.run({
|
||||||
cmd: [...cmd, "--", "-D", "clippy::all"],
|
cmd: [
|
||||||
|
...cmd,
|
||||||
|
"--",
|
||||||
|
"-D",
|
||||||
|
"clippy::all",
|
||||||
|
"-D",
|
||||||
|
"clippy::await_holding_refcell_ref",
|
||||||
|
],
|
||||||
});
|
});
|
||||||
const { success } = await p.status();
|
const { success } = await p.status();
|
||||||
if (!success) {
|
if (!success) {
|
||||||
|
|
Loading…
Reference in a new issue