From 39a52d72a207b20e210ecd81ee158d8e086b62a7 Mon Sep 17 00:00:00 2001 From: Ben Balter Date: Mon, 9 Apr 2018 19:50:37 -0400 Subject: [PATCH] Validate and enforce style via CI --- .rubocop.yml | 6 ++++++ jekyll-theme-hacker.gemspec | 4 ++++ script/cibuild | 3 +++ script/validate-html | 27 +++++++++++++++++++++++++++ 4 files changed, 40 insertions(+) create mode 100644 .rubocop.yml create mode 100755 script/validate-html diff --git a/.rubocop.yml b/.rubocop.yml new file mode 100644 index 00000000000..648dfb112f2 --- /dev/null +++ b/.rubocop.yml @@ -0,0 +1,6 @@ +AllCops: + Exclude: + - _site/**/* + +Metrics/LineLength: + Enabled: false diff --git a/jekyll-theme-hacker.gemspec b/jekyll-theme-hacker.gemspec index 5a9729b3867..6c7dc526953 100644 --- a/jekyll-theme-hacker.gemspec +++ b/jekyll-theme-hacker.gemspec @@ -16,4 +16,8 @@ Gem::Specification.new do |s| s.platform = Gem::Platform::RUBY s.add_runtime_dependency "jekyll", "~> 3.5" s.add_runtime_dependency "jekyll-seo-tag", "~> 2.0" + s.add_development_dependency 'w3c_validators', "~> 1.3" + s.add_development_dependency 'html-proofer', "~> 3.0" + s.add_development_dependency 'rubocop', "~> 0.50" + end diff --git a/script/cibuild b/script/cibuild index 5a4da9a5846..b9a29627904 100755 --- a/script/cibuild +++ b/script/cibuild @@ -3,4 +3,7 @@ set -e bundle exec jekyll build +bundle exec htmlproofer ./_site --check-html --disable-external +bundle exec rubocop -D +bundle exec script/validate-html gem build jekyll-theme-hacker.gemspec diff --git a/script/validate-html b/script/validate-html new file mode 100755 index 00000000000..f6b17eb2e07 --- /dev/null +++ b/script/validate-html @@ -0,0 +1,27 @@ +#!/usr/bin/env ruby + +require 'w3c_validators' + +def validator(file) + extension = File.extname(file) + if extension == '.html' + W3CValidators::NuValidator.new + elsif extension == '.css' + W3CValidators::CSSValidator.new + end +end + +def validate(file) + puts "Checking #{file}..." + + path = File.expand_path "../_site/#{file}", __dir__ + results = validator(file).validate_file(path) + + return puts 'Valid!' if results.errors.empty? + + results.errors.each { |err| puts err.to_s } + exit 1 +end + +validate 'index.html' +validate File.join 'assets', 'css', 'style.css'