Farmbot-Web-App/lib/tasks/coverage.rake

52 lines
1.7 KiB
Ruby
Raw Normal View History

2018-11-05 18:19:29 -07:00
COVERAGE_FILE_PATH = "./coverage_fe/index.html"
2018-11-05 16:20:35 -07:00
THRESHOLD = 0.001
REPO_URL = "https://api.github.com/repos/Farmbot/Farmbot-Web-App/git"\
"/refs/heads/staging"
2018-11-05 18:19:29 -07:00
CURRENT_COMMIT = ENV.fetch("CIRCLE_SHA1", "")
2018-11-05 16:20:35 -07:00
CSS_SELECTOR = ".fraction"
FRACTION_DELIM = "/"
# Fetch JSON over HTTP. Rails probably already has a helper for this :shrug:
def open_json(url)
JSON.parse(open(url).read)
end
namespace :coverage do
desc "Coveralls stats stopped working :("
task run: :environment do
_, branches, _, lines = Nokogiri::HTML(open(COVERAGE_FILE_PATH))
.css(CSS_SELECTOR)
.map(&:text)
.map { |x| x.split(FRACTION_DELIM).map(&:to_f) }
.map { |x| Pair.new(*x) }
2018-11-05 18:19:29 -07:00
covered = lines.head + branches.head
total = lines.tail + branches.tail
build_percent = (covered / total) * 100
2018-11-05 16:20:35 -07:00
latest_commit_staging = open_json(REPO_URL).dig("object", "sha")
build_url = "https://coveralls.io/builds/#{latest_commit_staging}.json"
2018-11-05 18:19:29 -07:00
begin
staging_percent = open_json(build_url).fetch("covered_percent")
rescue OpenURI::HTTPError => exception
puts exception.message
puts "Error getting coveralls data. Wait for build to finish and try again."
staging_percent = 100
end
2018-11-05 16:20:35 -07:00
diff = (build_percent - staging_percent)
pass = (diff > -THRESHOLD)
puts "=" * 37
puts "COVERAGE RESULTS"
2018-11-05 18:19:29 -07:00
puts "This build: #{build_percent.round(8)} #{CURRENT_COMMIT[0,7]}"
puts "Staging build: #{staging_percent.round(8)} #{latest_commit_staging[0,7]}"
2018-11-05 16:20:35 -07:00
puts "=" * 37
2018-11-05 18:19:29 -07:00
puts "Difference: #{diff.round(8)}"
2018-11-05 16:20:35 -07:00
puts "Pass?: #{pass ? "yes" : "no"}"
exit pass ? 0 : 1
end
end