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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
# These two need to be loaded sperately.
# If we load packaging.rake first, and it isn't available,
# running `rake spec` in a bare repo will fail since neither
# rubygems nor `rake_task` will have loaded. However, when we load
# packaging.rake last, package building fails.
begin
load File.join(File.dirname(__FILE__), 'ext', 'packaging', 'packaging.rake')
rescue LoadError
end
begin
require 'rubygems'
require 'rspec/core/rake_task'
rescue LoadError
end
Dir['tasks/**/*.rake'].each { |t| load t }
build_defs_file = 'ext/build_defaults.yaml'
if File.exist?(build_defs_file)
begin
require 'yaml'
@build_defaults ||= YAML.load_file(build_defs_file)
rescue Exception => e
STDERR.puts "Unable to load yaml from #{build_defs_file}:"
STDERR.puts e
end
@packaging_url = @build_defaults['packaging_url']
@packaging_repo = @build_defaults['packaging_repo']
raise "Could not find packaging url in #{build_defs_file}" if @packaging_url.nil?
raise "Could not find packaging repo in #{build_defs_file}" if @packaging_repo.nil?
namespace :package do
desc "Bootstrap packaging automation, e.g. clone into packaging repo"
task :bootstrap do
if File.exist?("ext/#{@packaging_repo}")
puts "It looks like you already have ext/#{@packaging_repo}. If you don't like it, blow it away with package:implode."
else
cd 'ext' do
%x{git clone #{@packaging_url}}
end
end
end
desc "Remove all cloned packaging automation"
task :implode do
rm_rf "ext/#{@packaging_repo}"
end
end
end
task :spec do
sh %{rspec #{ENV['TEST'] || ENV['TESTS'] || 'spec'}}
end
task :test => :spec
desc "verify that commit messages match CONTRIBUTING.md requirements"
task(:commits) do
# This git command looks at the summary from every commit from this branch not in master.
# Ideally this would compare against the branch that a PR is submitted against, but I don't
# know how to get that information. Absent that, comparing with master should work in most cases.
%x{git log --no-merges --pretty=%s master..$HEAD}.each_line do |commit_summary|
# This regex tests for the currently supported commit summary tokens: maint, doc, packaging, or hi-<number>.
# The exception tries to explain it in more full.
if /^\((maint|doc|packaging|hi-\d+)\)|revert/i.match(commit_summary).nil?
raise "\n\n\n\tThis commit summary didn't match CONTRIBUTING.md guidelines:\n" \
"\n\t\t#{commit_summary}\n" \
"\tThe commit summary (i.e. the first line of the commit message) should start with one of:\n" \
"\t\t(hi-<digits>) # this is most common and should be a ticket at tickets.puppetlabs.com\n" \
"\t\t(doc)\n" \
"\t\t(maint)\n" \
"\t\t(packaging)\n" \
"\n\tThis test for the commit summary is case-insensitive.\n\n\n"
end
end
end
task :default do
sh 'rake -T'
end
|