Add --maximum-resolution-timeout (#1862)

* Add --maximum-resolution-timeout

Fixed #1823

* Display default value for `--maximum-resolution-timeout` in help
This commit is contained in:
Jiahao XU 2024-08-04 12:13:18 +10:00 committed by GitHub
parent de55e465f5
commit 52f2db4f57
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 76 additions and 48 deletions

View file

@ -187,6 +187,15 @@ pub struct Args {
)]
pub(crate) no_discover_github_token: bool,
/// Maximum time each resolution (one for each possible target and each strategy), in seconds.
#[clap(
help_heading = "Overrides",
long,
env = "BINSTALL_MAXIMUM_RESOLUTION_TIMEOUT",
default_value_t = NonZeroU16::new(180).unwrap(),
)]
pub(crate) maximum_resolution_timeout: NonZeroU16,
/// This flag is now enabled by default thus a no-op.
///
/// By default, Binstall will install a binary as-is in the install path.

View file

@ -2,6 +2,7 @@ use std::{
env, fs,
path::{Path, PathBuf},
sync::Arc,
time::Duration,
};
use binstalk::{
@ -200,6 +201,10 @@ pub fn install_crates(
SignaturePolicy::IfPresent
},
disable_telemetry: args.disable_telemetry,
maximum_resolution_timeout: Duration::from_secs(
args.maximum_resolution_timeout.get().into(),
),
});
// Destruct args before any async function to reduce size of the future

View file

@ -40,6 +40,7 @@ tokio = { version = "1.35.0", features = [
"rt",
"process",
"sync",
"time",
], default-features = false }
tracing = "0.1.39"
url = { version = "2.3.1", features = ["serde"] }

View file

@ -1,6 +1,6 @@
//! Concrete Binstall operations.
use std::{path::PathBuf, sync::Arc};
use std::{path::PathBuf, sync::Arc, time::Duration};
use semver::VersionReq;
@ -56,4 +56,6 @@ pub struct Options {
pub signature_policy: SignaturePolicy,
pub disable_telemetry: bool,
pub maximum_resolution_timeout: Duration,
}

View file

@ -17,7 +17,7 @@ use itertools::Itertools;
use leon::Template;
use maybe_owned::MaybeOwned;
use semver::{Version, VersionReq};
use tokio::task::spawn_blocking;
use tokio::{task::spawn_blocking, time::timeout};
use tracing::{debug, error, info, instrument, warn};
use url::Url;
@ -182,10 +182,13 @@ async fn resolve_inner(
}
for fetcher in handles {
match AutoAbortJoinHandle::new(fetcher.clone().find())
.flattened_join()
match timeout(
opts.maximum_resolution_timeout,
AutoAbortJoinHandle::new(fetcher.clone().find()).flattened_join(),
)
.await
{
Ok(ret) => match ret {
Ok(true) => {
// Generate temporary binary path
let bin_path = opts.temp_dir.join(format!(
@ -242,6 +245,14 @@ async fn resolve_inner(
err
);
}
},
Err(err) => {
warn!(
"Timeout reached while checking fetcher {}: {}",
fetcher.source_name(),
err
);
}
}
}