From 9d36ba1b36ab9a4e93395816acd83e81c7c62daf Mon Sep 17 00:00:00 2001 From: Yuval Shavit Date: Thu, 8 Aug 2024 21:12:20 -0400 Subject: [PATCH 1/4] require "chained" integ tests These are tests where things select themselves, to make sure the second one is superflous. --- build.rs | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/build.rs b/build.rs index f81eb5b..8ce21b8 100644 --- a/build.rs +++ b/build.rs @@ -44,9 +44,19 @@ fn generate_integ_test_cases(out_dir: &String) -> Result<(), String> { } }); + let mut found_chained_case = false; for case in spec_file_parsed.get_cases() { + found_chained_case |= case.case_name.eq("chained"); case.write_test_fn_to(out); } + if !found_chained_case { + out.writeln("#[test]"); + out.writeln("fn test() {"); + out.with_indent(|out| { + out.writeln("panic!(\"missing 'chained' test case\");"); + }); + out.writeln("}"); + } }); out.writeln("}"); From 4467820f7bd92a210931895f197040800aea6d59 Mon Sep 17 00:00:00 2001 From: Yuval Shavit Date: Thu, 8 Aug 2024 21:50:13 -0400 Subject: [PATCH 2/4] add various chained tests also, allow marking them as not needed; they're not always relevant to every toml file --- build.rs | 30 +++++++++++++++++++++------ tests/md_cases/link_placement.toml | 3 +++ tests/md_cases/links_references.toml | 4 ++++ tests/md_cases/matchers.toml | 2 ++ tests/md_cases/output_format.toml | 3 +++ tests/md_cases/select_exit_code.toml | 3 +++ tests/md_cases/select_html.toml | 7 +++++++ tests/md_cases/select_link.toml | 7 +++++++ tests/md_cases/select_lists.toml | 7 +++++++ tests/md_cases/select_paragraphs.toml | 7 +++++++ tests/md_cases/select_sections.toml | 9 ++++++++ 11 files changed, 76 insertions(+), 6 deletions(-) diff --git a/build.rs b/build.rs index 8ce21b8..f300604 100644 --- a/build.rs +++ b/build.rs @@ -33,6 +33,8 @@ fn generate_integ_test_cases(out_dir: &String) -> Result<(), String> { let spec_file_parsed: TestSpecFile = toml::from_str(&contents).map_err(|e| spec_file.err_string(e)).unwrap(); + let chained_needed = spec_file_parsed.chained.map(|ch| ch.needed).unwrap_or(true); + out.write("const MD: &str = indoc::indoc! {r#\""); out.with_indent(|out| { let mut iter = spec_file_parsed.given.md.trim().split('\n').peekable(); @@ -49,13 +51,14 @@ fn generate_integ_test_cases(out_dir: &String) -> Result<(), String> { found_chained_case |= case.case_name.eq("chained"); case.write_test_fn_to(out); } + + match (chained_needed, found_chained_case) { + (true, false) => Case::write_failing_test(out, "chained", "missing 'chained' test case"), + (false, true) => Case::write_failing_test(out, "chained__extra", "provided 'chained' test case even though it was marked as not needed"), + _ => {} + } + if !found_chained_case { - out.writeln("#[test]"); - out.writeln("fn test() {"); - out.with_indent(|out| { - out.writeln("panic!(\"missing 'chained' test case\");"); - }); - out.writeln("}"); } }); @@ -112,6 +115,7 @@ impl DirEntryHelper { struct TestSpecFile { given: TestGiven, expect: HashMap, + chained: Option, } #[derive(Deserialize)] @@ -127,6 +131,11 @@ struct TestExpect { ignore: Option, } +#[derive(Deserialize, Copy, Clone)] +struct Chained { + needed: bool, +} + impl TestSpecFile { fn get_cases(self) -> Vec { let mut results = Vec::with_capacity(self.expect.len()); @@ -153,6 +162,15 @@ struct Case { } impl Case { + fn write_failing_test(out: &mut Writer, name: &str, err_msg: &str) { + out.writeln("#[test]"); + out.writes(&["fn ", name, "() {"]); + out.with_indent(|out| { + out.writes(&["panic!(\"", err_msg, "\");"]); + }); + out.writeln("}"); + } + fn write_test_fn_to(&self, out: &mut Writer) { let fn_name = self.case_name.replace(|ch: char| !ch.is_alphanumeric(), "_"); if self.ignored { diff --git a/tests/md_cases/link_placement.toml b/tests/md_cases/link_placement.toml index 00a614a..e079c93 100644 --- a/tests/md_cases/link_placement.toml +++ b/tests/md_cases/link_placement.toml @@ -11,6 +11,9 @@ Some section text. [1]: https://example.com/interesting ''' +[chained] +needed = false + [expect."standard link placement"] cli_args = [] diff --git a/tests/md_cases/links_references.toml b/tests/md_cases/links_references.toml index a44e5a7..eafd1bb 100644 --- a/tests/md_cases/links_references.toml +++ b/tests/md_cases/links_references.toml @@ -16,6 +16,9 @@ md = ''' [shortcut link]: https://example.com/shortcut ''' +[chained] +needed = false + [expect."default"] cli_args = [] @@ -72,3 +75,4 @@ output = ''' - a [link with a title](https://example.com "my title") - a [link with a title that contains double-quotes](https://example.com 'my "alleged" title') ''' + diff --git a/tests/md_cases/matchers.toml b/tests/md_cases/matchers.toml index 2353f37..8f84c7f 100644 --- a/tests/md_cases/matchers.toml +++ b/tests/md_cases/matchers.toml @@ -6,6 +6,8 @@ md = ''' - lorem ipsum dolor sit amet. ''' +[chained] +needed = false [expect."bareword"] cli_args = ['- world '] # note: trailing space is ignored diff --git a/tests/md_cases/output_format.toml b/tests/md_cases/output_format.toml index 81447ff..96dfd93 100644 --- a/tests/md_cases/output_format.toml +++ b/tests/md_cases/output_format.toml @@ -5,6 +5,9 @@ Test _one_ [two][1] three. [1]: https://example.com/1 ''' +[chained] +needed = false + [expect."default"] cli_args = [] diff --git a/tests/md_cases/select_exit_code.toml b/tests/md_cases/select_exit_code.toml index 8cef450..2da331e 100644 --- a/tests/md_cases/select_exit_code.toml +++ b/tests/md_cases/select_exit_code.toml @@ -3,6 +3,9 @@ md = ''' [fizz](https://example.com/buzz) ''' +[chained] +needed = false + [expect."match and output"] cli_args = ["--link-format", "keep", "[]()"] diff --git a/tests/md_cases/select_html.toml b/tests/md_cases/select_html.toml index e022818..660b782 100644 --- a/tests/md_cases/select_html.toml +++ b/tests/md_cases/select_html.toml @@ -62,3 +62,10 @@ output = '''
span | ""'] +output = ''' + +''' \ No newline at end of file diff --git a/tests/md_cases/select_link.toml b/tests/md_cases/select_link.toml index 365d0c1..ed73179 100644 --- a/tests/md_cases/select_link.toml +++ b/tests/md_cases/select_link.toml @@ -36,3 +36,10 @@ output = ''' ![image alt text](https://example.com/hylas-and-nymphs.png)''' +[expect."chained"] +cli_args = ['[inline]() | [](example.com)'] +output = ''' +[an inline link][1] + +[1]: https://example.com/inline +''' diff --git a/tests/md_cases/select_lists.toml b/tests/md_cases/select_lists.toml index e3a9ed6..fa20c94 100644 --- a/tests/md_cases/select_lists.toml +++ b/tests/md_cases/select_lists.toml @@ -78,3 +78,10 @@ cli_args = ['1. [?]'] output = ''' 1. [ ] ordered tasks are possible, too ''' + + +[expect."chained"] +cli_args = ['- a point | - a point'] +output = ''' +- a point +''' diff --git a/tests/md_cases/select_paragraphs.toml b/tests/md_cases/select_paragraphs.toml index 4a6c6dc..642c497 100644 --- a/tests/md_cases/select_paragraphs.toml +++ b/tests/md_cases/select_paragraphs.toml @@ -65,3 +65,10 @@ cli_args = ["P : *"] expect_success = false output = ''' ''' + + +[expect."chained"] +cli_args = ['P: hello | P: world'] +output = ''' +Hello, world. +''' \ No newline at end of file diff --git a/tests/md_cases/select_sections.toml b/tests/md_cases/select_sections.toml index e5c226c..cd29e98 100644 --- a/tests/md_cases/select_sections.toml +++ b/tests/md_cases/select_sections.toml @@ -55,3 +55,12 @@ Hello, world. My second section. ''' + + +[expect."chained"] +cli_args = ['# bravo | # bravo'] +output = ''' +# Bravo + +My second section. +''' From cef20ac9eed7ba656d848271cd109012d83f97e7 Mon Sep 17 00:00:00 2001 From: Yuval Shavit Date: Thu, 8 Aug 2024 21:54:47 -0400 Subject: [PATCH 3/4] cargo fmt --- build.rs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/build.rs b/build.rs index f300604..8564781 100644 --- a/build.rs +++ b/build.rs @@ -54,12 +54,15 @@ fn generate_integ_test_cases(out_dir: &String) -> Result<(), String> { match (chained_needed, found_chained_case) { (true, false) => Case::write_failing_test(out, "chained", "missing 'chained' test case"), - (false, true) => Case::write_failing_test(out, "chained__extra", "provided 'chained' test case even though it was marked as not needed"), + (false, true) => Case::write_failing_test( + out, + "chained__extra", + "provided 'chained' test case even though it was marked as not needed", + ), _ => {} } - if !found_chained_case { - } + if !found_chained_case {} }); out.writeln("}"); From a24646af5aad3b148bc4e4a91c5f09e6dabddb8d Mon Sep 17 00:00:00 2001 From: Yuval Shavit Date: Thu, 8 Aug 2024 21:55:24 -0400 Subject: [PATCH 4/4] rm the TODO --- tests/md_cases/select_tables.toml | 2 -- 1 file changed, 2 deletions(-) diff --git a/tests/md_cases/select_tables.toml b/tests/md_cases/select_tables.toml index d23cd51..3280c28 100644 --- a/tests/md_cases/select_tables.toml +++ b/tests/md_cases/select_tables.toml @@ -74,8 +74,6 @@ output = ''' [expect."chained"] -# chaining onen all-cells selector into another; the second should be a noop -# TODO need to add "chained" tests for all! And maybe even require it in the build.rs code cli_args = [":-: * :-: * | :-: * :-: * | "] output = ''' | Name | Description | |