blob: 7b9b9e34550a2e40c10204562d84f0064e6bb646 (
plain) (
tree)
|
|
use std::ffi::OsString;
use clap::Parser;
use expect_test::expect;
use tvix_cli::init_io_handle;
macro_rules! test_repl {
($name:ident() {$($send:expr => $expect:expr;)*}) => {
#[test]
fn $name() {
let tokio_runtime = tokio::runtime::Runtime::new().unwrap();
let args = tvix_cli::Args::parse_from(vec![
OsString::from("tvix"),
OsString::from("--nix-search-path"),
OsString::from("nixpkgs=/tmp"),
]);
let mut repl = tvix_cli::Repl::new(init_io_handle(&tokio_runtime, &args), &args);
$({
let result = repl.send($send.into());
$expect.assert_eq(result.output())
;
})*
}
}
}
test_repl!(simple_expr_eval() {
"1" => expect![[r#"
=> 1 :: int
"#]];
});
test_repl!(multiline_input() {
"{ x = 1; " => expect![[""]];
"y = 2; }" => expect![[r#"
=> { x = 1; y = 2; } :: set
"#]];
});
test_repl!(bind_literal() {
"x = 1" => expect![[""]];
"x" => expect![[r#"
=> 1 :: int
"#]];
});
test_repl!(bind_lazy() {
"x = { z = 1; }" => expect![[""]];
"x" => expect![[r#"
=> { z = 1; } :: set
"#]];
"x.z" => expect![[r#"
=> 1 :: int
"#]];
"x.z" => expect![[r#"
=> 1 :: int
"#]];
});
test_repl!(bind_lazy_errors() {
r#"x = (_: "x" + 1)"# => expect![[""]];
"x null" => expect![[""]];
});
test_repl!(bind_referencing_import() {
"six = import ./tests/six.nix {}" => expect![[""]];
"six.six" => expect![[r#"
=> 6 :: int
"#]];
"imported = import ./tests/import.nix" => expect![[""]];
"(imported {}).six" => expect![[r#"
=> 6 :: int
"#]];
});
test_repl!(deep_print() {
"builtins.map (x: x + 1) [ 1 2 3 ]" => expect![[r#"
=> [ <CODE> <CODE> <CODE> ] :: list
"#]];
":p builtins.map (x: x + 1) [ 1 2 3 ]" => expect![[r#"
=> [ 2 3 4 ] :: list
"#]];
});
test_repl!(explain() {
":d { x = 1; y = [ 2 3 4 ]; }" => expect![[r#"
=> a 2-item attribute set
"#]];
});
test_repl!(reference_nix_path() {
"<nixpkgs>" => expect![[r#"
=> /tmp :: path
"#]];
"<nixpkgs>" => expect![[r#"
=> /tmp :: path
"#]];
});
|