Avoid waiting for metadata for --no-deps editables (#3188)

## Summary

We don't emit a request for this, so we shouldn't wait for it either --
we already have the metadata!

Closes https://github.com/astral-sh/uv/issues/3184.
This commit is contained in:
Charlie Marsh 2024-04-22 12:29:19 -04:00 committed by GitHub
parent 725004dcf1
commit a4f125ca34
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 28 additions and 1 deletions

View file

@ -864,7 +864,7 @@ impl<
if self.dependency_mode.is_direct() {
// If an extra is provided, wait for the metadata to be available, since it's
// still required for reporting diagnostics.
if extra.is_some() {
if extra.is_some() && self.editables.get(package_name).is_none() {
// Determine the distribution to lookup.
let dist = match url {
Some(url) => PubGrubDistribution::from_url(package_name, url),

View file

@ -1495,6 +1495,33 @@ fn no_deps() {
context.assert_command("import flask").failure();
}
/// Install an editable package from the command line into a virtual environment, ignoring its
/// dependencies.
#[test]
fn no_deps_editable() {
let context = TestContext::new("3.12");
// Install the editable version of Black. This should remove the registry-based version.
uv_snapshot!(context.filters(), context.install()
.arg("--no-deps")
.arg("-e")
.arg(context.workspace_root.join("scripts/packages/black_editable[dev]")), @r###"
success: true
exit_code: 0
----- stdout -----
----- stderr -----
Built 1 editable in [TIME]
Resolved 1 package in [TIME]
Installed 1 package in [TIME]
+ black==0.1.0 (from file://[WORKSPACE]/scripts/packages/black_editable)
"###
);
context.assert_command("import black").success();
context.assert_command("import aiohttp").failure();
}
/// Upgrade a package.
#[test]
fn install_upgrade() {