forked from magento/devdocs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test.rake
58 lines (49 loc) · 1.98 KB
/
test.rake
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# frozen_string_literal: true
namespace :test do
# Run html-proofer to check for broken links
desc 'Build devdocs and check for broken links'
task links: %w[build links_no_build]
# Run htmlproofer to check for broken external links
desc 'Check the existing _site for broken EXTERNAL links'
task :external_links do
puts 'Testing external links'
system 'bundle exec htmlproofer _site/ --external_only'
end
desc 'Check the entire _site for broken links and invalid HTML'
task :html do
puts 'Checking links with html-proofer...'.magenta
LinkChecker.check_site
end
desc 'Check the existing _site for broken links'
task :links_no_build do
begin
# Write console output (stderr only) to a file.
# Use this if you need to also capture stdout: https://stackoverflow.com/a/2480439
report = LinkChecker.md_report_path
$stderr.reopen(report, 'w+')
puts 'Checking links with html-proofer...'.magenta
LinkChecker.check_site
# We're expecting link validation errors, but unless we rescue from
# StandardError, rake will abort and won't run the convert task (https://stackoverflow.com/a/10048406).
# Wrapping task in a begin-rescue block prevent rake from aborting.
# Seems to prevent printing an error count though.
rescue StandardError => e
# Show how many lines contains the Markdown report
puts e.to_s.red
puts "To see the report, open the #{report} file.".red
end
end
desc 'Report about broken links in HTML'
task report: %w[links] do
puts 'Converting the link check report to HTML...'.magenta
Converter.to_html
end
desc 'Test Markdown style with mdl'
task :md do
puts 'Testing Markdown style with mdl ...'.magenta
output = `mdl --style=_checks/styles/style-rules-prod --ignore-front-matter --git-recurse -- .`
puts output.yellow
abort "The Markdown linter has found #{output.lines.count} issues".red unless output.empty?
puts 'No issues found'.magenta
end
end