feat(nix/utils): add onlyDrvPath to get the drvPath w/o the outputs
I want to use this utility in a deploy script where the .drv is nix-copy-closure-d to a remote host and realized there. Consequently it doesn't make sense that the local deploy script depends on the derivation's outputs which drvPath does by default. This also came up when working on //nix/buildkite, although we didn't end up using it there. Change-Id: I952bbfd4d7e9de212569d5ee12182eb50d360f53 Reviewed-on: https://cl.tvl.fyi/c/depot/+/5767 Tested-by: BuildkiteCI Autosubmit: sterni <sternenseemann@systemli.org> Reviewed-by: tazjin <tazjin@tvl.su>
This commit is contained in:
parent
6c3465dc59
commit
6813598c17
2 changed files with 27 additions and 0 deletions
|
|
@ -15,6 +15,7 @@ let
|
|||
isSymlink
|
||||
pathType
|
||||
storePathName
|
||||
onlyDrvPath
|
||||
;
|
||||
|
||||
assertUtilsPred = msg: act: exp: [
|
||||
|
|
@ -91,9 +92,19 @@ let
|
|||
(storePathName cleanedSource)
|
||||
cleanedSource.name)
|
||||
];
|
||||
|
||||
onlyDrvPathTests = it "correctly updates the string context of drvPath" [
|
||||
(assertEq "onlyDrvPath only produces path dependencies"
|
||||
(builtins.all
|
||||
(dep: dep.path or false)
|
||||
(builtins.attrValues
|
||||
(builtins.getContext (onlyDrvPath depot.tools.cheddar))))
|
||||
true)
|
||||
];
|
||||
in
|
||||
|
||||
runTestsuite "nix.utils" [
|
||||
pathPredicates
|
||||
storePathNameTests
|
||||
onlyDrvPathTests
|
||||
]
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue