54 lines
1.8 KiB
Rust
54 lines
1.8 KiB
Rust
#[test]
|
|
#[cfg(not(feature = "unbounded"))]
|
|
fn array_recursion_limit() {
|
|
let depths = [(1, true), (20, true), (300, false)];
|
|
for (depth, is_ok) in depths {
|
|
let input = format!("x={}{}", &"[".repeat(depth), &"]".repeat(depth));
|
|
let document = input.parse::<toml_edit::Document>();
|
|
assert_eq!(document.is_ok(), is_ok, "depth: {}", depth);
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
#[cfg(not(feature = "unbounded"))]
|
|
fn inline_table_recursion_limit() {
|
|
let depths = [(1, true), (20, true), (300, false)];
|
|
for (depth, is_ok) in depths {
|
|
let input = format!("x={}true{}", &"{ x = ".repeat(depth), &"}".repeat(depth));
|
|
let document = input.parse::<toml_edit::Document>();
|
|
assert_eq!(document.is_ok(), is_ok, "depth: {}", depth);
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
#[cfg(not(feature = "unbounded"))]
|
|
fn table_key_recursion_limit() {
|
|
let depths = [(1, true), (20, true), (300, false)];
|
|
for (depth, is_ok) in depths {
|
|
let input = format!("[x{}]", &".x".repeat(depth));
|
|
let document = input.parse::<toml_edit::Document>();
|
|
assert_eq!(document.is_ok(), is_ok, "depth: {}", depth);
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
#[cfg(not(feature = "unbounded"))]
|
|
fn dotted_key_recursion_limit() {
|
|
let depths = [(1, true), (20, true), (300, false)];
|
|
for (depth, is_ok) in depths {
|
|
let input = format!("x{} = true", &".x".repeat(depth));
|
|
let document = input.parse::<toml_edit::Document>();
|
|
assert_eq!(document.is_ok(), is_ok, "depth: {}", depth);
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
#[cfg(not(feature = "unbounded"))]
|
|
fn inline_dotted_key_recursion_limit() {
|
|
let depths = [(1, true), (20, true), (300, false)];
|
|
for (depth, is_ok) in depths {
|
|
let input = format!("x = {{ x{} = true }}", &".x".repeat(depth));
|
|
let document = input.parse::<toml_edit::Document>();
|
|
assert_eq!(document.is_ok(), is_ok, "depth: {}", depth);
|
|
}
|
|
}
|