add tests for compressed output

This commit is contained in:
Connor Skees 2021-07-10 12:52:41 -04:00
parent a5f3823521
commit bc49c2b8ee
3 changed files with 105 additions and 9 deletions

View File

@ -248,7 +248,7 @@ impl Css {
let out = unsafe { String::from_utf8_unchecked(buf) }; let out = unsafe { String::from_utf8_unchecked(buf) };
Ok(if show_charset { Ok(if show_charset {
match style { match style {
OutputStyle::Compressed => format!("@charset \"UTF-8\";{}", out), OutputStyle::Compressed => format!("\u{FEFF}{}", out),
OutputStyle::Expanded => format!("@charset \"UTF-8\";\n{}", out), OutputStyle::Expanded => format!("@charset \"UTF-8\";\n{}", out),
} }
} else { } else {
@ -311,9 +311,7 @@ impl Formatter for CompressedFormatter {
self.write_block_entry(buf, &styles)?; self.write_block_entry(buf, &styles)?;
write!(buf, "}}")?; write!(buf, "}}")?;
} }
Toplevel::MultilineComment(s) => { Toplevel::MultilineComment(..) => continue,
write!(buf, "/*{}*/", s)?;
}
Toplevel::Import(s) => { Toplevel::Import(s) => {
write!(buf, "@import {};", s)?; write!(buf, "@import {};", s)?;
} }
@ -411,22 +409,26 @@ impl CompressedFormatter {
fn write_block_entry(&self, buf: &mut Vec<u8>, styles: &[BlockEntry]) -> SassResult<()> { fn write_block_entry(&self, buf: &mut Vec<u8>, styles: &[BlockEntry]) -> SassResult<()> {
let mut styles = styles.iter(); let mut styles = styles.iter();
if let Some(style) = styles.next() {
while let Some(style) = styles.next() {
match style { match style {
BlockEntry::Style(s) => { BlockEntry::Style(s) => {
let value = s.value.node.to_css_string(s.value.span)?; let value = s.value.node.to_css_string(s.value.span)?;
write!(buf, "{}:{}", s.property, value)?; write!(buf, "{}:{}", s.property, value)?;
break;
} }
BlockEntry::MultilineComment(s) => write!(buf, "/*{}*/", s)?, BlockEntry::MultilineComment(..) => continue,
} }
} }
for style in styles { for style in styles {
match style { match style {
BlockEntry::Style(s) => { BlockEntry::Style(s) => {
let value = s.value.node.to_css_string(s.value.span)?; let value = s.value.node.to_css_string(s.value.span)?;
write!(buf, ";{}:{}", s.property, value)?; write!(buf, ";{}:{}", s.property, value)?;
} }
BlockEntry::MultilineComment(s) => write!(buf, "/*{}*/", s)?, BlockEntry::MultilineComment(..) => continue,
} }
} }
Ok(()) Ok(())

88
tests/compressed.rs Normal file
View File

@ -0,0 +1,88 @@
#[macro_use]
mod macros;
test!(
compresses_simple_rule,
"a {\n color: red;\n}\n",
"a{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
compresses_rule_with_many_styles,
"a {\n color: red;\n color: green;\n color: blue;\n}\n",
"a{color:red;color:green;color:blue}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
#[ignore = "we don't support compressed values"]
strips_the_leading_zero,
"a {\n color: 0.5;\n}\n",
"a{color:.5}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
compresses_media_rule,
"@media foo {\n a {\n color: red;\n }\n}\n",
"@media foo{a{color:red}}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
compresses_selector_with_space_after_comma,
"a, b {\n color: red;\n}\n",
"a,b{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
compresses_selector_with_newline_after_comma,
"a,\nb {\n color: red;\n}\n",
"a,b{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
emits_bom_when_compressed,
"a {\n color: 👭;\n}\n",
"\u{FEFF}a{color:👭}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_space_between_selector_combinator,
"a > b {\n color: red;\n}\n",
"a>b{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_before_style,
"a {\n /* abc */\n color: red;\n}\n",
"a{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_after_style,
"a {\n color: red;\n /* abc */\n}\n",
"a{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_between_styles,
"a {\n color: red;\n /* abc */\n color: green;\n}\n",
"a{color:red;color:green}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_before_ruleset,
"/* abc */a {\n color: red;\n}\n",
"a{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_after_ruleset,
"a {\n color: red;\n}\n/* abc */",
"a{color:red}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);
test!(
removes_multiline_comment_between_rulesets,
"a {\n color: red;\n}\n/* abc */b {\n color: green;\n}\n",
"a{color:red}b{color:green}",
grass::Options::default().style(grass::OutputStyle::Compressed)
);

View File

@ -1,11 +1,11 @@
#[macro_export] #[macro_export]
macro_rules! test { macro_rules! test {
($( #[$attr:meta] ),*$func:ident, $input:expr, $output:expr) => { (@base $( #[$attr:meta] ),*$func:ident, $input:expr, $output:expr, $options:expr) => {
$(#[$attr])* $(#[$attr])*
#[test] #[test]
#[allow(non_snake_case)] #[allow(non_snake_case)]
fn $func() { fn $func() {
let sass = grass::from_string($input.to_string(), &grass::Options::default()) let sass = grass::from_string($input.to_string(), &$options)
.expect(concat!("failed to parse on ", $input)); .expect(concat!("failed to parse on ", $input));
assert_eq!( assert_eq!(
String::from($output), String::from($output),
@ -13,6 +13,12 @@ macro_rules! test {
); );
} }
}; };
($( #[$attr:meta] ),*$func:ident, $input:expr, $output:expr, $options:expr) => {
test!(@base $(#[$attr])* $func, $input, $output, $options);
};
($( #[$attr:meta] ),*$func:ident, $input:expr, $output:expr) => {
test!(@base $(#[$attr])* $func, $input, $output, grass::Options::default());
};
} }
/// Verify the error *message* /// Verify the error *message*