Skip to content

Commit

Permalink
chore: Use backon to replace backoff
Browse files Browse the repository at this point in the history
  • Loading branch information
Xuanwo authored Oct 8, 2024
1 parent f71185c commit d906714
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 134 deletions.
130 changes: 10 additions & 120 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ tracing = { version = "0.1.30", optional = true }

[dev-dependencies]
async-std = { version = "1.9.0", features = ["attributes"] }
backoff = "0.1.5"
backon = { version = "1.2", default-features = false, features = ["std-blocking-sleep"] }
chrono = "0.4.0"
clap = "2.18.0"
env_logger = "0.9.0"
Expand Down
20 changes: 7 additions & 13 deletions tests/test_admin.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
use std::time::Duration;

use backoff::{ExponentialBackoff, Operation};
use backon::{BlockingRetryable, ExponentialBuilder};

use rdkafka::admin::{
AdminClient, AdminOptions, AlterConfig, ConfigEntry, ConfigSource, GroupResult, NewPartitions,
Expand Down Expand Up @@ -75,10 +75,6 @@ fn fetch_metadata(topic: &str) -> Metadata {
create_config().create().expect("consumer creation failed");
let timeout = Some(Duration::from_secs(1));

let mut backoff = ExponentialBackoff {
max_elapsed_time: Some(Duration::from_secs(5)),
..Default::default()
};
(|| {
let metadata = consumer
.fetch_metadata(Some(topic), timeout)
Expand All @@ -90,9 +86,10 @@ fn fetch_metadata(topic: &str) -> Metadata {
if topic.partitions().is_empty() {
Err("metadata fetch returned a topic with no partitions".to_string())?
}
Ok(metadata)
Ok::<_, String>(metadata)
})
.retry(&mut backoff)
.retry(ExponentialBuilder::default().with_max_delay(Duration::from_secs(5)))
.call()
.unwrap()
}

Expand All @@ -101,10 +98,6 @@ fn verify_delete(topic: &str) {
create_config().create().expect("consumer creation failed");
let timeout = Some(Duration::from_secs(1));

let mut backoff = ExponentialBackoff {
max_elapsed_time: Some(Duration::from_secs(5)),
..Default::default()
};
(|| {
// Asking about the topic specifically will recreate it (under the
// default Kafka configuration, at least) so we have to ask for the list
Expand All @@ -115,9 +108,10 @@ fn verify_delete(topic: &str) {
if metadata.topics().iter().any(|t| t.name() == topic) {
Err(format!("topic {} still exists", topic))?
}
Ok(())
Ok::<(), String>(())
})
.retry(&mut backoff)
.retry(ExponentialBuilder::default().with_max_delay(Duration::from_secs(5)))
.call()
.unwrap()
}

Expand Down

0 comments on commit d906714

Please sign in to comment.