From d2243c1de69642dab2838bc0fb935e8212b087c5 Mon Sep 17 00:00:00 2001 From: Pedro Fialho Date: Mon, 26 Dec 2022 15:12:41 -0300 Subject: [PATCH 1/5] create `latest` alias on install --- src/commands/install.rs | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/commands/install.rs b/src/commands/install.rs index ee22ebfe4..41ed76d52 100644 --- a/src/commands/install.rs +++ b/src/commands/install.rs @@ -137,6 +137,16 @@ impl super::command::Command for Install { other_err => other_err.map_err(|source| Error::DownloadError { source })?, }; + if let UserVersion::Full(Version::Latest) = current_version { + let alias_name = Version::Latest.v_str(); + debug!( + "Tagging {} as alias for {}", + alias_name.cyan(), + version.v_str().cyan() + ); + create_alias(config, &alias_name, &version)?; + } + if let UserVersion::Full(Version::Lts(lts_type)) = current_version { let alias_name = Version::Lts(lts_type).v_str(); debug!( From 0653f8a2a45045a153e3d468705f70d4b94a48b0 Mon Sep 17 00:00:00 2001 From: Pedro Fialho Date: Mon, 26 Dec 2022 17:50:42 -0300 Subject: [PATCH 2/5] add e2e tests for `latest` --- e2e/__snapshots__/latest.test.ts.snap | 32 +++++++++++++++++++++++++++ e2e/latest.test.ts | 19 ++++++++++++++++ 2 files changed, 51 insertions(+) create mode 100644 e2e/__snapshots__/latest.test.ts.snap create mode 100644 e2e/latest.test.ts diff --git a/e2e/__snapshots__/latest.test.ts.snap b/e2e/__snapshots__/latest.test.ts.snap new file mode 100644 index 000000000..8b25da341 --- /dev/null +++ b/e2e/__snapshots__/latest.test.ts.snap @@ -0,0 +1,32 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Bash installs latest: Bash 1`] = ` +"set -e +eval "$(fnm env)" +fnm install --latest +(fnm ls) | grep latest || (echo "Expected output to contain latest" && exit 1) +fnm use 'latest'" +`; + +exports[`Fish installs latest: Fish 1`] = ` +"fnm env | source +fnm install --latest +begin; fnm ls; end | grep latest; or echo "Expected output to contain latest" && exit 1 +fnm use 'latest'" +`; + +exports[`PowerShell installs latest: PowerShell 1`] = ` +"$ErrorActionPreference = "Stop" +fnm env | Out-String | Invoke-Expression +fnm install --latest +$($__out__ = $(fnm ls | Select-String latest); if ($__out__ -eq $null) { exit 1 } else { $__out__ }) +fnm use 'latest'" +`; + +exports[`Zsh installs latest: Zsh 1`] = ` +"set -e +eval "$(fnm env)" +fnm install --latest +(fnm ls) | grep latest || (echo "Expected output to contain latest" && exit 1) +fnm use 'latest'" +`; diff --git a/e2e/latest.test.ts b/e2e/latest.test.ts new file mode 100644 index 000000000..8d2a0fdd6 --- /dev/null +++ b/e2e/latest.test.ts @@ -0,0 +1,19 @@ +import { script } from "./shellcode/script.js" +import { Bash, Fish, PowerShell, Zsh } from "./shellcode/shells.js" +import describe from "./describe.js" + +for (const shell of [Bash, Zsh, Fish, PowerShell]) { + describe(shell, () => { + test(`installs latest`, async () => { + await script(shell) + .then(shell.env({})) + .then(shell.call("fnm", ["install", "--latest"])) + .then( + shell.scriptOutputContains(shell.call("fnm", ["ls"]), "latest") + ) + .then(shell.call("fnm", ["use", "'latest'"])) + .takeSnapshot(shell) + .execute(shell) + }) + }) +} From 22623fca30ec9848b36174a1d7d0ef8b1c26b6bf Mon Sep 17 00:00:00 2001 From: Gal Schlezinger Date: Mon, 27 May 2024 17:36:45 +0300 Subject: [PATCH 3/5] merge conditionals --- src/commands/install.rs | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/src/commands/install.rs b/src/commands/install.rs index 8dd418efe..dc13e0246 100644 --- a/src/commands/install.rs +++ b/src/commands/install.rs @@ -151,23 +151,17 @@ impl Command for Install { Ok(()) => {} }; - if let UserVersion::Full(Version::Latest) = current_version { - let alias_name = Version::Latest.v_str(); - debug!( - "Tagging {} as alias for {}", - alias_name.cyan(), - version.v_str().cyan() - ); - create_alias(config, &alias_name, &version)?; - } - if config.corepack_enabled() { outln!(config, Info, "Enabling corepack for {}", version_str.cyan()); enable_corepack(&version, config)?; } - if let UserVersion::Full(Version::Lts(lts_type)) = current_version { - let alias_name = Version::Lts(lts_type).v_str(); + if let Some(tagged_alias) = match ¤t_version { + UserVersion::Full(Version::Latest) => Some(Version::Latest), + UserVersion::Full(Version::Lts(lts_type)) => Some(Version::Lts(lts_type.clone())), + _ => None, + } { + let alias_name = tagged_alias.v_str(); debug!( "Tagging {} as alias for {}", alias_name.cyan(), From 315068568ebfb1ae846d4dd9b9e7586e4f3c3a2d Mon Sep 17 00:00:00 2001 From: Gal Schlezinger Date: Mon, 27 May 2024 17:37:55 +0300 Subject: [PATCH 4/5] Add changeset --- .changeset/many-sloths-fry.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/many-sloths-fry.md diff --git a/.changeset/many-sloths-fry.md b/.changeset/many-sloths-fry.md new file mode 100644 index 000000000..a64d094de --- /dev/null +++ b/.changeset/many-sloths-fry.md @@ -0,0 +1,5 @@ +--- +"fnm": minor +--- + +`fnm install latest` will now tag the `latest` alias From fb1cf73d6c9a3bcabb8c9b43c0a57624b470932b Mon Sep 17 00:00:00 2001 From: Gal Schlezinger Date: Mon, 27 May 2024 17:44:36 +0300 Subject: [PATCH 5/5] fix clippy --- src/commands/install.rs | 30 ++++++++++++++++-------------- src/user_version.rs | 9 +++++++++ 2 files changed, 25 insertions(+), 14 deletions(-) diff --git a/src/commands/install.rs b/src/commands/install.rs index dc13e0246..a0539edca 100644 --- a/src/commands/install.rs +++ b/src/commands/install.rs @@ -156,29 +156,31 @@ impl Command for Install { enable_corepack(&version, config)?; } - if let Some(tagged_alias) = match ¤t_version { - UserVersion::Full(Version::Latest) => Some(Version::Latest), - UserVersion::Full(Version::Lts(lts_type)) => Some(Version::Lts(lts_type.clone())), - _ => None, - } { - let alias_name = tagged_alias.v_str(); - debug!( - "Tagging {} as alias for {}", - alias_name.cyan(), - version.v_str().cyan() - ); - create_alias(config, &alias_name, &version)?; - } - if !config.default_version_dir().exists() { debug!("Tagging {} as the default version", version.v_str().cyan()); create_alias(config, "default", &version)?; } + if let Some(tagged_alias) = current_version.inferred_alias() { + tag_alias(config, &version, &tagged_alias)?; + } + Ok(()) } } +fn tag_alias(config: &FnmConfig, matched_version: &Version, alias: &Version) -> Result<(), Error> { + let alias_name = alias.v_str(); + debug!( + "Tagging {} as alias for {}", + alias_name.cyan(), + matched_version.v_str().cyan() + ); + create_alias(config, &alias_name, matched_version)?; + + Ok(()) +} + fn enable_corepack(version: &Version, config: &FnmConfig) -> Result<(), Error> { let corepack_path = version.installation_path(config); let corepack_path = if cfg!(windows) { diff --git a/src/user_version.rs b/src/user_version.rs index 52c69a12f..eb43d7145 100644 --- a/src/user_version.rs +++ b/src/user_version.rs @@ -50,6 +50,15 @@ impl UserVersion { } } } + + /// The inferred alias for the user version, if it exists. + pub fn inferred_alias(&self) -> Option { + match self { + UserVersion::Full(Version::Latest) => Some(Version::Latest), + UserVersion::Full(Version::Lts(lts_type)) => Some(Version::Lts(lts_type.clone())), + _ => None, + } + } } fn next_of<'a, T: FromStr, It: Iterator>(i: &mut It) -> Option {