From 8064e1e85bb728e26fbb7fbf9da708f62689a316 Mon Sep 17 00:00:00 2001 From: Daniel Elsner Date: Thu, 24 Oct 2024 15:00:21 +0200 Subject: [PATCH 1/4] feat: Add --env-name flag for environment output directory --- src/main.rs | 6 ++++++ src/unpack.rs | 3 ++- tests/integration_test.rs | 18 ++++++++++++++++++ 3 files changed, 26 insertions(+), 1 deletion(-) diff --git a/src/main.rs b/src/main.rs index 7344c55..7715694 100644 --- a/src/main.rs +++ b/src/main.rs @@ -71,6 +71,10 @@ enum Commands { #[arg(short, long, default_value = cwd().into_os_string())] output_directory: PathBuf, + /// Name of the environment + #[arg(short, long, default_value = "env")] + env_name: String, + /// Path to the pack file #[arg()] pack_file: PathBuf, @@ -122,12 +126,14 @@ async fn main() -> Result<()> { } Commands::Unpack { output_directory, + env_name, pack_file, shell, } => { let options = UnpackOptions { pack_file, output_directory, + env_name, shell, }; tracing::debug!("Running unpack command with options: {:?}", options); diff --git a/src/unpack.rs b/src/unpack.rs index 930abbc..cae5a77 100644 --- a/src/unpack.rs +++ b/src/unpack.rs @@ -31,6 +31,7 @@ use crate::{ pub struct UnpackOptions { pub pack_file: PathBuf, pub output_directory: PathBuf, + pub env_name: String, pub shell: Option, } @@ -47,7 +48,7 @@ pub async fn unpack(options: UnpackOptions) -> Result<()> { validate_metadata_file(unpack_dir.join(PIXI_PACK_METADATA_PATH)).await?; - let target_prefix = options.output_directory.join("env"); + let target_prefix = options.output_directory.join(options.env_name); tracing::info!("Creating prefix at {}", target_prefix.display()); let channel_directory = unpack_dir.join(CHANNEL_DIRECTORY_NAME); diff --git a/tests/integration_test.rs b/tests/integration_test.rs index 3929848..efd4b8c 100644 --- a/tests/integration_test.rs +++ b/tests/integration_test.rs @@ -29,6 +29,7 @@ fn options( #[default(PixiPackMetadata::default())] metadata: PixiPackMetadata, #[default(Some(ShellEnum::Bash(Bash)))] shell: Option, #[default(false)] ignore_pypi_errors: bool, + #[default("env")] env_name: String, ) -> Options { let output_dir = tempdir().expect("Couldn't create a temp dir for tests"); let pack_file = output_dir.path().join("environment.tar"); @@ -46,6 +47,7 @@ fn options( unpack_options: UnpackOptions { pack_file, output_directory: output_dir.path().to_path_buf(), + env_name, shell, }, output_dir, @@ -335,3 +337,19 @@ async fn test_non_authenticated( .to_string() .contains("failed to download")); } + +#[rstest] +#[tokio::test] +async fn test_custom_env_name(options: Options) { + let env_name = "custom"; + let pack_options = options.pack_options; + let pack_result = pixi_pack::pack(pack_options).await; + assert!(pack_result.is_ok(), "{:?}", pack_result); + + let mut unpack_options = options.unpack_options; + unpack_options.env_name = env_name.to_string(); + let env_dir = unpack_options.output_directory.join(env_name); + let unpack_result = pixi_pack::unpack(unpack_options).await; + assert!(unpack_result.is_ok(), "{:?}", unpack_result); + assert!(env_dir.is_dir()); +} From 15c768126f780d4262c5bc9cd1366564a742bad4 Mon Sep 17 00:00:00 2001 From: Daniel Elsner Date: Thu, 24 Oct 2024 15:00:55 +0200 Subject: [PATCH 2/4] Bump version to 0.2.1 --- Cargo.lock | 4 ++-- Cargo.toml | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index eca90ba..cdc4e4d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1,6 +1,6 @@ # This file is automatically @generated by Cargo. # It is not intended for manual editing. -version = 3 +version = 4 [[package]] name = "addr2line" @@ -2343,7 +2343,7 @@ dependencies = [ [[package]] name = "pixi-pack" -version = "0.2.0" +version = "0.2.1" dependencies = [ "anyhow", "async-std", diff --git a/Cargo.toml b/Cargo.toml index 5f2fec6..4358e21 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "pixi-pack" description = "A command line tool to pack and unpack conda environments for easy sharing" -version = "0.2.0" +version = "0.2.1" edition = "2021" [features] From 510ed5f81a693d639f12f0189d0ee00687ff4faf Mon Sep 17 00:00:00 2001 From: Pavel Zwerschke Date: Thu, 24 Oct 2024 15:02:46 +0200 Subject: [PATCH 3/4] Update Cargo.lock --- Cargo.lock | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Cargo.lock b/Cargo.lock index cdc4e4d..7a6b17e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1,6 +1,6 @@ # This file is automatically @generated by Cargo. # It is not intended for manual editing. -version = 4 +version = 3 [[package]] name = "addr2line" From 00555c46b5b0302132af1c64ef595a6d51086b8b Mon Sep 17 00:00:00 2001 From: Daniel Elsner Date: Thu, 24 Oct 2024 15:10:18 +0200 Subject: [PATCH 4/4] Change cli docs --- src/main.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/main.rs b/src/main.rs index 7715694..5b586cf 100644 --- a/src/main.rs +++ b/src/main.rs @@ -66,7 +66,8 @@ enum Commands { /// Unpack a pixi environment Unpack { /// Where to unpack the environment. - /// The environment will be unpacked into a `env` subdirectory of this path. + /// The environment will be unpacked into a subdirectory of this path + /// (default `env`, change with `--env-name`). /// The activation script will be written to the root of this path. #[arg(short, long, default_value = cwd().into_os_string())] output_directory: PathBuf,