lib/path: properly handle /. in hasStorePathPrefix

This commit is contained in:
Mikael Voss 2025-03-13 12:57:06 +01:00
parent b179a7a07f
commit bf790d1a7f
No known key found for this signature in database
2 changed files with 7 additions and 1 deletions

View file

@ -165,7 +165,7 @@ let
# This is a workaround for https://github.com/NixOS/nix/issues/12361 which
# was needed during the experimental phase of ca-derivations and should be
# removed once the issue has been resolved.
|| match "[0-9a-z]{52}" (head components) != null;
|| components != [ ] && match "[0-9a-z]{52}" (head components) != null;
in
# No rec! Add dependencies on this file at the top.

View file

@ -110,6 +110,12 @@ let
expected = false;
};
# Root path (empty path components list)
testHasStorePathPrefixRoot = {
expr = hasStorePathPrefix /.;
expected = false;
};
testHasStorePathPrefixExample1 = {
expr = hasStorePathPrefix (storeDirPath + "/nvl9ic0pj1fpyln3zaqrf4cclbqdfn1j-foo/bar/baz");
expected = true;