test(tvix/glue/known_paths): add tests
Change-Id: I02dc891c49ed650c66c403107767b11b6d5e2734 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10949 Reviewed-by: flokli <flokli@flokli.de> Tested-by: BuildkiteCI Reviewed-by: Peter Kolloch <info@eigenvalue.net> Autosubmit: flokli <flokli@flokli.de>
This commit is contained in:
parent
8cd93f3db5
commit
44624284fd
5 changed files with 104 additions and 0 deletions
1
tvix/Cargo.lock
generated
1
tvix/Cargo.lock
generated
|
@ -3377,6 +3377,7 @@ dependencies = [
|
|||
"bytes",
|
||||
"criterion",
|
||||
"data-encoding",
|
||||
"hex-literal",
|
||||
"lazy_static",
|
||||
"nix-compat",
|
||||
"pretty_assertions",
|
||||
|
|
|
@ -10681,6 +10681,10 @@ rec {
|
|||
packageId = "criterion";
|
||||
features = [ "html_reports" ];
|
||||
}
|
||||
{
|
||||
name = "hex-literal";
|
||||
packageId = "hex-literal";
|
||||
}
|
||||
{
|
||||
name = "lazy_static";
|
||||
packageId = "lazy_static";
|
||||
|
|
|
@ -24,6 +24,7 @@ git = "https://github.com/tvlfyi/wu-manber.git"
|
|||
|
||||
[dev-dependencies]
|
||||
criterion = { version = "0.5", features = ["html_reports"] }
|
||||
hex-literal = "0.4.1"
|
||||
lazy_static = "1.4.0"
|
||||
pretty_assertions = "1.4.0"
|
||||
rstest = "0.18.2"
|
||||
|
|
|
@ -108,3 +108,100 @@ impl KnownPaths {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use nix_compat::{derivation::Derivation, nixhash::NixHash, store_path::StorePath};
|
||||
|
||||
use super::KnownPaths;
|
||||
use hex_literal::hex;
|
||||
use lazy_static::lazy_static;
|
||||
|
||||
lazy_static! {
|
||||
static ref BAR_DRV: Derivation = Derivation::from_aterm_bytes(include_bytes!(
|
||||
"tests/ss2p4wmxijn652haqyd7dckxwl4c7hxx-bar.drv"
|
||||
))
|
||||
.expect("must parse");
|
||||
static ref FOO_DRV: Derivation = Derivation::from_aterm_bytes(include_bytes!(
|
||||
"tests/ch49594n9avinrf8ip0aslidkc4lxkqv-foo.drv"
|
||||
))
|
||||
.expect("must parse");
|
||||
static ref BAR_DRV_PATH: StorePath =
|
||||
StorePath::from_bytes(b"ss2p4wmxijn652haqyd7dckxwl4c7hxx-bar.drv").expect("must parse");
|
||||
static ref FOO_DRV_PATH: StorePath =
|
||||
StorePath::from_bytes(b"ch49594n9avinrf8ip0aslidkc4lxkqv-foo.drv").expect("must parse");
|
||||
static ref BAR_OUT_PATH: StorePath =
|
||||
StorePath::from_bytes(b"mp57d33657rf34lzvlbpfa1gjfv5gmpg-bar").expect("must parse");
|
||||
static ref FOO_OUT_PATH: StorePath =
|
||||
StorePath::from_bytes(b"fhaj6gmwns62s6ypkcldbaj2ybvkhx3p-foo").expect("must parse");
|
||||
}
|
||||
|
||||
/// ensure we don't allow acdding a Derivation that depends on another,
|
||||
/// not-yet-added Derivation.
|
||||
#[test]
|
||||
#[should_panic]
|
||||
fn reject_if_missing_input_drv() {
|
||||
let mut known_paths = KnownPaths::default();
|
||||
|
||||
// FOO_DRV depends on BAR_DRV, which wasn't added.
|
||||
known_paths.add(FOO_DRV_PATH.clone(), FOO_DRV.clone());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn happy_path() {
|
||||
let mut known_paths = KnownPaths::default();
|
||||
|
||||
// get_drv_by_drvpath should return None for non-existing Derivations,
|
||||
// same as get_hash_derivation_modulo and get_drv_path_for_output_path
|
||||
assert_eq!(None, known_paths.get_drv_by_drvpath(&BAR_DRV_PATH));
|
||||
assert_eq!(None, known_paths.get_hash_derivation_modulo(&BAR_DRV_PATH));
|
||||
assert_eq!(
|
||||
None,
|
||||
known_paths.get_drv_path_for_output_path(&BAR_OUT_PATH)
|
||||
);
|
||||
|
||||
// Add BAR_DRV
|
||||
known_paths.add(BAR_DRV_PATH.clone(), BAR_DRV.clone());
|
||||
|
||||
// We should get it back
|
||||
assert_eq!(
|
||||
Some(&BAR_DRV.clone()),
|
||||
known_paths.get_drv_by_drvpath(&BAR_DRV_PATH)
|
||||
);
|
||||
|
||||
// Test get_drv_path_for_output_path
|
||||
assert_eq!(
|
||||
Some(&BAR_DRV_PATH.clone()),
|
||||
known_paths.get_drv_path_for_output_path(&BAR_OUT_PATH)
|
||||
);
|
||||
|
||||
// It should be possible to get the hash derivation modulo.
|
||||
assert_eq!(
|
||||
Some(&NixHash::Sha256(hex!(
|
||||
"c79aebd0ce3269393d4a1fde2cbd1d975d879b40f0bf40a48f550edc107fd5df"
|
||||
))),
|
||||
known_paths.get_hash_derivation_modulo(&BAR_DRV_PATH.clone())
|
||||
);
|
||||
|
||||
// Now insert FOO_DRV too. It shouldn't panic, as BAR_DRV is already
|
||||
// added.
|
||||
known_paths.add(FOO_DRV_PATH.clone(), FOO_DRV.clone());
|
||||
|
||||
assert_eq!(
|
||||
Some(&FOO_DRV.clone()),
|
||||
known_paths.get_drv_by_drvpath(&FOO_DRV_PATH)
|
||||
);
|
||||
assert_eq!(
|
||||
Some(&NixHash::Sha256(hex!(
|
||||
"af030d36d63d3d7f56a71adaba26b36f5fa1f9847da5eed953ed62e18192762f"
|
||||
))),
|
||||
known_paths.get_hash_derivation_modulo(&FOO_DRV_PATH.clone())
|
||||
);
|
||||
|
||||
// Test get_drv_path_for_output_path
|
||||
assert_eq!(
|
||||
Some(&FOO_DRV_PATH.clone()),
|
||||
known_paths.get_drv_path_for_output_path(&FOO_OUT_PATH)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
Derive([("out","/nix/store/mp57d33657rf34lzvlbpfa1gjfv5gmpg-bar","r:sha1","0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33")],[],[],":",":",[],[("builder",":"),("name","bar"),("out","/nix/store/mp57d33657rf34lzvlbpfa1gjfv5gmpg-bar"),("outputHash","0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33"),("outputHashAlgo","sha1"),("outputHashMode","recursive"),("system",":")])
|
Loading…
Reference in a new issue