lib-laddertypes/src/test/lnf.rs

57 lines
1.8 KiB
Rust
Raw Normal View History

2025-02-04 14:34:55 +01:00
use crate::{dict::{BimapTypeDict}, parser::*};
2023-10-01 17:10:40 +02:00
#[test]
2023-10-02 18:48:04 +02:00
fn test_flat() {
2025-02-04 14:34:55 +01:00
let mut dict = BimapTypeDict::new();
2023-10-02 18:48:04 +02:00
assert!( dict.parse("A").expect("parse error").is_flat() );
assert!( dict.parse("10").expect("parse error").is_flat() );
assert!( dict.parse("'x'").expect("parse error").is_flat() );
assert!( dict.parse("<A B 23>").expect("parse error").is_flat() );
assert!( dict.parse("<A <B C 'x' D>>").expect("parse error").is_flat() );
assert!( ! dict.parse("A~B").expect("parse error").is_flat() );
assert!( ! dict.parse("<A B~C>").expect("parse error").is_flat() );
assert!( ! dict.parse("<A <B C~X D>>").expect("parse error").is_flat() );
}
#[test]
fn test_normalize() {
2025-02-04 14:34:55 +01:00
let mut dict = BimapTypeDict::new();
2023-10-02 18:48:04 +02:00
assert_eq!(
dict.parse("A~B~C").expect("parse error").normalize(),
dict.parse("A~B~C").expect("parse errror"),
);
assert_eq!(
dict.parse("<A B>~C").expect("parse error").normalize(),
dict.parse("<A B>~C").expect("parse errror"),
);
assert_eq!(
dict.parse("<A B~C>").expect("parse error").normalize(),
dict.parse("<A B>~<A C>").expect("parse errror"),
);
assert_eq!(
dict.parse("<A B~C D~E>").expect("parse error").normalize(),
dict.parse("<A B D>~<A C D>~<A C E>").expect("parse errror"),
);
assert_eq!(
dict.parse("<Seq <Digit 10>~Char>").expect("parse error").normalize(),
dict.parse("<Seq <Digit 10>>~<Seq Char>").expect("parse errror"),
);
assert_eq!(
dict.parse("<A <B C~D~E> F~G H H>").expect("parse error").normalize(),
dict.parse("<A <B C> F H H>
~<A <B D> F H H>
~<A <B E> F H H>
~<A <B E> G H H>").expect("parse errror"),
);
2023-10-01 17:10:40 +02:00
}