From 5da8b8565620c0987d6baa4345fa4d033b5e7819 Mon Sep 17 00:00:00 2001 From: Jake Shadle Date: Mon, 5 Aug 2024 13:06:49 +0200 Subject: [PATCH] Fix unused workspace dependency for current dir (#691) This fixes a bug where using the current dir '.' component would cause an incorrect unused-workspace-dependency lint to be triggered. --- CHANGELOG.md | 3 +++ src/diag/krate_spans.rs | 4 +++- tests/test_data/workspace/Cargo.toml | 2 +- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ade9d5dd..67ee62be 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] - ReleaseDate +### Fixed +- [PR#691](https://github.com/EmbarkStudios/cargo-deny/pull/691) fixed an issue where workspace dependencies that used the current dir '.' path component would incorrectly trigger the `unused-workspace-dependency` lint. + ## [0.16.0] - 2024-08-02 ### Removed - [PR#681](https://github.com/EmbarkStudios/cargo-deny/pull/681) finished the deprecation introduced in [PR#611](https://github.com/EmbarkStudios/cargo-deny/pull/611), making the usage of the deprecated fields into errors. diff --git a/src/diag/krate_spans.rs b/src/diag/krate_spans.rs index 8560a872..a0e52ff8 100644 --- a/src/diag/krate_spans.rs +++ b/src/diag/krate_spans.rs @@ -766,7 +766,9 @@ fn read_workspace_deps<'k>( // situations let dir = km.krate.manifest_path.parent()?; let path = crate::Path::new(path); - if path.as_str().contains("..") { + + // Handle cases of current '.' or parent '..' directories + if path.as_str().contains('.') { let mut pb = krates.workspace_root().to_owned(); for comp in path.components() { match comp { diff --git a/tests/test_data/workspace/Cargo.toml b/tests/test_data/workspace/Cargo.toml index dbb76bbf..6d31b980 100644 --- a/tests/test_data/workspace/Cargo.toml +++ b/tests/test_data/workspace/Cargo.toml @@ -17,7 +17,7 @@ spdx = "0.10" spdx-old = { version = "0.9", package = "spdx" } spdx-very-old = { version = "0.8", package = "spdx" } spdx-git = { git = "https://github.com/EmbarkStudios/spdx.git", tag = "0.7.0", package = "spdx" } -member-one = { path = "crates/member-one" } +member-one = { path = "./crates/member-one" } member-two = { path = "crates/member-two" } # Validates we can find workspace dependency sources from non-crates.io registries crate-two = { version = "0.1.0", registry = "embark-deny-git" }