179 lines
4.8 KiB
Rust
179 lines
4.8 KiB
Rust
|
|
mod lex_tests {
|
||
|
|
use relish::ast::lex;
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_lex_basic_pair() {
|
||
|
|
let document = String::from("(hello 'world')");
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), document);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_lex_basic_list() {
|
||
|
|
let document = String::from("(hello 'world' 1 2 3)");
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), document);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_lex_complex_list() {
|
||
|
|
let document = String::from("(hello 'world' (1 2 (1 2 3)) 1 2 3)");
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), document);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_bad_symbol() {
|
||
|
|
let document = String::from("(as;dd)");
|
||
|
|
let output: &str = "Problem lexing document: \"Unparsable token: as;dd\"";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
print!("Bad token yielded: {}\n", tree.to_string());
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
assert_eq!(s, output);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_list_delim_in_str() {
|
||
|
|
let document = String::from("('(')");
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), document);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_empty_string() {
|
||
|
|
let document = String::from("('')");
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), document);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_unmatched_list_delim_flat() {
|
||
|
|
let document = String::from("(one two");
|
||
|
|
let output: &str = "Problem lexing document: \"Unmatched list delimiter in input\"";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
print!("Bad token yielded: {}\n", tree.to_string());
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
assert_eq!(s, output);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_unmatched_list_delim_complex() {
|
||
|
|
let document = String::from("(one two (three)");
|
||
|
|
let output: &str = "Problem lexing document: \"Unmatched list delimiter in input\"";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
print!("Bad token yielded: {}\n", tree);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
assert_eq!(s, output);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_comment() {
|
||
|
|
let document = String::from("#!/bin/relish\n(one two)");
|
||
|
|
let output: &str = "(one two)";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), output);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_postline_comment() {
|
||
|
|
let document = String::from("#!/bin/relish\n((one two)# another doc comment\n(three four))");
|
||
|
|
let output: &str = "((one two) (three four))";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), output.to_string());
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_inline_comment() {
|
||
|
|
let document = String::from("#!/bin/relish\n((one two)\n# another doc comment\nthree)");
|
||
|
|
let output: &str = "((one two) three)";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
assert_eq!(tree.to_string(), output.to_string());
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
print!("{}\n", s);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
#[test]
|
||
|
|
fn test_bad_token_list() {
|
||
|
|
let document = String::from("(one t(wo)");
|
||
|
|
let output: &str = "Problem lexing document: \"list started in middle of another token\"";
|
||
|
|
match lex(&document) {
|
||
|
|
Ok(tree) => {
|
||
|
|
print!("Bad token yielded: {}\n", tree);
|
||
|
|
assert!(false);
|
||
|
|
}
|
||
|
|
Err(s) => {
|
||
|
|
assert_eq!(s, output);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|