-
Notifications
You must be signed in to change notification settings - Fork 114
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add link-check linter #216
Comments
Yeah, https://docs.travis-ci.com uses https://github.com/gjtorikian/html-proofer to do this. |
There is some documentation on using it with travis at https://github.com/gjtorikian/html-proofer/wiki/Using-HTMLProofer-From-Ruby-and-Travis |
If we wanted to do this we could probably just do the 'stupid thing' they have on there language: ruby
before_install:
- export NOKOGIRI_USE_SYSTEM_LIBRARIES=true
addons:
apt:
packages:
- libcurl4-openssl-dev # required to avoid SSL errors
script:
- gem install html-proofer && htmlproofer . |
Great. There's also the rakefile option: desc "Run the HTML-Proofer"
task :run_proofer do
require 'html-proofer'
# Ignore platform switcher hash URLs
platform_hash_urls = ['#platform-mac', '#platform-windows', '#platform-linux', '#platform-all']
HTMLProofer.check_directory("./output", {
:url_ignore => platform_hash_urls,
:typhoeus => { :ssl_verifypeer => false }
}).run
end |
Rmd link checker? |
Might be worth looking if there's a pre-made github action for this |
There seem to be a few, e.g. https://github.com/marketplace/actions/link-checker, https://github.com/gaurav-nelson/github-action-markdown-link-check, |
After trying them out locally it seems really easy to hit the GitHub rate limits and start getting 429 responses from GitHub. We would probably have to be careful to only check modified files and maybe even find a link checker (or make one) that uses a GITHUB_PAT to up the rate limit. |
Sharing my experience in case it can be useful: I've just added two workflows to R-hub docs depending on https://github.com/urlstechie/urlchecker-action that I've found out about on a blog. It's quite new but the maintainers are very responsive. It uses a Python library that uses regex, not commonmark 😢 but that's because it's general to any file (Rd files? 🙂).
|
Those are nice @maelle! I think we should be able to
With something like this. (it definitely won't work as-is, but you hopefully get the idea) on:
push:
paths: content/blog/**/*.markdown
check_links:
run: |
files=$(git diff --name-only ${{ github.event.before }} ${{ github.sha }})
run_checker $files |
Can https://validator.w3.org/checklink maybe help? |
@jimhester, did you mention the existence of something like this once?
The text was updated successfully, but these errors were encountered: