From 48c09c2e4a237a32b40e69c4d2090f855f7089d5 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Wed, 28 Aug 2024 13:08:45 +0800 Subject: [PATCH 1/2] Integration Test: kill_gracefully on RandomlyKill --- test/src/specs/fault_injection/randomly_kill.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/src/specs/fault_injection/randomly_kill.rs b/test/src/specs/fault_injection/randomly_kill.rs index 358c81bd9d..92c6101805 100644 --- a/test/src/specs/fault_injection/randomly_kill.rs +++ b/test/src/specs/fault_injection/randomly_kill.rs @@ -24,7 +24,7 @@ impl Spec for RandomlyKill { node.mine(n); } info!("Stop the node"); - node.stop(); + node.stop_gracefully(); info!("Start the node"); node.start(); } From 3a40e37f9622181877b67ed524dbc4df399eeac7 Mon Sep 17 00:00:00 2001 From: Eval EXEC Date: Thu, 29 Aug 2024 11:29:48 +0800 Subject: [PATCH 2/2] Do not kill gracefully on windows Signed-off-by: Eval EXEC --- test/src/node.rs | 28 ++++++++-------------------- 1 file changed, 8 insertions(+), 20 deletions(-) diff --git a/test/src/node.rs b/test/src/node.rs index c26c233983..e7f906a289 100644 --- a/test/src/node.rs +++ b/test/src/node.rs @@ -32,9 +32,6 @@ use std::sync::{Arc, RwLock}; use std::thread::sleep; use std::time::{Duration, Instant}; -#[cfg(target_os = "windows")] -use windows_sys::Win32::System::Console::{GenerateConsoleCtrlEvent, CTRL_C_EVENT}; - pub(crate) struct ProcessGuard { pub name: String, pub child: Child, @@ -845,28 +842,19 @@ impl Node { info!("accessed db done"); } + #[allow(unused_mut)] pub fn stop_gracefully(&mut self) { let guard = self.take_guard(); if let Some(mut guard) = guard { if !guard.killed { // on nix: send SIGINT to the child - // on windows: use taskkill to kill the child gracefully - Self::kill_gracefully(guard.child.id()); - let _ = guard.child.wait(); - guard.killed = true; - } - } - } - - #[cfg(target_os = "windows")] - fn kill_gracefully(pid: u32) { - unsafe { - let ret = GenerateConsoleCtrlEvent(CTRL_C_EVENT, pid); - if ret == 0 { - let err = std::io::Error::last_os_error(); - error!("GenerateConsoleCtrlEvent failed: {}", err); - } else { - info!("GenerateConsoleCtrlEvent success"); + // on windows: don't kill gracefully..... fix later + #[cfg(not(target_os = "windows"))] + { + Self::kill_gracefully(guard.child.id()); + let _ = guard.child.wait(); + guard.killed = true; + } } } }