Skip to content

Commit

Permalink
Skip link checking for URL with prefix in config (#846)
Browse files Browse the repository at this point in the history
  • Loading branch information
TjeuKayim authored and Keats committed Nov 25, 2019
1 parent 450451b commit 6a2d2c8
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 11 deletions.
27 changes: 24 additions & 3 deletions components/config/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -91,13 +91,15 @@ type TranslateTerm = HashMap<String, String>;
#[derive(Clone, Debug, PartialEq, Eq, Serialize, Deserialize)]
#[serde(default)]
pub struct LinkChecker {
/// Skip link checking for these URL prefixes
pub skip_prefixes: Vec<String>,
/// Skip anchor checking for these URL prefixes
pub skip_anchor_prefixes: Vec<String>,
}

impl Default for LinkChecker {
fn default() -> LinkChecker {
LinkChecker { skip_anchor_prefixes: Vec::new() }
LinkChecker { skip_prefixes: Vec::new(), skip_anchor_prefixes: Vec::new() }
}
}

Expand Down Expand Up @@ -589,10 +591,29 @@ skip_anchor_prefixes = [
"#;

let config = Config::parse(config_str).unwrap();
let v = config.link_checker.skip_anchor_prefixes;
assert_eq!(
v,
config.link_checker.skip_anchor_prefixes,
vec!["https://caniuse.com/#feat=", "https://github.com/rust-lang/rust/blob/"]
);
}

#[test]
fn link_checker_skip_prefixes() {
let config_str = r#"
title = "My site"
base_url = "example.com"
[link_checker]
skip_prefixes = [
"http://[2001:db8::]/",
"https://www.example.com/path",
]
"#;

let config = Config::parse(config_str).unwrap();
assert_eq!(
config.link_checker.skip_prefixes,
vec!["http://[2001:db8::]/", "https://www.example.com/path",]
);
}
}
1 change: 1 addition & 0 deletions components/link_checker/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -198,6 +198,7 @@ mod tests {
#[test]
fn skip_anchor_prefixes() {
let config = LinkChecker {
skip_prefixes: vec![],
skip_anchor_prefixes: vec!["https://github.com/rust-lang/rust/blob/".to_owned()],
};

Expand Down
9 changes: 9 additions & 0 deletions components/site/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -399,6 +399,15 @@ impl Site {
all_links
.par_iter()
.filter_map(|(page_path, link)| {
if self
.config
.link_checker
.skip_prefixes
.iter()
.any(|prefix| link.starts_with(prefix))
{
return None;
}
let res = check_url(&link, &self.config.link_checker);
if res.is_valid() {
None
Expand Down
18 changes: 10 additions & 8 deletions components/site/tests/site.rs
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,10 @@ fn can_build_site_without_live_reload() {
assert!(file_exists!(public, "nested_sass/scss.css"));

// no live reload code
assert_eq!(file_contains!(public, "index.html", "/livereload.js?port=1112&amp;mindelay=10"), false);
assert_eq!(
file_contains!(public, "index.html", "/livereload.js?port=1112&amp;mindelay=10"),
false
);

// Both pages and sections are in the sitemap
assert!(file_contains!(
Expand Down Expand Up @@ -470,11 +473,7 @@ fn can_build_site_with_pagination_for_index() {
"page/1/index.html",
"http-equiv=\"refresh\" content=\"0;url=https://replace-this-with-your-url.com/\""
));
assert!(file_contains!(
public,
"page/1/index.html",
"<title>Redirect</title>"
));
assert!(file_contains!(public, "page/1/index.html", "<title>Redirect</title>"));
assert!(file_contains!(
public,
"page/1/index.html",
Expand Down Expand Up @@ -677,8 +676,11 @@ fn can_ignore_markdown_content() {
fn check_site() {
let (mut site, _tmp_dir, _public) = build_site("test_site");

let prefixes = &site.config.link_checker.skip_anchor_prefixes;
assert_eq!(prefixes, &vec!["https://github.com/rust-lang/rust/blob/"]);
assert_eq!(
site.config.link_checker.skip_anchor_prefixes,
vec!["https://github.com/rust-lang/rust/blob/"]
);
assert_eq!(site.config.link_checker.skip_prefixes, vec!["http://[2001:db8::]/"]);

site.config.enable_check_mode();
site.load().expect("link check test_site");
Expand Down
5 changes: 5 additions & 0 deletions docs/content/documentation/getting-started/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,11 @@ extra_syntaxes = []

# Configure the link checker
[link_checker]
# Skip link checking for external URLs that start with these prefixes
skip_prefixes = [
"http://[2001:db8::]/",
]

# Skip anchor checking for external URLs that start with these prefixes
skip_anchor_prefixes = [
"https://caniuse.com/",
Expand Down
4 changes: 4 additions & 0 deletions test_site/config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@ extra_syntaxes = ["syntaxes"]
ignored_content = ["*/ignored.md"]

[link_checker]
skip_prefixes = [
"http://[2001:db8::]/",
]

skip_anchor_prefixes = [
"https://github.com/rust-lang/rust/blob/",
]
Expand Down
2 changes: 2 additions & 0 deletions test_site/content/posts/tutorials/programming/rust.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,6 @@ A simple page

Link to some rust-lang [source code][permalink].

Internal web server <http://[2001:db8::]/path>.

[permalink]: https://github.com/rust-lang/rust/blob/c772948b687488a087356cb91432425662e034b9/src/librustc_back/target/mod.rs#L194-L214

0 comments on commit 6a2d2c8

Please sign in to comment.