|
1 |
| -// This test ensures that all items from `foo` are correctly generated into the `redirect-map.json` |
2 |
| -// file with `--generate-redirect-map` rustdoc option. |
3 |
| - |
4 |
| -use std::path::Path; |
5 |
| - |
| 1 | +use run_make_support::path_helpers::read_dir_entries_recursive; |
6 | 2 | use run_make_support::rfs::read_to_string;
|
7 |
| -use run_make_support::{path, rustdoc, serde_json}; |
| 3 | +use run_make_support::{jzon, rustdoc}; |
8 | 4 |
|
9 | 5 | fn main() {
|
10 | 6 | let out_dir = "out";
|
11 |
| - let crate_name = "foo"; |
12 | 7 | rustdoc()
|
13 | 8 | .input("foo.rs")
|
14 |
| - .crate_name(crate_name) |
15 | 9 | .arg("-Zunstable-options")
|
16 | 10 | .arg("--generate-redirect-map")
|
17 | 11 | .out_dir(&out_dir)
|
18 | 12 | .run();
|
19 | 13 |
|
20 |
| - let generated = read_to_string(path(out_dir).join(crate_name).join("redirect-map.json")); |
21 |
| - let expected = read_to_string("expected.json"); |
22 |
| - let generated: serde_json::Value = |
23 |
| - serde_json::from_str(&generated).expect("failed to parse JSON"); |
24 |
| - let expected: serde_json::Value = |
25 |
| - serde_json::from_str(&expected).expect("failed to parse JSON"); |
26 |
| - let expected = expected.as_object().unwrap(); |
| 14 | + let mut found_file = false; |
| 15 | + read_dir_entries_recursive(&out_dir, |path| { |
| 16 | + if !found_file |
| 17 | + && path.is_file() |
| 18 | + && path.file_name().map(|name| name == "redirect-map.json").unwrap_or(false) |
| 19 | + { |
| 20 | + found_file = true; |
| 21 | + let generated = read_to_string(path); |
| 22 | + let expected = read_to_string("expected.json"); |
| 23 | + let generated = jzon::parse(&generated).expect("failed to parse JSON"); |
| 24 | + let expected = jzon::parse(&expected).expect("failed to parse JSON"); |
27 | 25 |
|
28 |
| - let mut differences = Vec::new(); |
29 |
| - for (key, expected_value) in expected.iter() { |
30 |
| - match generated.get(key) { |
31 |
| - Some(value) => { |
32 |
| - if expected_value != value { |
33 |
| - differences.push(format!( |
34 |
| - "values for key `{key}` don't match: `{expected_value:?}` != `{value:?}`" |
35 |
| - )); |
| 26 | + let mut differences = Vec::new(); |
| 27 | + for (key, expected_value) in expected.entries() { |
| 28 | + match generated.get(key) { |
| 29 | + Some(value) => { |
| 30 | + if expected_value != value { |
| 31 | + differences.push(format!("values for key `{key}` don't match")); |
| 32 | + } |
| 33 | + } |
| 34 | + None => differences.push(format!("missing key `{key}`")), |
| 35 | + } |
| 36 | + } |
| 37 | + for (key, data) in generated.entries() { |
| 38 | + if !expected.has_key(key) { |
| 39 | + differences |
| 40 | + .push(format!("Extra data not expected: key: `{key}`, data: `{data}`")); |
36 | 41 | }
|
37 | 42 | }
|
38 |
| - None => differences.push(format!("missing key `{key}`")), |
39 |
| - } |
40 |
| - } |
41 |
| - for (key, data) in generated.as_object().unwrap().iter() { |
42 |
| - if !expected.contains_key(key) { |
43 |
| - differences.push(format!("Extra data not expected: key: `{key}`, data: `{data}`")); |
44 |
| - } |
45 |
| - } |
46 | 43 |
|
47 |
| - if !differences.is_empty() { |
48 |
| - eprintln!("Found differences in JSON files:"); |
49 |
| - for diff in differences { |
50 |
| - eprintln!("=> {diff}"); |
| 44 | + if !differences.is_empty() { |
| 45 | + eprintln!("Found differences in JSON files:"); |
| 46 | + for diff in differences { |
| 47 | + eprintln!("=> {diff}"); |
| 48 | + } |
| 49 | + std::process::exit(1); |
| 50 | + } |
51 | 51 | }
|
52 |
| - panic!("Found differences in JSON files"); |
| 52 | + }); |
| 53 | + |
| 54 | + if !found_file { |
| 55 | + panic!("`redirect-map.json` file was not found"); |
53 | 56 | }
|
54 | 57 | }
|
0 commit comments