grass/tests/args.rs
2020-08-15 21:33:44 -04:00

216 lines
5.0 KiB
Rust

#[macro_use]
mod macros;
error!(
variable_after_varargs,
"@function foo($a..., $b) {\n @return $a;\n}\n", "Error: expected \")\"."
);
error!(
varargs_one_period,
"@function foo($a.) {\n @return $a;\n}\n", "Error: expected \".\"."
);
error!(
varargs_two_periods,
"@function foo($a..) {\n @return $a;\n}\n", "Error: expected \".\"."
);
test!(
mixin_varargs_are_comma_separated,
"@mixin foo($a...) {\n color: $a;\n}\n\na {\n @include foo(1, 2, 3, 4, 5);\n}\n",
"a {\n color: 1, 2, 3, 4, 5;\n}\n"
);
test!(
function_varargs_are_comma_separated,
"@function foo($a...) {\n @return $a;\n}\n\na {\n color: foo(1, 2, 3, 4, 5);\n}\n",
"a {\n color: 1, 2, 3, 4, 5;\n}\n"
);
test!(
default_args_are_lazily_evaluated,
"$da: a;\n\n@mixin foo($x: $da) {\n color: $x;\n}\n$da: b;\n\na {\n @include foo();\n}\n",
"a {\n color: b;\n}\n"
);
test!(
variable_being_subtracted,
"$index: 1;\n\n@function foo($a) {\n @return $a;\n}\n\na {\n color: foo($index - 1);\n}\n",
"a {\n color: 0;\n}\n"
);
test!(
parens_in_default_arg_value,
"@function foo($arg1: bar()) {\n @return true;\n}\n\na {\n color: foo();\n}\n",
"a {\n color: true;\n}\n"
);
test!(
self_referential_default_arg_value,
"@function foo($a, $b: $a) {\n @return $b;\n}\n\na {\n color: foo(2);\n}\n",
"a {\n color: 2;\n}\n"
);
test!(
arg_errors_are_lazy_for_if,
"a {\n color: if(false, unit(foo), red);\n}\n",
"a {\n color: red;\n}\n"
);
error!(
#[ignore = "expects incorrect char, '{'"]
nothing_after_open,
"a { color:rgb(; }", "Error: expected \")\"."
);
error!(
nothing_after_open_paren_in_fn_args,
"@function foo(", "Error: expected \")\"."
);
error!(
args_are_evaluated_eagerly,
"@function foo($a) {\n @return foo;\n}\n\na {\n color: foo(unit(bar));\n}\n",
"Error: $number: bar is not a number."
);
test!(
variable_is_only_hyphens,
"$--: red;
a {
color: foo($--);
}",
"a {\n color: foo(red);\n}\n"
);
test!(
no_space_after_colon_in_keyword_arg,
"@function foo($a) {
@return $a;
}
$b: red;
a {
color: foo($a:$b);
}",
"a {\n color: red;\n}\n"
);
test!(
comment_after_comma_in_func_args,
"@mixin a(
$foo,//foo
) {
color: $foo;
}
a {
@include a(red);
}",
"a {\n color: red;\n}\n"
);
test!(
filter_one_arg,
"a {\n color: foo(a=a);\n}\n",
"a {\n color: foo(a=a);\n}\n"
);
test!(
filter_two_args,
"a {\n color: foo(a=a, b=b);\n}\n",
"a {\n color: foo(a=a, b=b);\n}\n"
);
test!(
filter_whitespace,
"a {\n color: foo( a = a );\n}\n",
"a {\n color: foo(a=a);\n}\n"
);
test!(
filter_whitespace_list,
"a {\n color: foo( A a = a );\n}\n",
"a {\n color: foo(A a=a);\n}\n"
);
test!(
filter_function_call,
"a {\n color: foo(hue(green)=hue(green));\n}\n",
"a {\n color: foo(120deg=120deg);\n}\n"
);
test!(
filter_addition,
"a {\n color: foo(1+1=1+1);\n}\n",
"a {\n color: foo(2=2);\n}\n"
);
test!(
filter_splat_of_single_value,
"a {\n color: foo(a=a...);\n}\n",
"a {\n color: foo(a=a);\n}\n"
);
test!(
filter_splat_of_list,
"a {\n color: foo(a=[a, b]...);\n}\n",
"a {\n color: foo(a=[a, b]);\n}\n"
);
test!(
filter_both_null,
"a {\n color: foo(null=null);\n}\n",
"a {\n color: foo(=);\n}\n"
);
error!(
filter_splat_missing_third_period,
"a {\n color: foo(1 + 1 = a..);\n}\n", "Error: expected \".\"."
);
error!(
filter_invalid_css_value,
"a {\n color: foo((a: b)=a);\n}\n", "Error: (a: b) isn't a valid CSS value."
);
error!(
filter_nothing_before_equal,
"a {\n color: foo(=a);\n}\n", "Error: Expected expression."
);
error!(
filter_nothing_after_equal,
"a {\n color: foo(a=);\n}\n", "Error: Expected expression."
);
error!(
filter_equal_is_last_char,
"a {\n color: foo(a=", "Error: Expected expression."
);
error!(
filter_value_after_equal_is_last_char,
"a {\n color: foo(a=a", "Error: expected \")\"."
);
error!(
unclosed_paren_in_nested_args,
"a { color: a(b(red); }", "Error: expected \")\"."
);
error!(
filter_rhs_missing_closing_paren,
"a { color: lighten(red=(green); }", "Error: expected \")\"."
);
test!(
space_after_loud_comment,
"@mixin foo($x) {
color: $x;
}
a {
@include foo($x /* blah */ : kwd-y);
}",
"a {\n color: kwd-y;\n}\n"
);
test!(
quoted_string_as_default_argument_value,
r#"@function foo($font-family: 'Roboto, "Helvetica Neue", sans-serif') {
@return $font-family;
}
a {
color: foo();
}"#,
"a {\n color: 'Roboto, \"Helvetica Neue\", sans-serif';\n}\n"
);
test!(
args_do_not_affect_existing_outer_variables,
"@mixin mixin2($a) {
color: $a;
}
@mixin mixin1($a) {
color: $a;
@include mixin2(bar);
color: $a;
}
a {
@include mixin1(foo);
}",
"a {\n color: foo;\n color: bar;\n color: foo;\n}\n"
);