From ab9967556290026fe6fdd2a82ad7994246ce711b Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Tue, 2 May 2017 10:44:34 +0200 Subject: [PATCH] Add tests for StoreId --- libimagstore/src/storeid.rs | 94 +++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) diff --git a/libimagstore/src/storeid.rs b/libimagstore/src/storeid.rs index 975892b4..ab2727fe 100644 --- a/libimagstore/src/storeid.rs +++ b/libimagstore/src/storeid.rs @@ -234,8 +234,11 @@ impl Iterator for StoreIdIterator { #[cfg(test)] mod test { + use std::path::PathBuf; + use storeid::StoreId; use storeid::IntoStoreId; + use error::StoreErrorKind as SEK; module_entry_path_mod!("test"); @@ -246,4 +249,95 @@ mod test { assert_eq!(p.into_storeid().unwrap().to_str().unwrap(), "test/test"); } + #[test] + fn test_baseless_path() { + let id = StoreId::new_baseless(PathBuf::from("test")); + assert!(id.is_ok()); + assert_eq!(id.unwrap(), StoreId { + base: None, + id: PathBuf::from("test") + }); + } + + #[test] + fn test_base_path() { + let id = StoreId::from_full_path(&PathBuf::from("/tmp/"), PathBuf::from("/tmp/test")); + assert!(id.is_ok()); + assert_eq!(id.unwrap(), StoreId { + base: Some(PathBuf::from("/tmp/")), + id: PathBuf::from("test") + }); + } + + #[test] + fn test_adding_base_to_baseless_path() { + let id = StoreId::new_baseless(PathBuf::from("test")); + + assert!(id.is_ok()); + let id = id.unwrap(); + + assert_eq!(id, StoreId { base: None, id: PathBuf::from("test") }); + + let id = id.with_base(PathBuf::from("/tmp/")); + assert_eq!(id, StoreId { + base: Some(PathBuf::from("/tmp/")), + id: PathBuf::from("test") + }); + } + + #[test] + fn test_removing_base_from_base_path() { + let id = StoreId::from_full_path(&PathBuf::from("/tmp/"), PathBuf::from("/tmp/test")); + + assert!(id.is_ok()); + let id = id.unwrap(); + + assert_eq!(id, StoreId { + base: Some(PathBuf::from("/tmp/")), + id: PathBuf::from("test") + }); + + let id = id.without_base(); + assert_eq!(id, StoreId { + base: None, + id: PathBuf::from("test") + }); + } + + #[test] + fn test_baseless_into_pathbuf_is_err() { + let id = StoreId::new_baseless(PathBuf::from("test")); + assert!(id.is_ok()); + assert!(id.unwrap().into_pathbuf().is_err()); + } + + #[test] + fn test_baseless_into_pathbuf_is_storeidhasnobaseerror() { + let id = StoreId::new_baseless(PathBuf::from("test")); + assert!(id.is_ok()); + + let pb = id.unwrap().into_pathbuf(); + assert!(pb.is_err()); + + assert_eq!(pb.unwrap_err().err_type(), SEK::StoreIdHasNoBaseError); + } + + #[test] + fn test_basefull_into_pathbuf_is_ok() { + let id = StoreId::from_full_path(&PathBuf::from("/tmp/"), PathBuf::from("/tmp/test")); + assert!(id.is_ok()); + assert!(id.unwrap().into_pathbuf().is_ok()); + } + + #[test] + fn test_basefull_into_pathbuf_is_correct() { + let id = StoreId::from_full_path(&PathBuf::from("/tmp/"), PathBuf::from("/tmp/test")); + assert!(id.is_ok()); + + let pb = id.unwrap().into_pathbuf(); + assert!(pb.is_ok()); + + assert_eq!(pb.unwrap(), PathBuf::from("/tmp/test")); + } + }