Skip to content

Commit

Permalink
fix: always write slash paths to RECORD file
Browse files Browse the repository at this point in the history
Signed-off-by: Frost Ming <[email protected]>
  • Loading branch information
frostming committed Dec 26, 2024
1 parent 3cb7232 commit c539331
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 2 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions crates/uv-install-wheel/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ data-encoding = { workspace = true }
fs-err = { workspace = true }
mailparse = { workspace = true }
pathdiff = { workspace = true }
path-slash = { workspace = true }
platform-info = { workspace = true }
reflink-copy = { workspace = true }
regex = { workspace = true }
Expand Down
34 changes: 32 additions & 2 deletions crates/uv-install-wheel/src/wheel.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ use data_encoding::BASE64URL_NOPAD;
use fs_err as fs;
use fs_err::{DirEntry, File};
use mailparse::parse_headers;
use path_slash::PathExt;
use rustc_hash::FxHashMap;
use sha2::{Digest, Sha256};
use tracing::{instrument, warn};
Expand Down Expand Up @@ -604,7 +605,7 @@ pub(crate) fn write_file_recorded(
let hash = Sha256::new().chain_update(content.as_ref()).finalize();
let encoded_hash = format!("sha256={}", BASE64URL_NOPAD.encode(&hash));
record.push(RecordEntry {
path: relative_path.display().to_string(),
path: relative_path.to_slash_lossy().to_string(),
hash: Some(encoded_hash),
size: Some(content.as_ref().len() as u64),
});
Expand Down Expand Up @@ -741,7 +742,8 @@ mod test {
use crate::Error;

use super::{
get_script_executable, parse_email_message_file, parse_wheel_file, read_record_file, Script,
get_script_executable, parse_email_message_file, parse_wheel_file, read_record_file,
write_installer_metadata, Script,
};

#[test]
Expand Down Expand Up @@ -1016,4 +1018,32 @@ mod test {

Ok(())
}

#[test]
fn test_write_installer_metadata() {
let temp_dir = assert_fs::TempDir::new().unwrap();
let site_packages = temp_dir.path();
let mut record: Vec<crate::record::RecordEntry> = Vec::new();
write_installer_metadata(
site_packages,
"foo-0.1.0",
true,
None,
None,
Some("uv"),
&mut record,
)
.unwrap();
let expected = [
"foo-0.1.0.dist-info/INSTALLER",
"foo-0.1.0.dist-info/REQUESTED",
]
.map(ToString::to_string)
.to_vec();
let actual = record
.into_iter()
.map(|entry| entry.path)
.collect::<Vec<String>>();
assert_eq!(expected, actual);
}
}

0 comments on commit c539331

Please sign in to comment.