Skip to content
Snippets Groups Projects
Commit c3a8701d authored by Mike McQuaid's avatar Mike McQuaid
Browse files

test-bot: default to building testbottest.

This provides an integration test for `test-bot.rb` by performing
compilation of an actual formula.
parent ee545fa1
No related branches found
No related tags found
No related merge requests found
...@@ -62,6 +62,9 @@ ...@@ -62,6 +62,9 @@
#: If `--coverage` is passed, generate coverage report and send it to #: If `--coverage` is passed, generate coverage report and send it to
#: Coveralls. #: Coveralls.
#: #:
#: If `--test-default-formula` is passed, use a default testing formula if
#: no formulae are otherwise found.
#:
#: If `--ci-master` is passed, use the Homebrew master branch CI #: If `--ci-master` is passed, use the Homebrew master branch CI
#: options. #: options.
#: #:
...@@ -268,11 +271,14 @@ module Homebrew ...@@ -268,11 +271,14 @@ module Homebrew
@tap = options[:tap] @tap = options[:tap]
@repository = @tap ? @tap.path : HOMEBREW_REPOSITORY @repository = @tap ? @tap.path : HOMEBREW_REPOSITORY
@skip_homebrew = options.fetch(:skip_homebrew, false) @skip_homebrew = options.fetch(:skip_homebrew, false)
@test_default_formula = options.fetch(:test_default_formula, false)
if quiet_system "git", "-C", @repository.to_s, "rev-parse", "--verify", "-q", argument if quiet_system "git", "-C", @repository.to_s, "rev-parse", "--verify", "-q", argument
@hash = argument @hash = argument
elsif url_match = argument.match(HOMEBREW_PULL_OR_COMMIT_URL_REGEX) elsif url_match = argument.match(HOMEBREW_PULL_OR_COMMIT_URL_REGEX)
@url = url_match[0] @url = url_match[0]
elsif @test_default_formula
@formulae = [argument]
elsif canonical_formula_name = safe_formula_canonical_name(argument) elsif canonical_formula_name = safe_formula_canonical_name(argument)
@formulae = [canonical_formula_name] @formulae = [canonical_formula_name]
else else
...@@ -695,7 +701,7 @@ module Homebrew ...@@ -695,7 +701,7 @@ module Homebrew
@category = __method__ @category = __method__
return if @skip_homebrew return if @skip_homebrew
if @tap.nil? && Array(@formulae).empty? if @tap.nil? && (@test_default_formula || Array(@formulae).empty?)
tests_args = ["--official-cmd-taps"] tests_args = ["--official-cmd-taps"]
tests_args_no_compat = [] tests_args_no_compat = []
tests_args_no_compat << "--coverage" if ARGV.include?("--coverage") tests_args_no_compat << "--coverage" if ARGV.include?("--coverage")
...@@ -1006,12 +1012,18 @@ module Homebrew ...@@ -1006,12 +1012,18 @@ module Homebrew
if ARGV.include?("--ci-master") || ARGV.include?("--ci-pr") \ if ARGV.include?("--ci-master") || ARGV.include?("--ci-pr") \
|| ARGV.include?("--ci-testing") || ARGV.include?("--ci-testing")
ARGV << "--cleanup" if ENV["JENKINS_HOME"] ARGV << "--cleanup" if ENV["JENKINS_HOME"]
ARGV << "--junit" << "--local" ARGV << "--junit" << "--local" << "--test-default-formula"
end end
if ARGV.include? "--ci-master" if ARGV.include? "--ci-master"
ARGV << "--fast" ARGV << "--fast"
end end
# TODO: refactor bottle code so this isn't needed.
if ARGV.include? "--test-default-formula"
ARGV << "--no-bottle"
end
if ARGV.include? "--local" if ARGV.include? "--local"
ENV["HOMEBREW_CACHE"] = "#{ENV["HOME"]}/Library/Caches/Homebrew" ENV["HOMEBREW_CACHE"] = "#{ENV["HOME"]}/Library/Caches/Homebrew"
mkdir_p ENV["HOMEBREW_CACHE"] mkdir_p ENV["HOMEBREW_CACHE"]
...@@ -1039,22 +1051,28 @@ module Homebrew ...@@ -1039,22 +1051,28 @@ module Homebrew
any_errors = false any_errors = false
skip_homebrew = ARGV.include?("--skip-homebrew") skip_homebrew = ARGV.include?("--skip-homebrew")
if ARGV.named.empty? if ARGV.named.empty?
# With no arguments just build the most recent commit. current_test = if ARGV.include?("--test-default-formula")
head_test = Test.new("HEAD", :tap => tap, :skip_homebrew => skip_homebrew) # Build the default test formula.
any_errors = !head_test.run Test.new("#{HOMEBREW_LIBRARY}/Homebrew/test/testbottest.rb",
tests << head_test :test_default_formula => true, :skip_homebrew => skip_homebrew)
else
# Otherwise just build the most recent commit.
Test.new("HEAD", :tap => tap, :skip_homebrew => skip_homebrew)
end
any_errors = !current_test.run
tests << current_test
else else
ARGV.named.each do |argument| ARGV.named.each do |argument|
test_error = false test_error = false
begin begin
test = Test.new(argument, :tap => tap, :skip_homebrew => skip_homebrew) current_test = Test.new(argument, :tap => tap, :skip_homebrew => skip_homebrew)
skip_homebrew = true skip_homebrew = true
rescue ArgumentError => e rescue ArgumentError => e
test_error = true test_error = true
ofail e.message ofail e.message
else else
test_error = !test.run test_error = !current_test.run
tests << test tests << current_test
end end
any_errors ||= test_error any_errors ||= test_error
end end
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment