From fa1498396e25382d932191c6cd0cdab7d2487bc6 Mon Sep 17 00:00:00 2001 From: Charlie Marsh Date: Fri, 30 Aug 2024 15:02:06 -0400 Subject: [PATCH] Treat missing `top_level.txt` as non-fatal (#6881) ## Summary Closes https://github.com/astral-sh/uv/issues/6872. --- crates/uv/src/commands/pip/operations.rs | 10 +++++- crates/uv/tests/pip_install.rs | 39 +++++++++++++++++++++++- 2 files changed, 47 insertions(+), 2 deletions(-) diff --git a/crates/uv/src/commands/pip/operations.rs b/crates/uv/src/commands/pip/operations.rs index 4e2bd312b..c34b8e089 100644 --- a/crates/uv/src/commands/pip/operations.rs +++ b/crates/uv/src/commands/pip/operations.rs @@ -463,7 +463,15 @@ pub(crate) async fn install( install_wheel_rs::Error::MissingRecord(_), )) => { warn_user!( - "Failed to uninstall package at {} due to missing RECORD file. Installation may result in an incomplete environment.", + "Failed to uninstall package at {} due to missing `RECORD` file. Installation may result in an incomplete environment.", + dist_info.path().user_display().cyan(), + ); + } + Err(uv_installer::UninstallError::Uninstall( + install_wheel_rs::Error::MissingTopLevel(_), + )) => { + warn_user!( + "Failed to uninstall package at {} due to missing `top-level.txt` file. Installation may result in an incomplete environment.", dist_info.path().user_display().cyan(), ); } diff --git a/crates/uv/tests/pip_install.rs b/crates/uv/tests/pip_install.rs index 712c0d26f..71b1a9ad9 100644 --- a/crates/uv/tests/pip_install.rs +++ b/crates/uv/tests/pip_install.rs @@ -672,7 +672,7 @@ fn reinstall_incomplete() -> Result<()> { ----- stderr ----- Resolved 3 packages in [TIME] Prepared 1 package in [TIME] - warning: Failed to uninstall package at [SITE_PACKAGES]/anyio-3.7.0.dist-info due to missing RECORD file. Installation may result in an incomplete environment. + warning: Failed to uninstall package at [SITE_PACKAGES]/anyio-3.7.0.dist-info due to missing `RECORD` file. Installation may result in an incomplete environment. Uninstalled 1 package in [TIME] Installed 1 package in [TIME] - anyio==3.7.0 @@ -6455,3 +6455,40 @@ fn stale_egg_info() -> Result<()> { Ok(()) } + +/// `suds-community` has an incorrect layout whereby the wheel includes `suds_community.egg-info` at +/// the top-level. We're then under the impression that `suds` is installed twice, but when we go to +/// uninstall the second "version", we can't find the `egg-info` directory. +#[test] +fn missing_top_level() { + let context = TestContext::new("3.12"); + + uv_snapshot!(context.filters(), context.pip_install() + .arg("suds-community==0.8.5"), @r###" + success: true + exit_code: 0 + ----- stdout ----- + + ----- stderr ----- + Resolved 1 package in [TIME] + Prepared 1 package in [TIME] + Installed 1 package in [TIME] + + suds-community==0.8.5 + "### + ); + + uv_snapshot!(context.filters(), context.pip_install() + .arg("suds-community==0.8.5"), @r###" + success: true + exit_code: 0 + ----- stdout ----- + + ----- stderr ----- + Resolved 1 package in [TIME] + warning: Failed to uninstall package at [SITE_PACKAGES]/suds_community.egg-info due to missing `top-level.txt` file. Installation may result in an incomplete environment. + Uninstalled 2 packages in [TIME] + Installed 1 package in [TIME] + ~ suds-community==0.8.5 + "### + ); +}