From bd2185761c2b750479bad6976aa1ab177ec0331d Mon Sep 17 00:00:00 2001 From: MichaIng Date: Wed, 8 Jan 2025 14:03:25 +0700 Subject: [PATCH] fix: do not fail on empty # and #top fragments The empty "#" and "#top" fragments are always valid without related HTML element. Browser will scroll to the top of the page. Hence lychee must not fail on those. Signed-off-by: MichaIng --- fixtures/fragments/file.html | 2 ++ fixtures/fragments/file1.md | 8 ++++++++ lychee-bin/tests/cli.rs | 6 ++++-- lychee-lib/src/utils/fragment_checker.rs | 6 ++++-- 4 files changed, 18 insertions(+), 4 deletions(-) diff --git a/fixtures/fragments/file.html b/fixtures/fragments/file.html index 5ff181f737..8e0f62d5d8 100644 --- a/fixtures/fragments/file.html +++ b/fixtures/fragments/file.html @@ -22,6 +22,8 @@ back to Upper-ÄÖö
back to öüä encoded
doesn't exist
+ To the top
+ To the top alt
diff --git a/fixtures/fragments/file1.md b/fixtures/fragments/file1.md index 69af62f4f6..4e315ec804 100644 --- a/fixtures/fragments/file1.md +++ b/fixtures/fragments/file1.md @@ -54,4 +54,12 @@ Therefore we put the test into a code block for now to prevent false positives. [Link to umlauts wrong case](#fünf-sÜße-Äpfel) [Link to umlauts with percent encoding](#f%C3%BCnf-s%C3%BC%C3%9Fe-%C3%A4pfel) +# To top fragments + +The empty "#" and "#top" fragments are always valid +without related HTML element. Browser will scroll to the top of the page. + +[Link to top of file2](file2.md#) +[Alternative link to top of file2](file2.md#top) + ##### Lets wear a hat: être diff --git a/lychee-bin/tests/cli.rs b/lychee-bin/tests/cli.rs index 5479d37ae8..55fc6dfa8e 100644 --- a/lychee-bin/tests/cli.rs +++ b/lychee-bin/tests/cli.rs @@ -1834,8 +1834,10 @@ mod cli { .stderr(contains( "fixtures/fragments/file1.md#kebab-case-fragment-1", )) - .stdout(contains("21 Total")) - .stdout(contains("17 OK")) + .stderr(contains("fixtures/fragments/file.html#top")) + .stderr(contains("fixtures/fragments/file2.md#top")) + .stdout(contains("25 Total")) + .stdout(contains("21 OK")) // 4 failures because of missing fragments .stdout(contains("4 Errors")); } diff --git a/lychee-lib/src/utils/fragment_checker.rs b/lychee-lib/src/utils/fragment_checker.rs index 1cc6c772c8..b1c323db38 100644 --- a/lychee-lib/src/utils/fragment_checker.rs +++ b/lychee-lib/src/utils/fragment_checker.rs @@ -63,8 +63,10 @@ impl FragmentChecker { Entry::Vacant(entry) => { let content = fs::read_to_string(path).await?; let file_frags = extractor(&content); - let contains_fragment = - file_frags.contains(fragment) || file_frags.contains(&fragment_decoded as &str); + let contains_fragment = fragment.is_empty() + || fragment == "top" + || file_frags.contains(fragment) + || file_frags.contains(&fragment_decoded as &str); entry.insert(file_frags); Ok(contains_fragment) }