diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 00000000..487b4a19 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,41 @@ +sudo: false +language: rust +rust: + - beta + - nightly + - stable + +matrix: + allow_failures: + - rust: nightly + +before_script: + - | + pip install 'travis-cargo<0.2' --user && + export PATH=$HOME/.local/bin:$PATH + +script: + - | + travis-cargo build && + travis-cargo test && + travis-cargo bench && + travis-cargo --only stable doc + +addons: + apt: + packages: + - libcurl4-openssl-dev + - libelf-dev + - libdw-dev + +after_success: + - travis-cargo --only stable doc-upload + - travis-cargo coveralls --no-sudo + +notifications: + email: + on_success: never + +env: + global: + - TRAVIS_CARGO_NIGHTLY_FEATURE=dev diff --git a/src/storage/file/id.rs b/src/storage/file/id.rs index 3c8ddf36..c274077e 100644 --- a/src/storage/file/id.rs +++ b/src/storage/file/id.rs @@ -113,7 +113,8 @@ impl Into for FileID { #[cfg(test)] mod test { - use super::{FileID, FileIDType}; + use storage::file::id::FileID; + use storage::file::id_type::FileIDType; #[test] fn file_id_from_string() { @@ -123,25 +124,27 @@ mod test { let s2 = String::from("/home/user/testmodule-UUID-some-id.extension.imag"); let s3 = String::from("/home/user/testmodule-NOHASH-some-id.imag"); - let id1 = FileID::from(s1); - let id2 = FileID::from(s2); - let id3 = FileID::from(s3); + let id1 = FileID::parse(&s1).unwrap(); + let id2 = FileID::parse(&s2).unwrap(); + assert!(FileID::parse(&s3).is_none()); println!("Id 1 : {:?}", id1); println!("Id 2 : {:?}", id2); - println!("Id 3 : {:?}", id3); assert_eq!(FileIDType::UUID, id1.get_type()); assert_eq!(FileIDType::UUID, id2.get_type()); - assert_eq!(FileIDType::NONE, id3.get_type()); + + let h1 : String = id1.get_id().into(); + let h2 : String = id2.get_id().into(); + + assert_eq!(String::from("some-id"), h1); + assert_eq!(String::from("some-id"), h2); let f1 : String = id1.into(); let f2 : String = id2.into(); - let f3 : String = id3.into(); - assert_eq!(String::from("some-id"), f1); - assert_eq!(String::from("some-id"), f2); - assert_eq!(String::from("INVALID"), f3); + assert_eq!(String::from("UUID-some-id"), f1); + assert_eq!(String::from("UUID-some-id"), f2); } fn setup_logger() { diff --git a/src/storage/file/mod.rs b/src/storage/file/mod.rs index 16a072ef..61a7f749 100644 --- a/src/storage/file/mod.rs +++ b/src/storage/file/mod.rs @@ -100,10 +100,10 @@ impl Debug for File { mod test { // we use the JSON parser here, so we can generate FileHeaderData use storage::json::parser::JsonHeaderParser; - use super::match_header_spec; + use storage::file::header::match_header_spec; use storage::parser::{FileHeaderParser, ParserError}; - use storage::file::FileHeaderData as FHD; - use storage::file::FileHeaderSpec as FHS; + use storage::file::header::data::FileHeaderData as FHD; + use storage::file::header::spec::FileHeaderSpec as FHS; #[test] fn test_spec_matching() { diff --git a/src/storage/json/parser.rs b/src/storage/json/parser.rs index 7011b6c2..ea5738b7 100644 --- a/src/storage/json/parser.rs +++ b/src/storage/json/parser.rs @@ -148,10 +148,12 @@ impl Serialize for FileHeaderData { #[cfg(test)] mod test { + use std::ops::Deref; + use super::JsonHeaderParser; use storage::parser::{FileHeaderParser, ParserError}; - use storage::file::FileHeaderData as FHD; - use storage::file::FileHeaderSpec as FHS; + use storage::file::header::data::FileHeaderData as FHD; + use storage::file::header::spec::FileHeaderSpec as FHS; #[test] fn test_deserialization() { @@ -177,9 +179,9 @@ mod test { Some(FHD::Map{keys: keys}) => { for k in keys { match k { - FHD::Key{name: name, value: box value} => { + FHD::Key{name: name, value: value} => { assert!(name == "a" || name == "b", "Key unknown"); - match &value { + match value.deref() { &FHD::UInteger(u) => assert_eq!(u, 1), &FHD::Integer(i) => assert_eq!(i, -2), _ => assert!(false, "Integers are not here"),