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…
	
	Add table
		Add a link
		
	
		Reference in a new issue