Skip to content

Commit

Permalink
Auto merge of #8835 - steven-joruk:ignore-lock-files-in-packages, r=a…
Browse files Browse the repository at this point in the history
…lexcrichton

Skip extracting .cargo-ok files from packages

This is for #8816

I'll look into adding a unit test tomorrow, I'm still familiarising myself with the project.
  • Loading branch information
bors committed Nov 9, 2020
2 parents d5556ae + 05a8127 commit 03976af
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 11 deletions.
16 changes: 9 additions & 7 deletions src/cargo/sources/registry/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -471,13 +471,6 @@ impl<'cfg> RegistrySource<'cfg> {
return Ok(unpack_dir.to_path_buf());
}
}
let mut ok = OpenOptions::new()
.create(true)
.read(true)
.write(true)
.open(&path)
.chain_err(|| format!("failed to open `{}`", path.display()))?;

let gz = GzDecoder::new(tarball);
let mut tar = Archive::new(gz);
let prefix = unpack_dir.file_name().unwrap();
Expand Down Expand Up @@ -517,6 +510,15 @@ impl<'cfg> RegistrySource<'cfg> {
result.chain_err(|| format!("failed to unpack entry at `{}`", entry_path.display()))?;
}

// The lock file is created after unpacking so we overwrite a lock file
// which may have been extracted from the package.
let mut ok = OpenOptions::new()
.create(true)
.read(true)
.write(true)
.open(&path)
.chain_err(|| format!("failed to open `{}`", path.display()))?;

// Write to the lock file to indicate that unpacking was successful.
write!(ok, "ok")?;

Expand Down
45 changes: 41 additions & 4 deletions tests/testsuite/registry.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
//! Tests for normal registry dependencies.
use cargo::util::paths::remove_dir_all;
use cargo_test_support::cargo_process;
use cargo_test_support::git;
use cargo::{core::SourceId, util::paths::remove_dir_all};
use cargo_test_support::paths::{self, CargoPathExt};
use cargo_test_support::registry::{self, registry_path, Dependency, Package};
use cargo_test_support::{basic_manifest, project, t};
use cargo_test_support::{basic_manifest, project};
use cargo_test_support::{cargo_process, registry::registry_url};
use cargo_test_support::{git, install::cargo_home, t};
use std::fs::{self, File};
use std::path::Path;

Expand Down Expand Up @@ -2133,3 +2133,40 @@ Use `[source]` replacement to alter the default index for crates.io.
)
.run();
}

#[cargo_test]
fn package_lock_inside_package_is_overwritten() {
let p = project()
.file(
"Cargo.toml",
r#"
[project]
name = "foo"
version = "0.0.1"
authors = []
[dependencies]
bar = ">= 0.0.0"
"#,
)
.file("src/main.rs", "fn main() {}")
.build();

Package::new("bar", "0.0.1")
.file("src/lib.rs", "")
.file(".cargo-ok", "")
.publish();

p.cargo("build").run();

let id = SourceId::for_registry(&registry_url()).unwrap();
let hash = cargo::util::hex::short_hash(&id);
let ok = cargo_home()
.join("registry")
.join("src")
.join(format!("-{}", hash))
.join("bar-0.0.1")
.join(".cargo-ok");

assert_eq!(ok.metadata().unwrap().len(), 2);
}

0 comments on commit 03976af

Please sign in to comment.