| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #: @hide_from_man_page | 
					
						
							|  |  |  | #:  * `test-bot` [options]  <url|formula>: | 
					
						
							| 
									
										
										
										
											2016-09-12 09:09:23 -04:00
										 |  |  | #:    Tests the full lifecycle of a formula or Homebrew/brew change. | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #: | 
					
						
							|  |  |  | #:    If `--dry-run` is passed, print what would be done rather than doing | 
					
						
							|  |  |  | #:    it. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--local` is passed, perform only local operations (i.e. don't | 
					
						
							|  |  |  | #:    push or create PR). | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--keep-logs` is passed, write and keep log files under | 
					
						
							|  |  |  | #:    `./brewbot/`. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--cleanup` is passed, clean all state from the Homebrew | 
					
						
							|  |  |  | #:    directory. Use with care! | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--clean-cache` is passed, remove all cached downloads. Use with | 
					
						
							|  |  |  | #:    care! | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--skip-setup` is passed, don't check the local system is setup | 
					
						
							|  |  |  | #:    correctly. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--skip-homebrew` is passed, don't check Homebrew's files and | 
					
						
							|  |  |  | #:    tests are all valid. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--junit` is passed, generate a JUnit XML test results file. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--no-bottle` is passed, run `brew install` without | 
					
						
							|  |  |  | #:    `--build-bottle`. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--keep-old` is passed, run `brew bottle --keep-old` to build new | 
					
						
							|  |  |  | #:    bottles for a single platform. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--skip-relocation` is passed, run | 
					
						
							|  |  |  | #:   `brew bottle --skip-relocation` to build new bottles that don't | 
					
						
							|  |  |  | #:    require relocation. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--HEAD` is passed, run `brew install` with `--HEAD`. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--local` is passed, ask Homebrew to write verbose logs under | 
					
						
							|  |  |  | #:    `./logs/` and set `$HOME` to `./home/`. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--tap=<tap>` is passed, use the `git` repository of the given | 
					
						
							|  |  |  | #:    tap. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--dry-run` is passed, just print commands, don't run them. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--fail-fast` is passed, immediately exit on a failing step. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--verbose` is passed, print test step output in real time. Has | 
					
						
							|  |  |  | #:    the side effect of passing output as raw bytes instead of | 
					
						
							|  |  |  | #:    re-encoding in UTF-8. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--fast` is passed, don't install any packages, but run e.g. | 
					
						
							|  |  |  | #:    `brew audit` anyway. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--keep-tmp` is passed, keep temporary files written by main | 
					
						
							|  |  |  | #:    installs and tests that are run. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--no-pull` is passed, don't use `brew pull` when possible. | 
					
						
							|  |  |  | #: | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  | #:    If `--coverage` is passed, generate and uplaod a coverage report. | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #: | 
					
						
							| 
									
										
										
										
											2016-09-13 13:25:33 +01:00
										 |  |  | #:    If `--test-default-formula` is passed, use a default testing formula | 
					
						
							|  |  |  | #:    when not building a tap and no other formulae are specified. | 
					
						
							| 
									
										
										
										
											2016-09-13 08:18:43 +01:00
										 |  |  | #: | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #:    If `--ci-master` is passed, use the Homebrew master branch CI | 
					
						
							|  |  |  | #:    options. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--ci-pr` is passed, use the Homebrew pull request CI options. | 
					
						
							|  |  |  | #: | 
					
						
							|  |  |  | #:    If `--ci-testing` is passed, use the Homebrew testing CI options. | 
					
						
							|  |  |  | #: | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  | #:    If `--ci-auto` is passed, automatically pick one of the Homebrew CI | 
					
						
							|  |  |  | #:    options based on the environment. | 
					
						
							|  |  |  | #: | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #:    If `--ci-upload` is passed, use the Homebrew CI bottle upload | 
					
						
							|  |  |  | #:    options. | 
					
						
							|  |  |  | #: | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2016-09-08 09:05:00 +01:00
										 |  |  | #:    Influential environment variables include: | 
					
						
							|  |  |  | #:    `TRAVIS_REPO_SLUG`: same as `--tap` | 
					
						
							|  |  |  | #:    `GIT_URL`: if set to URL of a tap remote, same as `--tap` | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  | require "formula" | 
					
						
							|  |  |  | require "utils" | 
					
						
							|  |  |  | require "date" | 
					
						
							|  |  |  | require "rexml/document" | 
					
						
							|  |  |  | require "rexml/xmldecl" | 
					
						
							|  |  |  | require "rexml/cdata" | 
					
						
							| 
									
										
										
										
											2015-12-19 19:10:22 +08:00
										 |  |  | require "tap" | 
					
						
							| 
									
										
										
										
											2016-07-29 20:31:32 -06:00
										 |  |  | require "development_tools" | 
					
						
							| 
									
										
										
										
											2016-07-29 21:58:17 -06:00
										 |  |  | require "utils/bottles" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | module Homebrew | 
					
						
							| 
									
										
										
										
											2014-10-16 10:28:51 +01:00
										 |  |  |   BYTES_IN_1_MEGABYTE = 1024*1024
 | 
					
						
							| 
									
										
										
										
											2016-04-06 16:48:07 -04:00
										 |  |  |   MAX_STEP_OUTPUT_SIZE = BYTES_IN_1_MEGABYTE - (200*1024) # margin of safety | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-07 18:18:36 +08:00
										 |  |  |   HOMEBREW_TAP_REGEX = %r{^([\w-]+)/homebrew-([\w-]+)$} | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-18 14:35:39 +08:00
										 |  |  |   def fix_encoding!(str) | 
					
						
							|  |  |  |     # Assume we are starting from a "mostly" UTF-8 string | 
					
						
							|  |  |  |     str.force_encoding(Encoding::UTF_8) | 
					
						
							|  |  |  |     return str if str.valid_encoding? | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |     str.encode!(Encoding::UTF_16, invalid: :replace) | 
					
						
							| 
									
										
										
										
											2016-08-18 14:35:39 +08:00
										 |  |  |     str.encode!(Encoding::UTF_8) | 
					
						
							| 
									
										
										
										
											2016-04-06 06:22:22 +02:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-18 20:18:37 +08:00
										 |  |  |   def resolve_test_tap | 
					
						
							| 
									
										
										
										
											2016-01-14 15:52:10 +08:00
										 |  |  |     if tap = ARGV.value("tap") | 
					
						
							|  |  |  |       return Tap.fetch(tap) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-07 18:18:36 +08:00
										 |  |  |     if (tap = ENV["TRAVIS_REPO_SLUG"]) && (tap =~ HOMEBREW_TAP_REGEX) | 
					
						
							| 
									
										
										
										
											2016-01-14 15:52:10 +08:00
										 |  |  |       return Tap.fetch(tap) | 
					
						
							| 
									
										
										
										
											2015-12-07 14:11:04 +08:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:18:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if ENV["UPSTREAM_BOT_PARAMS"] | 
					
						
							|  |  |  |       bot_argv = ENV["UPSTREAM_BOT_PARAMS"].split " " | 
					
						
							|  |  |  |       bot_argv.extend HomebrewArgvExtension | 
					
						
							| 
									
										
										
										
											2016-01-14 15:52:10 +08:00
										 |  |  |       if tap = bot_argv.value("tap") | 
					
						
							| 
									
										
										
										
											2016-03-07 19:58:49 +08:00
										 |  |  |         return Tap.fetch(tap) | 
					
						
							| 
									
										
										
										
											2015-12-07 14:11:04 +08:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:18:37 +08:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-11 08:08:51 +00:00
										 |  |  |     if git_url = ENV["UPSTREAM_GIT_URL"] || ENV["GIT_URL"] | 
					
						
							|  |  |  |       # Also can get tap from Jenkins GIT_URL. | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |       url_path = git_url.sub(%r{^https?://github\.com/}, "").chomp("/").sub(/\.git$/, "") | 
					
						
							| 
									
										
										
										
											2015-12-11 08:08:51 +00:00
										 |  |  |       begin | 
					
						
							| 
									
										
										
										
											2016-03-07 19:58:49 +08:00
										 |  |  |         return Tap.fetch(url_path) if url_path =~ HOMEBREW_TAP_REGEX | 
					
						
							| 
									
										
										
										
											2015-12-11 08:08:51 +00:00
										 |  |  |       rescue | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 17:58:32 -07:00
										 |  |  |   # Wraps command invocations. Instantiated by Test#test. | 
					
						
							|  |  |  |   # Handles logging and pretty-printing. | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |   class Step | 
					
						
							| 
									
										
										
										
											2016-06-27 18:01:43 -07:00
										 |  |  |     attr_reader :command, :name, :status, :output | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 17:58:32 -07:00
										 |  |  |     # Instantiates a Step object. | 
					
						
							|  |  |  |     # @param test [Test] The parent Test object | 
					
						
							|  |  |  |     # @param command [Array<String>] Command to execute and arguments | 
					
						
							|  |  |  |     # @param options [Hash] Recognized options are: | 
					
						
							|  |  |  |     #   :puts_output_on_success | 
					
						
							|  |  |  |     #   :repository | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def initialize(test, command, options = {}) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @test = test | 
					
						
							|  |  |  |       @category = test.category | 
					
						
							|  |  |  |       @command = command | 
					
						
							|  |  |  |       @puts_output_on_success = options[:puts_output_on_success] | 
					
						
							|  |  |  |       @name = command[1].delete("-") | 
					
						
							|  |  |  |       @status = :running | 
					
						
							|  |  |  |       @repository = options[:repository] || HOMEBREW_REPOSITORY | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def log_file_path | 
					
						
							|  |  |  |       file = "#{@category}.#{@name}.txt" | 
					
						
							|  |  |  |       root = @test.log_root | 
					
						
							|  |  |  |       root ? root + file : file | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def command_short | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |       (@command - %w[brew --force --retry --verbose --build-bottle --json]).join(" ") | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def passed? | 
					
						
							|  |  |  |       @status == :passed | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def failed? | 
					
						
							|  |  |  |       @status == :failed | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def puts_command | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       if ENV["TRAVIS"] | 
					
						
							| 
									
										
										
										
											2015-09-18 21:44:49 +08:00
										 |  |  |         @@travis_step_num ||= 0
 | 
					
						
							|  |  |  |         @travis_fold_id = @command.first(2).join(".") + ".#{@@travis_step_num += 1}" | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         @travis_timer_id = rand(2**32).to_s(16) | 
					
						
							| 
									
										
										
										
											2015-09-18 21:44:49 +08:00
										 |  |  |         puts "travis_fold:start:#{@travis_fold_id}" | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         puts "travis_time:start:#{@travis_timer_id}" | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-09-18 10:28:13 +01:00
										 |  |  |       puts "#{Tty.blue}==>#{Tty.white} #{@command.join(" ")}#{Tty.reset}" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def puts_result | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       if ENV["TRAVIS"] | 
					
						
							| 
									
										
										
										
											2016-09-21 09:22:21 +02:00
										 |  |  |         travis_start_time = @start_time.to_i * 1_000_000_000
 | 
					
						
							|  |  |  |         travis_end_time = @end_time.to_i * 1_000_000_000
 | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         travis_duration = travis_end_time - travis_start_time | 
					
						
							| 
									
										
										
										
											2015-09-18 19:06:51 +08:00
										 |  |  |         puts "#{Tty.white}==>#{Tty.green} PASSED#{Tty.reset}" if passed? | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         puts "travis_time:end:#{@travis_timer_id},start=#{travis_start_time},finish=#{travis_end_time},duration=#{travis_duration}" | 
					
						
							| 
									
										
										
										
											2015-09-18 21:44:49 +08:00
										 |  |  |         puts "travis_fold:end:#{@travis_fold_id}" | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-09-18 19:06:51 +08:00
										 |  |  |       puts "#{Tty.white}==>#{Tty.red} FAILED#{Tty.reset}" if failed? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |     def output? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @output && !@output.empty? | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 17:58:32 -07:00
										 |  |  |     # The execution time of the task. | 
					
						
							|  |  |  |     # Precondition: Step#run has been called. | 
					
						
							|  |  |  |     # @return [Float] execution time in seconds | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |     def time | 
					
						
							|  |  |  |       @end_time - @start_time | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     def run | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       @start_time = Time.now | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       puts_command | 
					
						
							|  |  |  |       if ARGV.include? "--dry-run" | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         @end_time = Time.now | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         @status = :passed | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |         puts_result | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         return | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |       verbose = ARGV.verbose? | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |       # Step may produce arbitrary output and we read it bytewise, so must | 
					
						
							|  |  |  |       # buffer it as binary and convert to UTF-8 once complete | 
					
						
							| 
									
										
										
										
											2016-08-18 14:35:39 +08:00
										 |  |  |       output = "".encode!("BINARY") | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |       working_dir = Pathname.new(@command.first == "git" ? @repository : Dir.pwd) | 
					
						
							|  |  |  |       read, write = IO.pipe | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       begin | 
					
						
							|  |  |  |         pid = fork do | 
					
						
							|  |  |  |           read.close | 
					
						
							|  |  |  |           $stdout.reopen(write) | 
					
						
							|  |  |  |           $stderr.reopen(write) | 
					
						
							|  |  |  |           write.close | 
					
						
							|  |  |  |           working_dir.cd { exec(*@command) } | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |         write.close | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |         while buf = read.readpartial(4096) | 
					
						
							| 
									
										
										
										
											2015-09-23 21:23:17 +08:00
										 |  |  |           if verbose | 
					
						
							|  |  |  |             print buf | 
					
						
							|  |  |  |             $stdout.flush | 
					
						
							|  |  |  |           end | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |           output << buf | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |       rescue EOFError | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |       ensure | 
					
						
							|  |  |  |         read.close | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |       Process.wait(pid) | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       @end_time = Time.now | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @status = $?.success? ? :passed : :failed | 
					
						
							|  |  |  |       puts_result | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |       unless output.empty? | 
					
						
							| 
									
										
										
										
											2016-04-06 06:35:28 +02:00
										 |  |  |         @output = Homebrew.fix_encoding!(output) | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |         puts @output if (failed? || @puts_output_on_success) && !verbose | 
					
						
							| 
									
										
										
										
											2015-04-27 23:42:35 +08:00
										 |  |  |         File.write(log_file_path, @output) if ARGV.include? "--keep-logs" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2014-10-27 13:02:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-01 00:00:55 -04:00
										 |  |  |       exit 1 if ARGV.include?("--fail-fast") && failed? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   class Test | 
					
						
							|  |  |  |     attr_reader :log_root, :category, :name, :steps | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |     def initialize(argument, options = {}) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @hash = nil | 
					
						
							|  |  |  |       @url = nil | 
					
						
							|  |  |  |       @formulae = [] | 
					
						
							| 
									
										
										
										
											2014-12-29 07:55:01 +00:00
										 |  |  |       @added_formulae = [] | 
					
						
							|  |  |  |       @modified_formula = [] | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @steps = [] | 
					
						
							| 
									
										
										
										
											2016-05-28 18:49:08 +01:00
										 |  |  |       @tap = options[:tap] | 
					
						
							|  |  |  |       @repository = @tap ? @tap.path : HOMEBREW_REPOSITORY | 
					
						
							| 
									
										
										
										
											2016-01-15 19:44:04 +08:00
										 |  |  |       @skip_homebrew = options.fetch(:skip_homebrew, false) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-17 15:06:07 +08:00
										 |  |  |       if quiet_system "git", "-C", @repository.to_s, "rev-parse", "--verify", "-q", argument | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         @hash = argument | 
					
						
							| 
									
										
										
										
											2016-01-15 19:44:04 +08:00
										 |  |  |       elsif url_match = argument.match(HOMEBREW_PULL_OR_COMMIT_URL_REGEX) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         @url = url_match[0] | 
					
						
							| 
									
										
										
										
											2016-01-15 20:12:41 +08:00
										 |  |  |       elsif canonical_formula_name = safe_formula_canonical_name(argument) | 
					
						
							|  |  |  |         @formulae = [canonical_formula_name] | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       else | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |         raise ArgumentError, "#{argument} is not a pull request URL, commit URL or formula name." | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       @category = __method__ | 
					
						
							|  |  |  |       @brewbot_root = Pathname.pwd + "brewbot" | 
					
						
							|  |  |  |       FileUtils.mkdir_p @brewbot_root | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def no_args? | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       @hash == "HEAD" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 20:12:41 +08:00
										 |  |  |     def safe_formula_canonical_name(formula_name) | 
					
						
							|  |  |  |       Formulary.factory(formula_name).full_name | 
					
						
							| 
									
										
										
										
											2016-09-07 12:47:21 +01:00
										 |  |  |     rescue TapFormulaUnavailableError => e | 
					
						
							|  |  |  |       raise if e.tap.installed? | 
					
						
							|  |  |  |       test "brew", "tap", e.tap.name | 
					
						
							|  |  |  |       retry unless steps.last.failed? | 
					
						
							|  |  |  |       onoe e | 
					
						
							| 
									
										
										
										
											2016-09-11 12:31:44 +01:00
										 |  |  |       puts e.backtrace if ARGV.debug? | 
					
						
							|  |  |  |     rescue FormulaUnavailableError, TapFormulaAmbiguityError, TapFormulaWithOldnameAmbiguityError => e | 
					
						
							| 
									
										
										
										
											2016-09-06 12:00:08 +01:00
										 |  |  |       onoe e | 
					
						
							| 
									
										
										
										
											2016-09-11 12:31:44 +01:00
										 |  |  |       puts e.backtrace if ARGV.debug? | 
					
						
							| 
									
										
										
										
											2015-09-14 09:06:16 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     def git(*args) | 
					
						
							| 
									
										
										
										
											2016-01-15 19:59:22 +08:00
										 |  |  |       @repository.cd { Utils.popen_read("git", *args) } | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def download | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       def shorten_revision(revision) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         git("rev-parse", "--short", revision).strip | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def current_sha1 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |         shorten_revision "HEAD" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def current_branch | 
					
						
							|  |  |  |         git("symbolic-ref", "HEAD").gsub("refs/heads/", "").strip | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       def single_commit?(start_revision, end_revision) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         git("rev-list", "--count", "#{start_revision}..#{end_revision}").to_i == 1
 | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       def diff_formulae(start_revision, end_revision, path, filter) | 
					
						
							| 
									
										
										
										
											2016-05-28 18:49:08 +01:00
										 |  |  |         return unless @tap | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |         git( | 
					
						
							| 
									
										
										
										
											2016-06-23 17:56:10 +08:00
										 |  |  |           "diff-tree", "-r", "--name-only", "--diff-filter=#{filter}", | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |           start_revision, end_revision, "--", path | 
					
						
							|  |  |  |         ).lines.map do |line| | 
					
						
							| 
									
										
										
										
											2016-01-15 20:12:41 +08:00
										 |  |  |           file = Pathname.new line.chomp | 
					
						
							| 
									
										
										
										
											2016-06-23 17:56:10 +08:00
										 |  |  |           next unless @tap.formula_file?(file) | 
					
						
							| 
									
										
										
										
											2016-01-15 20:12:41 +08:00
										 |  |  |           @tap.formula_file_to_name(file) | 
					
						
							| 
									
										
										
										
											2015-08-11 21:31:03 +08:00
										 |  |  |         end.compact | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       @category = __method__ | 
					
						
							|  |  |  |       @start_branch = current_branch | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       travis_pr = ENV["TRAVIS_PULL_REQUEST"] && ENV["TRAVIS_PULL_REQUEST"] != "false" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Use Jenkins GitHub Pull Request Builder plugin variables for | 
					
						
							|  |  |  |       # pull request jobs. | 
					
						
							|  |  |  |       if ENV["ghprbPullLink"] | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |         @url = ENV["ghprbPullLink"] | 
					
						
							| 
									
										
										
										
											2014-10-16 22:06:46 +01:00
										 |  |  |         @hash = nil | 
					
						
							| 
									
										
										
										
											2015-09-18 11:23:53 +01:00
										 |  |  |         test "git", "checkout", "origin/master" | 
					
						
							| 
									
										
										
										
											2016-07-14 10:18:39 +01:00
										 |  |  |       elsif ENV["GIT_URL"] && ENV["GIT_BRANCH"] | 
					
						
							|  |  |  |         git_url = ENV["GIT_URL"].chomp("/").chomp(".git") | 
					
						
							| 
									
										
										
										
											2016-07-14 10:10:34 +01:00
										 |  |  |         %r{origin/pr/(\d+)/(merge|head)} =~ ENV["GIT_BRANCH"] | 
					
						
							|  |  |  |         pr = $1 | 
					
						
							| 
									
										
										
										
											2016-07-14 10:18:39 +01:00
										 |  |  |         @url = "#{git_url}/pull/#{pr}" | 
					
						
							| 
									
										
										
										
											2016-07-14 10:10:34 +01:00
										 |  |  |         @hash = nil | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Use Travis CI pull-request variables for pull request jobs. | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       elsif travis_pr | 
					
						
							|  |  |  |         @url = "https://github.com/#{ENV["TRAVIS_REPO_SLUG"]}/pull/#{ENV["TRAVIS_PULL_REQUEST"]}" | 
					
						
							|  |  |  |         @hash = nil | 
					
						
							| 
									
										
										
										
											2014-10-16 22:06:46 +01:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Use Jenkins Git plugin variables for master branch jobs. | 
					
						
							|  |  |  |       if ENV["GIT_PREVIOUS_COMMIT"] && ENV["GIT_COMMIT"] | 
					
						
							|  |  |  |         diff_start_sha1 = ENV["GIT_PREVIOUS_COMMIT"] | 
					
						
							|  |  |  |         diff_end_sha1 = ENV["GIT_COMMIT"] | 
					
						
							|  |  |  |       # Use Travis CI Git variables for master or branch jobs. | 
					
						
							|  |  |  |       elsif ENV["TRAVIS_COMMIT_RANGE"] | 
					
						
							|  |  |  |         diff_start_sha1, diff_end_sha1 = ENV["TRAVIS_COMMIT_RANGE"].split "..." | 
					
						
							|  |  |  |       # Otherwise just use the current SHA-1 (which may be overriden later) | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         diff_end_sha1 = diff_start_sha1 = current_sha1 | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-13 22:17:17 +08:00
										 |  |  |       diff_start_sha1 = git("merge-base", diff_start_sha1, diff_end_sha1).strip | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Handle no arguments being passed on the command-line e.g. `brew test-bot`. | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       if no_args? | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |         if diff_start_sha1 == diff_end_sha1 || \ | 
					
						
							|  |  |  |            single_commit?(diff_start_sha1, diff_end_sha1) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           @name = diff_end_sha1 | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           @name = "#{diff_start_sha1}-#{diff_end_sha1}" | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Handle formulae arguments being passed on the command-line e.g. `brew test-bot wget fish`. | 
					
						
							| 
									
										
										
										
											2016-09-13 13:25:33 +01:00
										 |  |  |       elsif !@formulae.empty? | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |         @name = "#{@formulae.first}-#{diff_end_sha1}" | 
					
						
							| 
									
										
										
										
											2015-10-20 12:28:09 +01:00
										 |  |  |         diff_start_sha1 = diff_end_sha1 | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Handle a hash being passed on the command-line e.g. `brew test-bot 1a2b3c`. | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       elsif @hash | 
					
						
							|  |  |  |         test "git", "checkout", @hash | 
					
						
							|  |  |  |         diff_start_sha1 = "#{@hash}^" | 
					
						
							|  |  |  |         diff_end_sha1 = @hash | 
					
						
							|  |  |  |         @name = @hash | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |       # Handle a URL being passed on the command-line or through Jenkins/Travis | 
					
						
							|  |  |  |       # environment variables e.g. | 
					
						
							| 
									
										
										
										
											2016-05-01 14:55:45 +02:00
										 |  |  |       # `brew test-bot https://github.com/Homebrew/homebrew-core/pull/678`. | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       elsif @url | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |         # TODO: in future Travis CI may need to also use `brew pull` to e.g. push | 
					
						
							|  |  |  |         # the right commit to BrewTestBot. | 
					
						
							| 
									
										
										
										
											2016-07-14 10:57:12 +01:00
										 |  |  |         if !travis_pr && !ARGV.include?("--no-pull") | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |           diff_start_sha1 = current_sha1 | 
					
						
							| 
									
										
										
										
											2016-05-28 18:48:51 +01:00
										 |  |  |           test "brew", "pull", "--clean", @url | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |           diff_end_sha1 = current_sha1 | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |         @short_url = @url.gsub("https://github.com/", "") | 
					
						
							|  |  |  |         if @short_url.include? "/commit/" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           # 7 characters should be enough for a commit (not 40). | 
					
						
							| 
									
										
										
										
											2016-09-12 08:52:19 +01:00
										 |  |  |           @short_url.gsub!(%r{(commit/\w{7}).*/}, '\1') | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           @name = @short_url | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           @name = "#{@short_url}-#{diff_end_sha1}" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       else | 
					
						
							| 
									
										
										
										
											2015-09-25 09:15:10 +01:00
										 |  |  |         raise "Cannot set @name: invalid command-line arguments!" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       @log_root = @brewbot_root + @name | 
					
						
							|  |  |  |       FileUtils.mkdir_p @log_root | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       return unless diff_start_sha1 != diff_end_sha1 | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       return if @url && steps.last && !steps.last.passed? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 13:25:33 +01:00
										 |  |  |       if @tap | 
					
						
							|  |  |  |         formula_path = @tap.formula_dir.to_s | 
					
						
							|  |  |  |         @added_formulae += diff_formulae(diff_start_sha1, diff_end_sha1, formula_path, "A") | 
					
						
							|  |  |  |         @modified_formula += diff_formulae(diff_start_sha1, diff_end_sha1, formula_path, "M")\ | 
					
						
							|  |  |  |       elsif @formulae.empty? && ARGV.include?("--test-default-formula") | 
					
						
							|  |  |  |         # Build the default test formula. | 
					
						
							|  |  |  |         HOMEBREW_CACHE_FORMULA.mkpath | 
					
						
							|  |  |  |         testbottest = "#{HOMEBREW_LIBRARY}/Homebrew/test/testbottest.rb" | 
					
						
							|  |  |  |         FileUtils.cp testbottest, HOMEBREW_CACHE_FORMULA | 
					
						
							|  |  |  |         @test_default_formula = true | 
					
						
							|  |  |  |         @added_formulae = [testbottest] | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |       @formulae += @added_formulae + @modified_formula | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def skip(formula_name) | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |       puts "#{Tty.blue}==>#{Tty.white} SKIPPING: #{formula_name}#{Tty.reset}" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def satisfied_requirements?(formula, spec, dependency = nil) | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |       requirements = formula.send(spec).requirements | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       unsatisfied_requirements = requirements.reject do |requirement| | 
					
						
							| 
									
										
										
										
											2014-11-18 16:43:13 +00:00
										 |  |  |         satisfied = false | 
					
						
							| 
									
										
										
										
											2015-02-03 16:46:36 +00:00
										 |  |  |         satisfied ||= requirement.satisfied? | 
					
						
							|  |  |  |         satisfied ||= requirement.optional? | 
					
						
							| 
									
										
										
										
											2014-11-18 16:43:13 +00:00
										 |  |  |         if !satisfied && requirement.default_formula? | 
					
						
							| 
									
										
										
										
											2015-06-06 19:55:31 +08:00
										 |  |  |           default = Formula[requirement.default_formula] | 
					
						
							| 
									
										
										
										
											2015-05-27 21:19:15 +08:00
										 |  |  |           satisfied = satisfied_requirements?(default, :stable, formula.full_name) | 
					
						
							| 
									
										
										
										
											2014-11-18 16:43:13 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |         satisfied | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if unsatisfied_requirements.empty? | 
					
						
							|  |  |  |         true | 
					
						
							|  |  |  |       else | 
					
						
							| 
									
										
										
										
											2015-05-27 21:19:15 +08:00
										 |  |  |         name = formula.full_name | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |         name += " (#{spec})" unless spec == :stable | 
					
						
							| 
									
										
										
										
											2014-11-18 16:43:13 +00:00
										 |  |  |         name += " (#{dependency} dependency)" if dependency | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |         skip name | 
					
						
							|  |  |  |         puts unsatisfied_requirements.map(&:message) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         false | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def setup | 
					
						
							|  |  |  |       @category = __method__ | 
					
						
							|  |  |  |       return if ARGV.include? "--skip-setup" | 
					
						
							| 
									
										
										
										
											2016-08-16 17:00:38 +01:00
										 |  |  |       if !ENV["TRAVIS"] && HOMEBREW_PREFIX.to_s == "/usr/local" | 
					
						
							| 
									
										
										
										
											2016-07-14 10:43:58 +01:00
										 |  |  |         test "brew", "doctor" | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       test "brew", "--env" | 
					
						
							|  |  |  |       test "brew", "config" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def formula(formula_name) | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |       @category = "#{__method__}.#{formula_name}" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 17:57:05 +01:00
										 |  |  |       test "brew", "uses", formula_name | 
					
						
							| 
									
										
										
										
											2014-12-18 17:03:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |       formula = Formulary.factory(formula_name) | 
					
						
							| 
									
										
										
										
											2015-05-11 15:44:42 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       installed_gcc = false | 
					
						
							| 
									
										
										
										
											2015-01-17 19:12:10 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       deps = [] | 
					
						
							|  |  |  |       reqs = [] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |       fetch_args = [formula_name] | 
					
						
							| 
									
										
										
										
											2016-01-12 00:02:14 +00:00
										 |  |  |       fetch_args << "--build-bottle" if !ARGV.include?("--fast") && !ARGV.include?("--no-bottle") && !formula.bottle_disabled? | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  |       fetch_args << "--force" if ARGV.include? "--cleanup" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |       audit_args = [formula_name] | 
					
						
							| 
									
										
										
										
											2016-08-02 10:59:39 +01:00
										 |  |  |       audit_args << "--new-formula" if @added_formulae.include? formula_name | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-17 19:12:10 +01:00
										 |  |  |       if formula.stable | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  |         unless satisfied_requirements?(formula, :stable) | 
					
						
							|  |  |  |           test "brew", "fetch", "--retry", *fetch_args | 
					
						
							|  |  |  |           test "brew", "audit", *audit_args | 
					
						
							|  |  |  |           return | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-01-17 19:12:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-24 14:41:56 -07:00
										 |  |  |         deps |= formula.stable.deps.to_a.reject(&:optional?) | 
					
						
							|  |  |  |         reqs |= formula.stable.requirements.to_a.reject(&:optional?) | 
					
						
							| 
									
										
										
										
											2015-01-17 19:12:10 +01:00
										 |  |  |       elsif formula.devel | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  |         unless satisfied_requirements?(formula, :devel) | 
					
						
							|  |  |  |           test "brew", "fetch", "--retry", "--devel", *fetch_args | 
					
						
							|  |  |  |           test "brew", "audit", "--devel", *audit_args | 
					
						
							|  |  |  |           return | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-01-17 19:12:10 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       if formula.devel && !ARGV.include?("--HEAD") | 
					
						
							| 
									
										
										
										
											2015-08-24 14:41:56 -07:00
										 |  |  |         deps |= formula.devel.deps.to_a.reject(&:optional?) | 
					
						
							|  |  |  |         reqs |= formula.devel.requirements.to_a.reject(&:optional?) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-21 12:05:54 +08:00
										 |  |  |       begin | 
					
						
							| 
									
										
										
										
											2015-08-24 14:41:56 -07:00
										 |  |  |         deps.each { |d| d.to_formula.recursive_dependencies } | 
					
						
							| 
									
										
										
										
											2015-08-21 12:05:54 +08:00
										 |  |  |       rescue TapFormulaUnavailableError => e | 
					
						
							|  |  |  |         raise if e.tap.installed? | 
					
						
							|  |  |  |         safe_system "brew", "tap", e.tap.name | 
					
						
							|  |  |  |         retry | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       begin | 
					
						
							| 
									
										
										
										
											2014-12-29 12:20:30 +00:00
										 |  |  |         deps.each do |dep| | 
					
						
							|  |  |  |           CompilerSelector.select_for(dep.to_formula) | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |         CompilerSelector.select_for(formula) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       rescue CompilerSelectionError => e | 
					
						
							|  |  |  |         unless installed_gcc | 
					
						
							| 
									
										
										
										
											2015-05-26 15:11:17 +01:00
										 |  |  |           run_as_not_developer { test "brew", "install", "gcc" } | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           installed_gcc = true | 
					
						
							| 
									
										
										
										
											2016-05-10 08:19:48 +01:00
										 |  |  |           DevelopmentTools.clear_version_cache | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           retry | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |         skip formula_name | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         puts e.message | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-11 14:41:27 -04:00
										 |  |  |       conflicts = formula.conflicts | 
					
						
							|  |  |  |       formula.recursive_dependencies.each do |dependency| | 
					
						
							|  |  |  |         conflicts += dependency.to_formula.conflicts | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       conflicts.each do |conflict| | 
					
						
							|  |  |  |         confict_formula = Formulary.factory(conflict.name) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if confict_formula.installed? && confict_formula.linked_keg.exist? | 
					
						
							|  |  |  |           test "brew", "unlink", "--force", conflict.name | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  |       installed = Utils.popen_read("brew", "list").split("\n") | 
					
						
							| 
									
										
										
										
											2016-04-16 00:23:40 +08:00
										 |  |  |       dependencies = Utils.popen_read("brew", "deps", "--include-build", formula_name).split("\n") | 
					
						
							| 
									
										
										
										
											2015-07-11 14:41:27 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |       (installed & dependencies).each do |installed_dependency| | 
					
						
							|  |  |  |         installed_dependency_formula = Formulary.factory(installed_dependency) | 
					
						
							| 
									
										
										
										
											2016-09-21 09:21:27 +02:00
										 |  |  |         next unless installed_dependency_formula.installed? | 
					
						
							|  |  |  |         next if installed_dependency_formula.keg_only? | 
					
						
							|  |  |  |         next if installed_dependency_formula.linked_keg.exist? | 
					
						
							|  |  |  |         test "brew", "link", installed_dependency | 
					
						
							| 
									
										
										
										
											2015-07-11 14:41:27 -04:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  |       dependencies -= installed | 
					
						
							|  |  |  |       unchanged_dependencies = dependencies - @formulae | 
					
						
							|  |  |  |       changed_dependences = dependencies - unchanged_dependencies | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-16 00:23:40 +08:00
										 |  |  |       runtime_dependencies = Utils.popen_read("brew", "deps", formula_name).split("\n") | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  |       build_dependencies = dependencies - runtime_dependencies | 
					
						
							|  |  |  |       unchanged_build_dependencies = build_dependencies - @formulae | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-16 00:23:40 +08:00
										 |  |  |       dependents = Utils.popen_read("brew", "uses", formula_name).split("\n") | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  |       dependents -= @formulae | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       dependents = dependents.map { |d| Formulary.factory(d) } | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |       bottled_dependents = dependents.select(&:bottled?) | 
					
						
							| 
									
										
										
										
											2016-04-17 21:25:11 -04:00
										 |  |  |       testable_dependents = dependents.select { |d| d.bottled? && d.test_defined? } | 
					
						
							| 
									
										
										
										
											2015-04-06 23:23:55 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       if (deps | reqs).any? { |d| d.name == "mercurial" && d.build? } | 
					
						
							| 
									
										
										
										
											2015-05-26 15:11:17 +01:00
										 |  |  |         run_as_not_developer { test "brew", "install", "mercurial" } | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       test "brew", "fetch", "--retry", *unchanged_dependencies unless unchanged_dependencies.empty? | 
					
						
							| 
									
										
										
										
											2015-08-04 00:12:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       unless changed_dependences.empty? | 
					
						
							|  |  |  |         test "brew", "fetch", "--retry", "--build-bottle", *changed_dependences | 
					
						
							| 
									
										
										
										
											2015-12-29 11:54:43 +00:00
										 |  |  |         unless ARGV.include?("--fast") | 
					
						
							|  |  |  |           # Install changed dependencies as new bottles so we don't have checksum problems. | 
					
						
							|  |  |  |           test "brew", "install", "--build-bottle", *changed_dependences | 
					
						
							|  |  |  |           # Run postinstall on them because the tested formula might depend on | 
					
						
							|  |  |  |           # this step | 
					
						
							|  |  |  |           test "brew", "postinstall", *changed_dependences | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-08-04 00:12:42 +02:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  |       test "brew", "fetch", "--retry", *fetch_args | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |       test "brew", "uninstall", "--force", formula_name if formula.installed? | 
					
						
							| 
									
										
										
										
											2016-04-10 22:53:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |       # shared_*_args are applied to both the main and --devel spec | 
					
						
							|  |  |  |       shared_install_args = ["--verbose"] | 
					
						
							|  |  |  |       shared_install_args << "--keep-tmp" if ARGV.keep_tmp? | 
					
						
							|  |  |  |       # install_args is just for the main (stable, or devel if in a devel-only tap) spec | 
					
						
							|  |  |  |       install_args = [] | 
					
						
							| 
									
										
										
										
											2016-01-12 00:02:14 +00:00
										 |  |  |       install_args << "--build-bottle" if !ARGV.include?("--fast") && !ARGV.include?("--no-bottle") && !formula.bottle_disabled? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       install_args << "--HEAD" if ARGV.include? "--HEAD" | 
					
						
							| 
									
										
										
										
											2015-01-19 13:39:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       # Pass --devel or --HEAD to install in the event formulae lack stable. Supports devel-only/head-only. | 
					
						
							|  |  |  |       # head-only should not have devel, but devel-only can have head. Stable can have all three. | 
					
						
							|  |  |  |       if devel_only_tap? formula | 
					
						
							|  |  |  |         install_args << "--devel" | 
					
						
							| 
									
										
										
										
											2015-10-14 13:53:24 +01:00
										 |  |  |         formula_bottled = false | 
					
						
							| 
									
										
										
										
											2015-01-19 13:39:38 +00:00
										 |  |  |       elsif head_only_tap? formula | 
					
						
							|  |  |  |         install_args << "--HEAD" | 
					
						
							| 
									
										
										
										
											2015-10-14 13:53:24 +01:00
										 |  |  |         formula_bottled = false | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         formula_bottled = formula.bottled? | 
					
						
							| 
									
										
										
										
											2015-01-19 13:39:38 +00:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-10 22:53:56 -04:00
										 |  |  |       install_args.concat(shared_install_args) | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |       install_args << formula_name | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       # Don't care about e.g. bottle failures for dependencies. | 
					
						
							| 
									
										
										
										
											2015-10-14 17:40:12 +02:00
										 |  |  |       install_passed = false | 
					
						
							| 
									
										
										
										
											2015-05-18 18:44:27 +08:00
										 |  |  |       run_as_not_developer do | 
					
						
							| 
									
										
										
										
											2015-10-20 14:53:50 +08:00
										 |  |  |         if !ARGV.include?("--fast") || formula_bottled || formula.bottle_unneeded? | 
					
						
							| 
									
										
										
										
											2015-10-14 13:53:24 +01:00
										 |  |  |           test "brew", "install", "--only-dependencies", *install_args unless dependencies.empty? | 
					
						
							|  |  |  |           test "brew", "install", *install_args | 
					
						
							|  |  |  |           install_passed = steps.last.passed? | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2015-05-18 18:44:27 +08:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |       test "brew", "audit", *audit_args | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       if install_passed | 
					
						
							| 
									
										
										
										
											2016-01-12 00:02:14 +00:00
										 |  |  |         if formula.stable? && !ARGV.include?("--fast") && !ARGV.include?("--no-bottle") && !formula.bottle_disabled? | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |           bottle_args = ["--verbose", "--json", formula_name] | 
					
						
							| 
									
										
										
										
											2015-09-11 10:15:21 +01:00
										 |  |  |           bottle_args << "--keep-old" if ARGV.include? "--keep-old" | 
					
						
							| 
									
										
										
										
											2016-06-28 20:58:44 +08:00
										 |  |  |           bottle_args << "--skip-relocation" if ARGV.include? "--skip-relocation" | 
					
						
							| 
									
										
										
										
											2016-09-13 08:58:12 +01:00
										 |  |  |           bottle_args << "--force-core-tap" if @test_default_formula | 
					
						
							| 
									
										
										
										
											2014-11-24 08:26:43 +00:00
										 |  |  |           test "brew", "bottle", *bottle_args | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           bottle_step = steps.last | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |           if bottle_step.passed? && bottle_step.output? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |             bottle_filename = | 
					
						
							| 
									
										
										
										
											2016-09-12 10:28:52 +01:00
										 |  |  |               bottle_step.output.gsub(%r{.*(\./\S+#{Utils::Bottles.native_regex}).*}m, '\1') | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |             bottle_json_filename = bottle_filename.gsub(/\.(\d+\.)?tar\.gz$/, ".json") | 
					
						
							|  |  |  |             bottle_merge_args = ["--merge", "--write", "--no-commit", bottle_json_filename] | 
					
						
							| 
									
										
										
										
											2015-10-15 15:00:05 +08:00
										 |  |  |             bottle_merge_args << "--keep-old" if ARGV.include? "--keep-old" | 
					
						
							|  |  |  |             test "brew", "bottle", *bottle_merge_args | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |             test "brew", "uninstall", "--force", formula_name | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |             FileUtils.ln bottle_filename, HOMEBREW_CACHE/bottle_filename, force: true | 
					
						
							| 
									
										
										
										
											2016-01-15 20:48:12 +08:00
										 |  |  |             @formulae.delete(formula_name) | 
					
						
							| 
									
										
										
										
											2016-08-05 22:01:32 +08:00
										 |  |  |             unless unchanged_build_dependencies.empty? | 
					
						
							| 
									
										
										
										
											2015-03-20 21:32:22 +00:00
										 |  |  |               test "brew", "uninstall", "--force", *unchanged_build_dependencies | 
					
						
							|  |  |  |               unchanged_dependencies -= unchanged_build_dependencies | 
					
						
							|  |  |  |             end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |             test "brew", "install", bottle_filename | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-04-10 22:53:56 -04:00
										 |  |  |         shared_test_args = ["--verbose"] | 
					
						
							|  |  |  |         shared_test_args << "--keep-tmp" if ARGV.keep_tmp? | 
					
						
							|  |  |  |         test "brew", "test", formula_name, *shared_test_args if formula.test_defined? | 
					
						
							| 
									
										
										
										
											2016-04-17 21:25:11 -04:00
										 |  |  |         bottled_dependents.each do |dependent| | 
					
						
							| 
									
										
										
										
											2015-01-08 20:49:24 +00:00
										 |  |  |           unless dependent.installed? | 
					
						
							|  |  |  |             test "brew", "fetch", "--retry", dependent.name | 
					
						
							|  |  |  |             next if steps.last.failed? | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |             conflicts = dependent.conflicts.map { |c| Formulary.factory(c.name) }.select(&:installed?) | 
					
						
							| 
									
										
										
										
											2016-06-20 00:53:56 -07:00
										 |  |  |             dependent.recursive_dependencies.each do |dependency| | 
					
						
							|  |  |  |               conflicts += dependency.to_formula.conflicts.map { |c| Formulary.factory(c.name) }.select(&:installed?) | 
					
						
							|  |  |  |             end | 
					
						
							| 
									
										
										
										
											2015-01-09 22:33:57 +08:00
										 |  |  |             conflicts.each do |conflict| | 
					
						
							|  |  |  |               test "brew", "unlink", conflict.name | 
					
						
							|  |  |  |             end | 
					
						
							| 
									
										
										
										
											2015-12-29 11:54:43 +00:00
										 |  |  |             unless ARGV.include?("--fast") | 
					
						
							|  |  |  |               run_as_not_developer { test "brew", "install", dependent.name } | 
					
						
							|  |  |  |               next if steps.last.failed? | 
					
						
							|  |  |  |             end | 
					
						
							| 
									
										
										
										
											2015-01-08 20:49:24 +00:00
										 |  |  |           end | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |           next unless dependent.installed? | 
					
						
							|  |  |  |           test "brew", "linkage", "--test", dependent.name | 
					
						
							|  |  |  |           if testable_dependents.include? dependent | 
					
						
							|  |  |  |             test "brew", "test", "--verbose", dependent.name | 
					
						
							| 
									
										
										
										
											2014-12-28 18:16:49 +00:00
										 |  |  |           end | 
					
						
							| 
									
										
										
										
											2014-12-18 17:03:17 +00:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |         test "brew", "uninstall", "--force", formula_name | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-14 13:53:24 +01:00
										 |  |  |       if formula.devel && formula.stable? \ | 
					
						
							|  |  |  |          && !ARGV.include?("--HEAD") && !ARGV.include?("--fast") \ | 
					
						
							| 
									
										
										
										
											2014-11-10 20:40:29 -06:00
										 |  |  |          && satisfied_requirements?(formula, :devel) | 
					
						
							| 
									
										
										
										
											2015-12-10 10:41:43 +00:00
										 |  |  |         test "brew", "fetch", "--retry", "--devel", *fetch_args | 
					
						
							| 
									
										
										
										
											2016-04-10 22:53:56 -04:00
										 |  |  |         run_as_not_developer do | 
					
						
							|  |  |  |           test "brew", "install", "--devel", formula_name, *shared_install_args | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         devel_install_passed = steps.last.passed? | 
					
						
							| 
									
										
										
										
											2014-12-27 13:03:40 +00:00
										 |  |  |         test "brew", "audit", "--devel", *audit_args | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         if devel_install_passed | 
					
						
							| 
									
										
										
										
											2016-04-10 22:53:56 -04:00
										 |  |  |           test "brew", "test", "--devel", formula_name, *shared_test_args if formula.test_defined? | 
					
						
							| 
									
										
										
										
											2016-01-15 20:26:20 +08:00
										 |  |  |           test "brew", "uninstall", "--devel", "--force", formula_name | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2016-08-05 22:01:32 +08:00
										 |  |  |       test "brew", "uninstall", "--force", *unchanged_dependencies unless unchanged_dependencies.empty? | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def homebrew | 
					
						
							|  |  |  |       @category = __method__ | 
					
						
							| 
									
										
										
										
											2015-09-11 15:29:16 +01:00
										 |  |  |       return if @skip_homebrew | 
					
						
							| 
									
										
										
										
											2016-05-28 18:49:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 13:25:33 +01:00
										 |  |  |       if !@tap && (@formulae.empty? || @test_default_formula) | 
					
						
							| 
									
										
										
										
											2016-09-16 17:17:50 +01:00
										 |  |  |         # TODO: try to fix this on Linux at some stage. | 
					
						
							|  |  |  |         if OS.mac? | 
					
						
							|  |  |  |           # test update from origin/master to current commit. | 
					
						
							|  |  |  |           test "brew", "update-test" | 
					
						
							|  |  |  |           # test no-op update from current commit (to current commit, a no-op). | 
					
						
							|  |  |  |           test "brew", "update-test", "--commit=HEAD" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 14:28:44 +01:00
										 |  |  |         test "brew", "style" | 
					
						
							| 
									
										
										
										
											2016-09-16 17:17:50 +01:00
										 |  |  |         test "brew", "readall", "--syntax" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |         coverage_args = [] | 
					
						
							|  |  |  |         if ARGV.include?("--coverage") | 
					
						
							|  |  |  |           if ENV["JENKINS_HOME"] | 
					
						
							| 
									
										
										
										
											2016-09-17 12:55:46 +01:00
										 |  |  |             if OS.mac? && MacOS.version == :sierra | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |               coverage_args << "--coverage" | 
					
						
							|  |  |  |             end | 
					
						
							|  |  |  |           else | 
					
						
							|  |  |  |             coverage_args << "--coverage" | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         test "brew", "tests", "--no-compat" | 
					
						
							|  |  |  |         test "brew", "tests", "--generic" | 
					
						
							|  |  |  |         test "brew", "tests", "--official-cmd-taps", *coverage_args | 
					
						
							| 
									
										
										
										
											2016-09-16 17:17:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-26 11:46:32 +02:00
										 |  |  |         if OS.mac? | 
					
						
							| 
									
										
										
										
											2016-08-17 14:47:24 +01:00
										 |  |  |           run_as_not_developer { test "brew", "tap", "caskroom/cask" } | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |           test "brew", "cask-tests", *coverage_args | 
					
						
							| 
									
										
										
										
											2016-08-17 09:09:55 +01:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-09-04 11:04:36 +01:00
										 |  |  |       elsif @tap | 
					
						
							| 
									
										
										
										
											2016-09-18 14:28:44 +01:00
										 |  |  |         if @tap.name == "homebrew/core" | 
					
						
							|  |  |  |           test "brew", "style", @tap.name | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-05-30 17:01:11 +01:00
										 |  |  |         test "brew", "readall", "--aliases", @tap.name | 
					
						
							| 
									
										
										
										
											2015-09-11 23:05:17 +08:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 14:14:26 +01:00
										 |  |  |     def cleanup_git | 
					
						
							| 
									
										
										
										
											2015-08-11 14:18:26 +01:00
										 |  |  |       git "gc", "--auto" | 
					
						
							| 
									
										
										
										
											2016-09-11 14:14:26 +01:00
										 |  |  |       test "git", "clean", "-ffdx", "--exclude=Library/Taps" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Tap.names.each do |tap| | 
					
						
							|  |  |  |         next if tap == "homebrew/core" | 
					
						
							|  |  |  |         next if tap == @tap.to_s | 
					
						
							|  |  |  |         safe_system "brew", "untap", tap | 
					
						
							| 
									
										
										
										
											2016-07-26 21:00:00 -06:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2016-09-04 11:26:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 19:30:00 +01:00
										 |  |  |       Formula.installed.each do |formula| | 
					
						
							|  |  |  |         safe_system "brew", "uninstall", "--force", formula | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2016-09-19 11:24:31 +01:00
										 |  |  |       safe_system "brew", "prune" | 
					
						
							| 
									
										
										
										
											2016-09-18 19:30:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-06 12:00:08 +01:00
										 |  |  |       unless @repository == HOMEBREW_REPOSITORY | 
					
						
							|  |  |  |         HOMEBREW_REPOSITORY.cd do | 
					
						
							|  |  |  |           safe_system "git", "checkout", "-f", "master" | 
					
						
							|  |  |  |           safe_system "git", "reset", "--hard", "origin/master" | 
					
						
							| 
									
										
										
										
											2016-09-11 12:31:44 +01:00
										 |  |  |           safe_system "git", "clean", "-ffdx", "--exclude=Library/Taps" | 
					
						
							| 
									
										
										
										
											2016-09-06 12:00:08 +01:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Pathname.glob("#{HOMEBREW_LIBRARY}/Taps/*/*").each do |git_repo| | 
					
						
							| 
									
										
										
										
											2016-09-04 11:26:38 +01:00
										 |  |  |         next if @repository == git_repo | 
					
						
							|  |  |  |         git_repo.cd do | 
					
						
							| 
									
										
										
										
											2016-07-15 13:10:39 +01:00
										 |  |  |           safe_system "git", "checkout", "-f", "master" | 
					
						
							| 
									
										
										
										
											2016-07-15 13:19:44 +01:00
										 |  |  |           safe_system "git", "reset", "--hard", "origin/master" | 
					
						
							| 
									
										
										
										
											2016-07-15 13:10:39 +01:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-04-03 00:58:53 -04:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2016-09-11 14:14:26 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def cleanup_before | 
					
						
							|  |  |  |       @category = __method__ | 
					
						
							|  |  |  |       return unless ARGV.include? "--cleanup" | 
					
						
							|  |  |  |       git "stash" | 
					
						
							|  |  |  |       git "am", "--abort" | 
					
						
							|  |  |  |       git "rebase", "--abort" | 
					
						
							|  |  |  |       unless ARGV.include? "--no-pull" | 
					
						
							|  |  |  |         git "checkout", "-f", "master" | 
					
						
							|  |  |  |         git "reset", "--hard", "origin/master" | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       cleanup_git | 
					
						
							| 
									
										
										
										
											2016-09-04 11:26:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-03 12:42:44 +08:00
										 |  |  |       pr_locks = "#{@repository}/.git/refs/remotes/*/pr/*/*.lock" | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       Dir.glob(pr_locks) { |lock| FileUtils.rm_rf lock } | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def cleanup_after | 
					
						
							|  |  |  |       @category = __method__ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  |       if @start_branch && !@start_branch.empty? && \ | 
					
						
							|  |  |  |          (ARGV.include?("--cleanup") || @url || @hash) | 
					
						
							| 
									
										
										
										
											2015-12-07 14:08:55 +00:00
										 |  |  |         checkout_args = [@start_branch] | 
					
						
							|  |  |  |         checkout_args << "-f" if ARGV.include? "--cleanup" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         test "git", "checkout", *checkout_args | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       if ARGV.include? "--cleanup" | 
					
						
							| 
									
										
										
										
											2016-07-15 13:19:44 +01:00
										 |  |  |         git "reset", "--hard", "origin/master" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         git "stash", "pop" | 
					
						
							| 
									
										
										
										
											2015-08-13 08:22:24 +01:00
										 |  |  |         test "brew", "cleanup", "--prune=7" | 
					
						
							| 
									
										
										
										
											2016-09-04 11:26:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 14:14:26 +01:00
										 |  |  |         cleanup_git | 
					
						
							| 
									
										
										
										
											2016-07-15 13:19:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-13 10:55:29 +01:00
										 |  |  |         if ARGV.include? "--local" | 
					
						
							|  |  |  |           FileUtils.rm_rf ENV["HOMEBREW_HOME"] | 
					
						
							|  |  |  |           FileUtils.rm_rf ENV["HOMEBREW_LOGS"] | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       FileUtils.rm_rf @brewbot_root unless ARGV.include? "--keep-logs" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test(*args) | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |       options = args.last.is_a?(Hash) ? args.pop : {} | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       options[:repository] = @repository | 
					
						
							|  |  |  |       step = Step.new self, args, options | 
					
						
							|  |  |  |       step.run | 
					
						
							|  |  |  |       steps << step | 
					
						
							|  |  |  |       step | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def check_results | 
					
						
							| 
									
										
										
										
											2015-02-17 18:02:05 +08:00
										 |  |  |       steps.all? do |step| | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         case step.status | 
					
						
							| 
									
										
										
										
											2015-02-17 18:02:05 +08:00
										 |  |  |         when :passed  then true | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         when :running then raise | 
					
						
							| 
									
										
										
										
											2015-02-17 18:02:05 +08:00
										 |  |  |         when :failed  then false | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def formulae | 
					
						
							|  |  |  |       changed_formulae_dependents = {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       @formulae.each do |formula| | 
					
						
							| 
									
										
										
										
											2016-08-25 22:35:21 -07:00
										 |  |  |         formula_dependencies = Utils.popen_read("brew", "deps", "--full-name", "--include-build", formula).split("\n") | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         unchanged_dependencies = formula_dependencies - @formulae | 
					
						
							|  |  |  |         changed_dependences = formula_dependencies - unchanged_dependencies | 
					
						
							|  |  |  |         changed_dependences.each do |changed_formula| | 
					
						
							|  |  |  |           changed_formulae_dependents[changed_formula] ||= 0
 | 
					
						
							|  |  |  |           changed_formulae_dependents[changed_formula] += 1
 | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       changed_formulae = changed_formulae_dependents.sort do |a1, a2| | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         a2[1].to_i <=> a1[1].to_i | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |       changed_formulae.map!(&:first) | 
					
						
							|  |  |  |       unchanged_formulae = @formulae - changed_formulae | 
					
						
							|  |  |  |       changed_formulae + unchanged_formulae | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def head_only_tap?(formula) | 
					
						
							| 
									
										
										
										
											2015-09-18 22:19:53 +08:00
										 |  |  |       formula.head && formula.devel.nil? && formula.stable.nil? && formula.tap == "homebrew/homebrew-head-only" | 
					
						
							| 
									
										
										
										
											2015-01-19 13:39:38 +00:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     def devel_only_tap?(formula) | 
					
						
							| 
									
										
										
										
											2015-09-18 22:19:53 +08:00
										 |  |  |       formula.devel && formula.stable.nil? && formula.tap == "homebrew/homebrew-devel-only" | 
					
						
							| 
									
										
										
										
											2015-01-19 13:39:38 +00:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     def run | 
					
						
							|  |  |  |       cleanup_before | 
					
						
							| 
									
										
										
										
											2015-10-15 15:19:12 +08:00
										 |  |  |       begin | 
					
						
							|  |  |  |         download | 
					
						
							|  |  |  |         setup | 
					
						
							|  |  |  |         homebrew | 
					
						
							|  |  |  |         formulae.each do |f| | 
					
						
							|  |  |  |           formula(f) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       ensure | 
					
						
							|  |  |  |         cleanup_after | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |       check_results | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-18 20:33:50 +08:00
										 |  |  |   def test_ci_upload(tap) | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |     # Don't trust formulae we're uploading | 
					
						
							|  |  |  |     ENV["HOMEBREW_DISABLE_LOAD_FORMULA"] = "1" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     bintray_user = ENV["BINTRAY_USER"] | 
					
						
							|  |  |  |     bintray_key = ENV["BINTRAY_KEY"] | 
					
						
							|  |  |  |     if !bintray_user || !bintray_key | 
					
						
							|  |  |  |       raise "Missing BINTRAY_USER or BINTRAY_KEY variables!" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |     # Don't pass keys/cookies to subprocesses | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     ENV["BINTRAY_KEY"] = nil | 
					
						
							|  |  |  |     ENV["HUDSON_SERVER_COOKIE"] = nil | 
					
						
							|  |  |  |     ENV["JENKINS_SERVER_COOKIE"] = nil | 
					
						
							|  |  |  |     ENV["HUDSON_COOKIE"] = nil | 
					
						
							| 
									
										
										
										
											2016-09-11 11:28:15 +01:00
										 |  |  |     ENV["COVERALLS_REPO_TOKEN"] = nil | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ARGV << "--verbose" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 11:28:15 +01:00
										 |  |  |     bottles = Dir["*.bottle*.*"] | 
					
						
							|  |  |  |     if bottles.empty? | 
					
						
							|  |  |  |       jenkins = ENV["JENKINS_HOME"] | 
					
						
							|  |  |  |       job = ENV["UPSTREAM_JOB_NAME"] | 
					
						
							|  |  |  |       id = ENV["UPSTREAM_BUILD_ID"] | 
					
						
							|  |  |  |       raise "Missing Jenkins variables!" if !jenkins || !job || !id | 
					
						
							| 
									
										
										
										
											2016-09-11 21:43:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 11:28:15 +01:00
										 |  |  |       bottles = Dir["#{jenkins}/jobs/#{job}/configurations/axis-version/*/builds/#{id}/archive/*.bottle*.*"] | 
					
						
							|  |  |  |       return if bottles.empty? | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |       FileUtils.cp bottles, Dir.pwd, verbose: true | 
					
						
							| 
									
										
										
										
											2016-09-11 21:43:37 +01:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-25 22:10:49 +01:00
										 |  |  |     json_files = Dir.glob("*.bottle.json") | 
					
						
							|  |  |  |     bottles_hash = json_files.reduce({}) do |hash, json_file| | 
					
						
							|  |  |  |       deep_merge_hashes hash, Utils::JSON.load(IO.read(json_file)) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-25 22:14:49 +01:00
										 |  |  |     first_formula_name = bottles_hash.keys.first | 
					
						
							| 
									
										
										
										
											2016-06-27 20:03:37 +08:00
										 |  |  |     tap = Tap.fetch(first_formula_name.rpartition("/").first.chuzzle || "homebrew/core") | 
					
						
							| 
									
										
										
										
											2016-06-25 22:10:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     ENV["GIT_AUTHOR_NAME"] = ENV["GIT_COMMITTER_NAME"] = "BrewTestBot" | 
					
						
							|  |  |  |     ENV["GIT_AUTHOR_EMAIL"] = ENV["GIT_COMMITTER_EMAIL"] = "brew-test-bot@googlegroups.com" | 
					
						
							| 
									
										
										
										
											2016-01-14 15:52:10 +08:00
										 |  |  |     ENV["GIT_WORK_TREE"] = tap.path | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     ENV["GIT_DIR"] = "#{ENV["GIT_WORK_TREE"]}/.git" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     quiet_system "git", "am", "--abort" | 
					
						
							|  |  |  |     quiet_system "git", "rebase", "--abort" | 
					
						
							|  |  |  |     safe_system "git", "checkout", "-f", "master" | 
					
						
							|  |  |  |     safe_system "git", "reset", "--hard", "origin/master" | 
					
						
							|  |  |  |     safe_system "brew", "update" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 21:43:37 +01:00
										 |  |  |     if (pr = ENV["UPSTREAM_PULL_REQUEST"]) | 
					
						
							| 
									
										
										
										
											2016-05-28 18:48:51 +01:00
										 |  |  |       pull_pr = "https://github.com/#{tap.user}/homebrew-#{tap.repo}/pull/#{pr}" | 
					
						
							|  |  |  |       safe_system "brew", "pull", "--clean", pull_pr | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-12 13:51:26 +01:00
										 |  |  |     if ENV["UPSTREAM_BOTTLE_KEEP_OLD"] || ENV["BOT_PARAMS"].to_s.include?("--keep-old") | 
					
						
							| 
									
										
										
										
											2016-09-04 20:07:35 +01:00
										 |  |  |       system "brew", "bottle", "--merge", "--write", "--keep-old", *json_files | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       system "brew", "bottle", "--merge", "--write", *json_files | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-03 00:09:30 +08:00
										 |  |  |     remote = "git@github.com:BrewTestBot/homebrew-#{tap.repo}.git" | 
					
						
							| 
									
										
										
										
											2016-09-11 21:43:37 +01:00
										 |  |  |     git_tag = if pr | 
					
						
							|  |  |  |       "pr-#{pr}" | 
					
						
							|  |  |  |     elsif (upstream_number = ENV["UPSTREAM_BUILD_NUMBER"]) | 
					
						
							|  |  |  |       "testing-#{upstream_number}" | 
					
						
							|  |  |  |     elsif (number = ENV["BUILD_NUMBER"]) | 
					
						
							|  |  |  |       "other-#{number}" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     if git_tag | 
					
						
							|  |  |  |       safe_system "git", "push", "--force", remote, "master:master", ":refs/tags/#{git_tag}" | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     formula_packaged = {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |     bottles_hash.each do |formula_name, bottle_hash| | 
					
						
							|  |  |  |       version = bottle_hash["formula"]["pkg_version"] | 
					
						
							|  |  |  |       bintray_package = bottle_hash["bintray"]["package"] | 
					
						
							|  |  |  |       bintray_repo = bottle_hash["bintray"]["repository"] | 
					
						
							|  |  |  |       bintray_repo_url = "https://api.bintray.com/packages/homebrew/#{bintray_repo}" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |       bottle_hash["bottle"]["tags"].each do |_tag, tag_hash| | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |         filename = tag_hash["filename"] | 
					
						
							|  |  |  |         if system "curl", "-I", "--silent", "--fail", "--output", "/dev/null", | 
					
						
							|  |  |  |                   "#{BottleSpecification::DEFAULT_DOMAIN}/#{bintray_repo}/#{filename}" | 
					
						
							|  |  |  |           raise <<-EOS.undent
 | 
					
						
							|  |  |  |             #{filename} is already published. Please remove it manually from | 
					
						
							|  |  |  |             https://bintray.com/homebrew/#{bintray_repo}/#{bintray_package}/view#files | 
					
						
							| 
									
										
										
										
											2016-02-27 22:13:31 -08:00
										 |  |  |           EOS | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-28 15:54:05 +01:00
										 |  |  |         unless formula_packaged[formula_name] | 
					
						
							|  |  |  |           package_url = "#{bintray_repo_url}/#{bintray_package}" | 
					
						
							|  |  |  |           unless system "curl", "--silent", "--fail", "--output", "/dev/null", package_url | 
					
						
							|  |  |  |             package_blob = <<-EOS.undent
 | 
					
						
							|  |  |  |               {"name": "#{bintray_package}", | 
					
						
							|  |  |  |                "public_download_numbers": true, | 
					
						
							|  |  |  |                "public_stats": true} | 
					
						
							|  |  |  |             EOS | 
					
						
							|  |  |  |             curl "--silent", "--fail", "-u#{bintray_user}:#{bintray_key}", | 
					
						
							|  |  |  |                  "-H", "Content-Type: application/json", | 
					
						
							|  |  |  |                  "-d", package_blob, bintray_repo_url | 
					
						
							|  |  |  |             puts | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |           formula_packaged[formula_name] = true | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         content_url = "https://api.bintray.com/content/homebrew" | 
					
						
							|  |  |  |         content_url += "/#{bintray_repo}/#{bintray_package}/#{version}/#{filename}" | 
					
						
							|  |  |  |         content_url += "?override=1" | 
					
						
							|  |  |  |         curl "--silent", "--fail", "-u#{bintray_user}:#{bintray_key}", | 
					
						
							|  |  |  |              "-T", filename, content_url | 
					
						
							|  |  |  |         puts | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 21:43:37 +01:00
										 |  |  |     if git_tag | 
					
						
							|  |  |  |       safe_system "git", "tag", "--force", git_tag | 
					
						
							|  |  |  |       safe_system "git", "push", "--force", remote, "master:master", "refs/tags/#{git_tag}" | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:28:36 +08:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |   def sanitize_argv_and_env | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     if Pathname.pwd == HOMEBREW_PREFIX && ARGV.include?("--cleanup") | 
					
						
							|  |  |  |       odie "cannot use --cleanup from HOMEBREW_PREFIX as it will delete all output." | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     ENV["HOMEBREW_DEVELOPER"] = "1" | 
					
						
							| 
									
										
										
										
											2015-08-17 13:58:12 +08:00
										 |  |  |     ENV["HOMEBREW_SANDBOX"] = "1" | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     ENV["HOMEBREW_NO_EMOJI"] = "1" | 
					
						
							| 
									
										
										
										
											2015-09-21 15:11:22 +01:00
										 |  |  |     ENV["HOMEBREW_FAIL_LOG_LINES"] = "150" | 
					
						
							| 
									
										
										
										
											2016-03-28 10:26:21 -07:00
										 |  |  |     ENV["HOMEBREW_EXPERIMENTAL_FILTER_FLAGS_ON_DEPS"] = "1" | 
					
						
							| 
									
										
										
										
											2016-09-20 08:42:30 +01:00
										 |  |  |     ENV["PATH"] = "#{HOMEBREW_PREFIX}/bin:#{HOMEBREW_PREFIX}/sbin:#{ENV["PATH"]}" | 
					
						
							| 
									
										
										
										
											2015-09-23 15:40:27 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |     travis = !ENV["TRAVIS"].nil? | 
					
						
							|  |  |  |     if travis | 
					
						
							| 
									
										
										
										
											2015-09-23 15:40:27 +08:00
										 |  |  |       ARGV << "--verbose" | 
					
						
							|  |  |  |       ENV["HOMEBREW_VERBOSE_USING_DOTS"] = "1" | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Only report coverage if build runs on macOS and this is indeed Homebrew, | 
					
						
							|  |  |  |     # as we don't want this to be averaged with inferior Linux test coverage. | 
					
						
							|  |  |  |     if OS.mac? && (ENV["COVERALLS_REPO_TOKEN"] || ENV["CODECOV_TOKEN"]) | 
					
						
							|  |  |  |       ARGV << "--coverage" | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-08-06 01:52:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 20:43:42 +01:00
										 |  |  |     travis_pr = ENV["TRAVIS_PULL_REQUEST"] && ENV["TRAVIS_PULL_REQUEST"] != "false" | 
					
						
							|  |  |  |     jenkins_pr = !ENV["ghprbPullLink"].nil? | 
					
						
							|  |  |  |     jenkins_branch = !ENV["GIT_COMMIT"].nil? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ARGV.include?("--ci-auto") | 
					
						
							|  |  |  |       if travis_pr || jenkins_pr | 
					
						
							|  |  |  |         ARGV << "--ci-pr" | 
					
						
							|  |  |  |       elsif travis || jenkins_branch | 
					
						
							|  |  |  |         ARGV << "--ci-master" | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         ARGV << "--ci-testing" | 
					
						
							| 
									
										
										
										
											2016-08-06 01:52:28 +02:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-09-23 15:40:27 +08:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-15 17:32:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     if ARGV.include?("--ci-master") || ARGV.include?("--ci-pr") \ | 
					
						
							|  |  |  |        || ARGV.include?("--ci-testing") | 
					
						
							| 
									
										
										
										
											2015-11-19 13:29:40 +00:00
										 |  |  |       ARGV << "--cleanup" if ENV["JENKINS_HOME"] | 
					
						
							| 
									
										
										
										
											2016-09-13 08:18:43 +01:00
										 |  |  |       ARGV << "--junit" << "--local" << "--test-default-formula" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-09-13 08:18:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     if ARGV.include? "--ci-master" | 
					
						
							| 
									
										
										
										
											2015-11-10 09:29:24 +00:00
										 |  |  |       ARGV << "--fast" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |     if ARGV.include? "--local" | 
					
						
							| 
									
										
										
										
											2016-06-01 11:24:45 +01:00
										 |  |  |       ENV["HOMEBREW_CACHE"] = "#{ENV["HOME"]}/Library/Caches/Homebrew" | 
					
						
							|  |  |  |       mkdir_p ENV["HOMEBREW_CACHE"] | 
					
						
							| 
									
										
										
										
											2015-08-13 10:55:29 +01:00
										 |  |  |       ENV["HOMEBREW_HOME"] = ENV["HOME"] = "#{Dir.pwd}/home" | 
					
						
							| 
									
										
										
										
											2015-08-03 13:09:07 +01:00
										 |  |  |       mkdir_p ENV["HOME"] | 
					
						
							|  |  |  |       ENV["HOMEBREW_LOGS"] = "#{Dir.pwd}/logs" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:33:50 +08:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def test_bot | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |     sanitize_argv_and_env | 
					
						
							| 
									
										
										
										
											2015-09-18 20:33:50 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     tap = resolve_test_tap | 
					
						
							| 
									
										
										
										
											2016-04-19 15:30:18 +08:00
										 |  |  |     # Tap repository if required, this is done before everything else | 
					
						
							|  |  |  |     # because Formula parsing and/or git commit hash lookup depends on it. | 
					
						
							|  |  |  |     # At the same time, make sure Tap is not a shallow clone. | 
					
						
							| 
									
										
										
										
											2016-08-18 17:32:35 +01:00
										 |  |  |     # bottle rebuild and bottle upload rely on full clone. | 
					
						
							| 
									
										
										
										
											2016-09-20 19:30:27 +01:00
										 |  |  |     if tap | 
					
						
							|  |  |  |       ENV["HOMEBREW_UPDATE_TO_TAG"] = "1" | 
					
						
							|  |  |  |       safe_system "brew", "tap", tap.name, "--full" | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-18 20:33:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-11 17:14:51 +08:00
										 |  |  |     if ARGV.include? "--ci-upload" | 
					
						
							| 
									
										
										
										
											2015-09-18 20:33:50 +08:00
										 |  |  |       return test_ci_upload(tap) | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     tests = [] | 
					
						
							|  |  |  |     any_errors = false | 
					
						
							| 
									
										
										
										
											2015-09-11 22:44:00 +08:00
										 |  |  |     skip_homebrew = ARGV.include?("--skip-homebrew") | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     if ARGV.named.empty? | 
					
						
							| 
									
										
										
										
											2016-09-13 13:25:33 +01:00
										 |  |  |       # With no arguments just build the most recent commit. | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |       current_test = Test.new("HEAD", tap: tap, skip_homebrew: skip_homebrew) | 
					
						
							| 
									
										
										
										
											2016-09-13 08:18:43 +01:00
										 |  |  |       any_errors = !current_test.run | 
					
						
							|  |  |  |       tests << current_test | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     else | 
					
						
							|  |  |  |       ARGV.named.each do |argument| | 
					
						
							| 
									
										
										
										
											2014-10-21 15:34:20 +01:00
										 |  |  |         test_error = false | 
					
						
							|  |  |  |         begin | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |           current_test = Test.new(argument, tap: tap, skip_homebrew: skip_homebrew) | 
					
						
							| 
									
										
										
										
											2015-09-11 22:36:27 +08:00
										 |  |  |           skip_homebrew = true | 
					
						
							| 
									
										
										
										
											2014-10-21 15:34:20 +01:00
										 |  |  |         rescue ArgumentError => e | 
					
						
							|  |  |  |           test_error = true | 
					
						
							|  |  |  |           ofail e.message | 
					
						
							| 
									
										
										
										
											2014-11-10 19:24:46 -06:00
										 |  |  |         else | 
					
						
							| 
									
										
										
										
											2016-09-13 08:18:43 +01:00
										 |  |  |           test_error = !current_test.run | 
					
						
							|  |  |  |           tests << current_test | 
					
						
							| 
									
										
										
										
											2014-10-21 15:34:20 +01:00
										 |  |  |         end | 
					
						
							| 
									
										
										
										
											2014-10-21 12:12:24 +01:00
										 |  |  |         any_errors ||= test_error | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ARGV.include? "--junit" | 
					
						
							|  |  |  |       xml_document = REXML::Document.new | 
					
						
							|  |  |  |       xml_document << REXML::XMLDecl.new | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:53 -05:00
										 |  |  |       testsuites = xml_document.add_element "testsuites" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |       tests.each do |test| | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:53 -05:00
										 |  |  |         testsuite = testsuites.add_element "testsuite" | 
					
						
							| 
									
										
										
										
											2016-07-29 21:58:17 -06:00
										 |  |  |         testsuite.add_attribute "name", "brew-test-bot.#{Utils::Bottles.tag}" | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:53 -05:00
										 |  |  |         testsuite.add_attribute "tests", test.steps.count | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         test.steps.each do |step| | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:53 -05:00
										 |  |  |           testcase = testsuite.add_element "testcase" | 
					
						
							|  |  |  |           testcase.add_attribute "name", step.command_short | 
					
						
							|  |  |  |           testcase.add_attribute "status", step.status | 
					
						
							|  |  |  |           testcase.add_attribute "time", step.time | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:52 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |           next unless step.output? | 
					
						
							|  |  |  |           output = sanitize_output_for_xml(step.output) | 
					
						
							|  |  |  |           cdata = REXML::CData.new output | 
					
						
							| 
									
										
										
										
											2014-12-02 21:14:53 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  |           if step.passed? | 
					
						
							|  |  |  |             elem = testcase.add_element "system-out" | 
					
						
							|  |  |  |           else | 
					
						
							|  |  |  |             elem = testcase.add_element "failure" | 
					
						
							|  |  |  |             elem.add_attribute "message", "#{step.status}: #{step.command.join(" ")}" | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |           end | 
					
						
							| 
									
										
										
										
											2016-09-11 17:41:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |           elem << cdata | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       open("brew-test-bot.xml", "w") do |xml_file| | 
					
						
							|  |  |  |         pretty_print_indent = 2
 | 
					
						
							|  |  |  |         xml_document.write(xml_file, pretty_print_indent) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-10-15 15:19:12 +08:00
										 |  |  |   ensure | 
					
						
							| 
									
										
										
										
											2015-11-04 14:36:44 +08:00
										 |  |  |     if ARGV.include? "--clean-cache" | 
					
						
							|  |  |  |       HOMEBREW_CACHE.children.each(&:rmtree) | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       Dir.glob("*.bottle*.tar.gz") do |bottle_file| | 
					
						
							|  |  |  |         FileUtils.rm_f HOMEBREW_CACHE/bottle_file | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  |     Homebrew.failed = any_errors | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |   def sanitize_output_for_xml(output) | 
					
						
							|  |  |  |     unless output.empty? | 
					
						
							|  |  |  |       # Remove invalid XML CData characters from step output. | 
					
						
							| 
									
										
										
										
											2016-08-18 14:35:39 +08:00
										 |  |  |       invalid_xml_pat = /[^\x09\x0A\x0D\x20-\uD7FF\uE000-\uFFFD\u{10000}-\u{10FFFF}]/ | 
					
						
							|  |  |  |       output = output.gsub(invalid_xml_pat, "\uFFFD") | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-06 16:48:07 -04:00
										 |  |  |       # Truncate to 1MB to avoid hitting CI limits | 
					
						
							|  |  |  |       if output.bytesize > MAX_STEP_OUTPUT_SIZE | 
					
						
							| 
									
										
										
										
											2016-09-17 15:32:44 +01:00
										 |  |  |         output = truncate_text_to_approximate_size(output, MAX_STEP_OUTPUT_SIZE, front_weight: 0.0) | 
					
						
							| 
									
										
										
										
											2016-04-05 17:23:24 -04:00
										 |  |  |         output = "truncated output to 1MB:\n" + output | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     output | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2014-09-20 14:24:52 +01:00
										 |  |  | end |