2021-07-19 23:59:03 -07:00
|
|
|
mod eval_tests {
|
2023-02-17 22:10:54 -08:00
|
|
|
use relish::ast::{eval, lex, SYM_TABLE};
|
|
|
|
|
use relish::ast::{Args, Symbol, Ctr, Seg, ValueType, UserFn};
|
2021-06-22 00:50:37 -07:00
|
|
|
|
|
|
|
|
// TODO: write generalized testing routine on top of list of inputs
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_singlet() {
|
|
|
|
|
let test_doc = "(1)".to_string();
|
2023-02-17 22:10:54 -08:00
|
|
|
match lex(&test_doc) {
|
2021-06-22 00:50:37 -07:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Lexing error: {}\n", e);
|
|
|
|
|
assert!(false)
|
2022-01-16 22:02:40 -08:00
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
Ok(ref initial_ast) => match eval(initial_ast, true, true) {
|
2022-01-16 22:02:40 -08:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Evaluation error: {}\n", e);
|
|
|
|
|
assert!(false)
|
|
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2022-01-16 22:02:40 -08:00
|
|
|
Ok(reduced) => {
|
2023-02-17 22:10:54 -08:00
|
|
|
assert_eq!(reduced.to_string(), test_doc)
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
2022-01-16 22:02:40 -08:00
|
|
|
},
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_embedded_lists_no_funcs() {
|
|
|
|
|
let test_doc = "(1 (1 2 3 4 5) 5)".to_string();
|
|
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
match lex(&test_doc) {
|
2021-06-22 00:50:37 -07:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Lexing error: {}\n", e);
|
|
|
|
|
assert!(false)
|
2022-01-16 22:02:40 -08:00
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
Ok(initial_ast) => match eval(&initial_ast, true, true) {
|
2022-01-16 22:02:40 -08:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Evaluation error: {}\n", e);
|
|
|
|
|
assert!(false)
|
|
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2022-01-16 22:02:40 -08:00
|
|
|
Ok(reduced) => {
|
2023-02-17 22:10:54 -08:00
|
|
|
assert_eq!(reduced.to_string(), test_doc)
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
2022-01-16 22:02:40 -08:00
|
|
|
},
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_function_call() {
|
2023-02-17 22:10:54 -08:00
|
|
|
let mut table_handle = SYM_TABLE.lock().unwrap();
|
2021-06-22 00:50:37 -07:00
|
|
|
let test_doc = "('one' (echo 'unwrap_me'))".to_string();
|
|
|
|
|
let output = "('one' 'unwrap_me')";
|
2023-02-17 22:10:54 -08:00
|
|
|
let test_external_func: Symbol = Symbol {
|
2021-06-22 00:50:37 -07:00
|
|
|
name: String::from("echo"),
|
|
|
|
|
args: Args::Lazy(1),
|
2023-02-17 22:10:54 -08:00
|
|
|
has_undefined_symbols: false,
|
|
|
|
|
value: ValueType::FuncForm( UserFn {
|
2022-01-16 22:02:40 -08:00
|
|
|
arg_syms: vec!["input".to_string()],
|
2023-02-17 22:10:54 -08:00
|
|
|
ast: Box::new(Seg::from(
|
|
|
|
|
Box::new(Ctr::Seg(Seg::from(
|
|
|
|
|
Box::from(Ctr::Symbol("input".to_string())),
|
|
|
|
|
Box::from(Ctr::None)))),
|
|
|
|
|
Box::new(Ctr::None),
|
|
|
|
|
)),
|
2022-01-16 22:02:40 -08:00
|
|
|
}),
|
2021-06-22 00:50:37 -07:00
|
|
|
};
|
|
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
table_handle.insert(String::from("echo"), test_external_func);
|
|
|
|
|
match lex(&test_doc) {
|
2021-06-22 00:50:37 -07:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Lexing error: {}\n", e);
|
|
|
|
|
assert!(false)
|
2022-01-16 22:02:40 -08:00
|
|
|
}
|
|
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
Ok(initial_ast) => match eval(&initial_ast, true, true) {
|
2022-01-16 22:02:40 -08:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Evaluation error: {}\n", e);
|
|
|
|
|
assert!(false)
|
|
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2022-01-16 22:02:40 -08:00
|
|
|
Ok(reduced) => {
|
2023-02-17 22:10:54 -08:00
|
|
|
assert_eq!(reduced.to_string(), output)
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
2022-01-16 22:02:40 -08:00
|
|
|
},
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_embedded_func_calls() {
|
2023-02-17 22:10:54 -08:00
|
|
|
let mut table_handle = SYM_TABLE.lock().unwrap();
|
2021-07-19 23:59:03 -07:00
|
|
|
let test_doc = "('one' (echo (echo 'unwrap_me')))".to_string();
|
|
|
|
|
let output = "('one' 'unwrap_me')";
|
2023-02-17 22:10:54 -08:00
|
|
|
let test_external_func: Symbol = Symbol{
|
2021-07-19 23:59:03 -07:00
|
|
|
name: String::from("echo"),
|
|
|
|
|
args: Args::Lazy(1),
|
2023-02-17 22:10:54 -08:00
|
|
|
has_undefined_symbols: false,
|
|
|
|
|
value: ValueType::FuncForm( UserFn {
|
2022-01-16 22:02:40 -08:00
|
|
|
arg_syms: vec!["input".to_string()],
|
2023-02-17 22:10:54 -08:00
|
|
|
ast: Box::new(Seg::from(
|
|
|
|
|
Box::new(Ctr::Seg(Seg::from(
|
|
|
|
|
Box::from(Ctr::Symbol("input".to_string())),
|
|
|
|
|
Box::from(Ctr::None)))),
|
|
|
|
|
Box::new(Ctr::None),
|
|
|
|
|
)),
|
2022-01-16 22:02:40 -08:00
|
|
|
}),
|
2021-07-19 23:59:03 -07:00
|
|
|
};
|
|
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
table_handle.insert(String::from("echo"), test_external_func);
|
|
|
|
|
match lex(&test_doc) {
|
2021-06-22 00:50:37 -07:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Lexing error: {}\n", e);
|
|
|
|
|
assert!(false)
|
2022-01-16 22:02:40 -08:00
|
|
|
}
|
|
|
|
|
|
2023-02-17 22:10:54 -08:00
|
|
|
Ok(initial_ast) => match eval(&initial_ast, true, true) {
|
2022-01-16 22:02:40 -08:00
|
|
|
Err(e) => {
|
|
|
|
|
println!("Evaluation error: {}\n", e);
|
|
|
|
|
assert!(false)
|
|
|
|
|
}
|
2021-06-22 00:50:37 -07:00
|
|
|
|
2022-01-16 22:02:40 -08:00
|
|
|
Ok(reduced) => {
|
2023-02-17 22:10:54 -08:00
|
|
|
assert_eq!(reduced.to_string(), output)
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
2022-01-16 22:02:40 -08:00
|
|
|
},
|
2021-06-22 00:50:37 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-19 23:59:03 -07:00
|
|
|
/*
|
2021-06-22 00:50:37 -07:00
|
|
|
#[test]
|
|
|
|
|
fn eval_bad_vars() {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_bad_func() {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn eval_verify_all_elems_cloned() {
|
|
|
|
|
}*/
|
|
|
|
|
}
|