Skip to content

Commit

Permalink
feat: install specific extension version (#3405)
Browse files Browse the repository at this point in the history
In order to not break CI every time we release a new dfx version, make it so we can install a specific version of an extension rather than relying on the compatibility matrix.

There is no document for `dfx extension` in docs/cli-reference, so I did not update it.
  • Loading branch information
ericswanson-dfinity authored Sep 29, 2023
1 parent 344225d commit 1e43780
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 4 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@

Generate frontend declarations for remote canisters too because frontend JS code may want to call them.

### feat: dfx extension install <extension> --version <specific version>

Install a specific version of an extension, bypassing version checks.

### feat: Updated handling of missing values in state tree certificates

The `Unknown` lookup of a path in a certificate results in an `AgentError` (the IC returns `Absent` for non-existing paths).
Expand Down
2 changes: 1 addition & 1 deletion e2e/tests-dfx/extension.bash
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ teardown() {
assert_command dfx extension list
assert_match 'No extensions installed'

assert_command dfx extension install sns --install-as snsx
assert_command dfx extension install sns --install-as snsx --version 0.2.1
# TODO: how to capture spinner message?
# assert_match 'Successfully installed extension'

Expand Down
2 changes: 1 addition & 1 deletion e2e/tests-dfx/ledger.bash
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ setup() {

dfx_start_for_nns_install

dfx extension install nns || true
dfx extension install nns --version 0.2.1 || true
dfx nns install --ledger-accounts 345f723e9e619934daac6ae0f4be13a7b0ba57d6a608e511a00fd0ded5866752 22ca7edac648b814e81d7946e8bacea99280e07c5f51a04ba7a38009d8ad8e89 5a94fe181e9d411c58726cb87cbf2d016241b6c350bc3330e4869ca76e54ecbc
}

Expand Down
6 changes: 5 additions & 1 deletion src/dfx-core/src/extension/manager/install.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ impl ExtensionManager {
&self,
extension_name: &str,
install_as: Option<&str>,
version: Option<&Version>,
) -> Result<(), ExtensionError> {
let effective_extension_name = install_as.unwrap_or(extension_name);

Expand All @@ -29,7 +30,10 @@ impl ExtensionManager {
));
}

let extension_version = self.get_extension_compatible_version(extension_name)?;
let extension_version = match version {
Some(version) => version.clone(),
None => self.get_extension_compatible_version(extension_name)?,
};
let github_release_tag = get_git_release_tag(extension_name, &extension_version);
let extension_archive = get_extension_archive_name(extension_name)?;
let url = get_extension_download_url(&github_release_tag, &extension_archive)?;
Expand Down
10 changes: 9 additions & 1 deletion src/dfx/src/commands/extension/install.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ use crate::lib::error::DfxResult;
use clap::Parser;
use clap::Subcommand;
use dfx_core::error::extension::ExtensionError;
use semver::Version;

#[derive(Parser)]
pub struct InstallOpts {
Expand All @@ -12,6 +13,9 @@ pub struct InstallOpts {
/// Installs the extension under different name. Useful when installing an extension with the same name as: already installed extension, or a built-in command.
#[clap(long)]
install_as: Option<String>,
/// Installs a specific version of the extension, bypassing version checks
#[clap(long)]
version: Option<Version>,
}

pub fn exec(env: &dyn Environment, opts: InstallOpts) -> DfxResult<()> {
Expand All @@ -22,7 +26,11 @@ pub fn exec(env: &dyn Environment, opts: InstallOpts) -> DfxResult<()> {
return Err(ExtensionError::CommandAlreadyExists(opts.name).into());
}

mgr.install_extension(&opts.name, opts.install_as.as_deref())?;
mgr.install_extension(
&opts.name,
opts.install_as.as_deref(),
opts.version.as_ref(),
)?;
spinner.finish_with_message(
format!(
"Extension '{}' installed successfully{}",
Expand Down

0 comments on commit 1e43780

Please sign in to comment.