-
Notifications
You must be signed in to change notification settings - Fork 143
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Prompt user to install the override toolchain if its specified but not installed yet #656
base: master
Are you sure you want to change the base?
Conversation
1f2086b
to
69176e8
Compare
Once I found that toolchain installations were not failing because of code, everything started falling into place... I've left the We should now be a bit more robust with this PR when parsing But for something to keep in mind, in the future we're probably better off converting |
I forgot to mention, with the toolchain spec here:
I think -- Other quick change to the PR could be to move the URL concats into a separate function like |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's coming along! I left some comments, and make sure to run cargo fmt
to get CI passing.
@@ -68,7 +50,7 @@ fn format_nightly_url(date: &Date) -> Result<String> { | |||
} | |||
|
|||
fn construct_channel_url(desc: &DistToolchainDescription) -> Result<String> { | |||
let mut url = FUELUP_GH_PAGES.to_owned(); | |||
let mut url = format!("{}{}/gh-pages/", GITHUB_USER_CONTENT_URL, "fuelup"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd prefer to keep FUELUP_GH_PAGES
as a constant and refactor this to not use a mutable url.
fn construct_channel_url(desc: &DistToolchainDescription) -> Result<String> {
let channel_file = match desc.name {
DistToolchainName::Latest => {
if let Some(date) = desc.date {
&format!("channels/latest/channel-fuel-latest-{date}.toml")
} else {
CHANNEL_LATEST_FILE_NAME
}
}
DistToolchainName::Nightly => {
let mut file = "".to_string();
if let Some(date) = desc.date {
file.push_str(&format_nightly_url(&date)?);
file.push('/');
}
file.push_str(CHANNEL_NIGHTLY_FILE_NAME);
&file
}
DistToolchainName::Beta1 => CHANNEL_BETA_1_FILE_NAME,
DistToolchainName::Beta2 => CHANNEL_BETA_2_FILE_NAME,
DistToolchainName::Beta3 => CHANNEL_BETA_3_FILE_NAME,
DistToolchainName::Beta4 => CHANNEL_BETA_4_FILE_NAME,
DistToolchainName::Beta5 => CHANNEL_BETA_5_FILE_NAME,
DistToolchainName::Devnet => CHANNEL_DEVNET_FILE_NAME,
DistToolchainName::Testnet => CHANNEL_TESTNET_FILE_NAME,
};
let mut url = format!("{}{}/gh-pages/", GITHUB_USER_CONTENT_URL, "fuelup");
Ok(format!("{FUELUP_GH_PAGES}{channel_file}"))
}
pub fn is_beta_toolchain(name: &str) -> Option<&str> { | ||
BETA_CHANNELS | ||
.iter() | ||
.find(|&beta_channel| name.starts_with(beta_channel)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't this still be name == beta_channel
?
@@ -45,7 +45,7 @@ fn name_allowed(s: &str) -> Result<String> { | |||
None => s, | |||
}; | |||
|
|||
if RESERVED_TOOLCHAIN_NAMES.contains(&name) { | |||
if CHANNELS.contains(&name) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
RESERVED_TOOLCHAIN_NAMES
is different from CHANNELS
. We want stable
to be reserved even though it isn't currently a usable channel.
@@ -25,7 +25,7 @@ impl Config { | |||
.filter(|e| e.file_type().map(|f| f.is_dir()).unwrap_or(false)) | |||
{ | |||
let toolchain = dir_entry.file_name().to_string_lossy().to_string(); | |||
if RESERVED_TOOLCHAIN_NAMES | |||
if CHANNELS |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same comment here.
@@ -57,4 +57,14 @@ pub fn ask_user_yes_no_question(question: &str) -> io::Result<bool> { | |||
return Ok(result); | |||
} | |||
} | |||
|
|||
// This is the dialoguer version of the prompter, but it's not testable |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Have you tried testing it with rexpect
? Here's an example
@@ -46,6 +51,41 @@ enum Commands { | |||
pub fn fuelup_cli() -> Result<()> { | |||
let cli = Cli::parse(); | |||
|
|||
if let Some(toolchain_override) = ToolchainOverride::from_project_root() { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: add a comment here explaining what this is checking
|
||
if !toolchain.exists() { | ||
match cli.command { | ||
Commands::Toolchain(_) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We only want to do this for operations where the toolchain override will be used in some way, right? So we also don't need to do this for fuelup update/upgrade/install
fuelup completions
fuelup check
fuelup default
We really only need it for proxy commands and for fuelup component
which modifies the currently active toolchain.
For fuelup show
it could be good to show the current state first and then prompt the user if they wish to install.
|
||
assert!(output | ||
.stdout | ||
.starts_with(&format!("Using override toolchain 'beta-1-{triple}'"))); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: we're planning to remove support for betas 1-4 pretty soon, so it might be better to make these tests use beta-5
|
||
/// A convenience wrapper for executing 'fuelup' within the fuelup test configuration. | ||
/// It takes an array ref of bytes to write into stdin. | ||
pub fn fuelup_with_input(&mut self, args: &[&str], input: &[u8]) -> TestOutput { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be easier with rexpect
Keeping this PR in DRAFT but backgrounding for now... Most of these changes have moved to other PRs and have been merged, but there's a few change and comments remaining that I want to pull into future changes. |
This PR is in relation to #652
When overriding toolchains, there are 2 places to be concerned with when a toolchain is missing:
fuelup
is the command runFor 2, we are already covering this scenario by installing missing components and plugins on first run.
As for 1, this PR will now
bail!()
unless the command is toinstall
,uninstall
, or create anew
toolkit....
No tests yet because I want to get feedback to see if I'm on the right track.