更新libclamav库1.0.0版本
This commit is contained in:
258
clamav/libclamav_rust/.cargo/vendor/toml/tests/enum_external_deserialize.rs
vendored
Normal file
258
clamav/libclamav_rust/.cargo/vendor/toml/tests/enum_external_deserialize.rs
vendored
Normal file
@@ -0,0 +1,258 @@
|
||||
#[macro_use]
|
||||
extern crate serde_derive;
|
||||
extern crate toml;
|
||||
|
||||
#[derive(Debug, Deserialize, PartialEq)]
|
||||
struct OuterStruct {
|
||||
inner: TheEnum,
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize, PartialEq)]
|
||||
enum TheEnum {
|
||||
Plain,
|
||||
Tuple(i64, bool),
|
||||
NewType(String),
|
||||
Struct { value: i64 },
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize, PartialEq)]
|
||||
struct Val {
|
||||
val: TheEnum,
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize, PartialEq)]
|
||||
struct Multi {
|
||||
enums: Vec<TheEnum>,
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn invalid_variant_returns_error_with_good_message_string() {
|
||||
let error = toml::from_str::<TheEnum>("\"NonExistent\"").unwrap_err();
|
||||
|
||||
assert_eq!(
|
||||
error.to_string(),
|
||||
"unknown variant `NonExistent`, expected one of `Plain`, `Tuple`, `NewType`, `Struct`"
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn invalid_variant_returns_error_with_good_message_inline_table() {
|
||||
let error = toml::from_str::<TheEnum>("{ NonExistent = {} }").unwrap_err();
|
||||
assert_eq!(
|
||||
error.to_string(),
|
||||
"unknown variant `NonExistent`, expected one of `Plain`, `Tuple`, `NewType`, `Struct`"
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn extra_field_returns_expected_empty_table_error() {
|
||||
let error = toml::from_str::<TheEnum>("{ Plain = { extra_field = 404 } }").unwrap_err();
|
||||
|
||||
assert_eq!(error.to_string(), "expected empty table");
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn extra_field_returns_expected_empty_table_error_struct_variant() {
|
||||
let error = toml::from_str::<TheEnum>("{ Struct = { value = 123, extra_0 = 0, extra_1 = 1 } }")
|
||||
.unwrap_err();
|
||||
|
||||
assert_eq!(
|
||||
error.to_string(),
|
||||
r#"unexpected keys in table: `["extra_0", "extra_1"]`, available keys: `["value"]`"#
|
||||
);
|
||||
}
|
||||
|
||||
mod enum_unit {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn from_str() {
|
||||
assert_eq!(TheEnum::Plain, toml::from_str("\"Plain\"").unwrap());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn from_inline_table() {
|
||||
assert_eq!(TheEnum::Plain, toml::from_str("{ Plain = {} }").unwrap());
|
||||
assert_eq!(
|
||||
Val {
|
||||
val: TheEnum::Plain
|
||||
},
|
||||
toml::from_str("val = { Plain = {} }").unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn from_dotted_table() {
|
||||
assert_eq!(TheEnum::Plain, toml::from_str("[Plain]\n").unwrap());
|
||||
}
|
||||
}
|
||||
|
||||
mod enum_tuple {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn from_inline_table() {
|
||||
assert_eq!(
|
||||
TheEnum::Tuple(-123, true),
|
||||
toml::from_str("{ Tuple = { 0 = -123, 1 = true } }").unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
Val {
|
||||
val: TheEnum::Tuple(-123, true)
|
||||
},
|
||||
toml::from_str("val = { Tuple = { 0 = -123, 1 = true } }").unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn from_dotted_table() {
|
||||
assert_eq!(
|
||||
TheEnum::Tuple(-123, true),
|
||||
toml::from_str(
|
||||
r#"[Tuple]
|
||||
0 = -123
|
||||
1 = true
|
||||
"#
|
||||
)
|
||||
.unwrap()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
mod enum_newtype {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn from_inline_table() {
|
||||
assert_eq!(
|
||||
TheEnum::NewType("value".to_string()),
|
||||
toml::from_str(r#"{ NewType = "value" }"#).unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
Val {
|
||||
val: TheEnum::NewType("value".to_string()),
|
||||
},
|
||||
toml::from_str(r#"val = { NewType = "value" }"#).unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[ignore = "Unimplemented: https://github.com/alexcrichton/toml-rs/pull/264#issuecomment-431707209"]
|
||||
fn from_dotted_table() {
|
||||
assert_eq!(
|
||||
TheEnum::NewType("value".to_string()),
|
||||
toml::from_str(r#"NewType = "value""#).unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
Val {
|
||||
val: TheEnum::NewType("value".to_string()),
|
||||
},
|
||||
toml::from_str(
|
||||
r#"[val]
|
||||
NewType = "value"
|
||||
"#
|
||||
)
|
||||
.unwrap()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
mod enum_struct {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn from_inline_table() {
|
||||
assert_eq!(
|
||||
TheEnum::Struct { value: -123 },
|
||||
toml::from_str("{ Struct = { value = -123 } }").unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
Val {
|
||||
val: TheEnum::Struct { value: -123 }
|
||||
},
|
||||
toml::from_str("val = { Struct = { value = -123 } }").unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn from_dotted_table() {
|
||||
assert_eq!(
|
||||
TheEnum::Struct { value: -123 },
|
||||
toml::from_str(
|
||||
r#"[Struct]
|
||||
value = -123
|
||||
"#
|
||||
)
|
||||
.unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn from_nested_dotted_table() {
|
||||
assert_eq!(
|
||||
OuterStruct {
|
||||
inner: TheEnum::Struct { value: -123 }
|
||||
},
|
||||
toml::from_str(
|
||||
r#"[inner.Struct]
|
||||
value = -123
|
||||
"#
|
||||
)
|
||||
.unwrap()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
mod enum_array {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn from_inline_tables() {
|
||||
let toml_str = r#"
|
||||
enums = [
|
||||
{ Plain = {} },
|
||||
{ Tuple = { 0 = -123, 1 = true } },
|
||||
{ NewType = "value" },
|
||||
{ Struct = { value = -123 } }
|
||||
]"#;
|
||||
assert_eq!(
|
||||
Multi {
|
||||
enums: vec![
|
||||
TheEnum::Plain,
|
||||
TheEnum::Tuple(-123, true),
|
||||
TheEnum::NewType("value".to_string()),
|
||||
TheEnum::Struct { value: -123 },
|
||||
]
|
||||
},
|
||||
toml::from_str(toml_str).unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[ignore = "Unimplemented: https://github.com/alexcrichton/toml-rs/pull/264#issuecomment-431707209"]
|
||||
fn from_dotted_table() {
|
||||
let toml_str = r#"[[enums]]
|
||||
Plain = {}
|
||||
|
||||
[[enums]]
|
||||
Tuple = { 0 = -123, 1 = true }
|
||||
|
||||
[[enums]]
|
||||
NewType = "value"
|
||||
|
||||
[[enums]]
|
||||
Struct = { value = -123 }
|
||||
"#;
|
||||
assert_eq!(
|
||||
Multi {
|
||||
enums: vec![
|
||||
TheEnum::Plain,
|
||||
TheEnum::Tuple(-123, true),
|
||||
TheEnum::NewType("value".to_string()),
|
||||
TheEnum::Struct { value: -123 },
|
||||
]
|
||||
},
|
||||
toml::from_str(toml_str).unwrap()
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user