From bf18613a2e94675eff31d58b985eb5037f151ea9 Mon Sep 17 00:00:00 2001 From: Yihau Chen Date: Thu, 22 Dec 2022 16:50:19 +0800 Subject: [PATCH] fix: client-test timeout (#29364) * fix: retry counter doesn't count * set timeout for wait_for --- client-test/tests/client.rs | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/client-test/tests/client.rs b/client-test/tests/client.rs index 6e3dded7e1f2d9..75d7639c004659 100644 --- a/client-test/tests/client.rs +++ b/client-test/tests/client.rs @@ -528,8 +528,13 @@ fn test_slot_subscription() { async fn test_slot_subscription_async() { let sync_service = Arc::new(AtomicU64::new(0)); let sync_client = Arc::clone(&sync_service); + fn wait_until(atomic: &Arc, value: u64) { + let now = Instant::now(); while atomic.load(Ordering::Relaxed) != value { + if now.elapsed() > Duration::from_secs(5) { + panic!("wait for too long") + } sleep(Duration::from_millis(1)) } } @@ -605,12 +610,16 @@ async fn test_slot_subscription_async() { unsubscribe().await; } -fn check_server_is_ready_or_panic(socket_addr: &SocketAddr, retry: u8, sleep_duration: Duration) { +fn check_server_is_ready_or_panic( + socket_addr: &SocketAddr, + mut retry: u8, + sleep_duration: Duration, +) { loop { if retry == 0 { break; } else { - retry.checked_sub(1).unwrap(); + retry = retry.checked_sub(1).unwrap(); } if connect(format!("ws://{socket_addr}")).is_ok() {