diff options
| author | Markus Reiter | 2017-02-10 21:21:57 +0100 | 
|---|---|---|
| committer | Markus Reiter | 2017-02-11 15:59:54 +0100 | 
| commit | c4ac30830273c9a638b4a7c32d31b0ab22bb39f8 (patch) | |
| tree | e361fdf160a148caa2952f5b64da9846c7102660 /Library/Homebrew/dev-cmd/tests.rb | |
| parent | ab785ca4146eb027e639a43f4efd8925886dfc85 (diff) | |
| download | brew-c4ac30830273c9a638b4a7c32d31b0ab22bb39f8.tar.bz2 | |
Allow `brew tests` to run specs.
Diffstat (limited to 'Library/Homebrew/dev-cmd/tests.rb')
| -rw-r--r-- | Library/Homebrew/dev-cmd/tests.rb | 45 | 
1 files changed, 32 insertions, 13 deletions
diff --git a/Library/Homebrew/dev-cmd/tests.rb b/Library/Homebrew/dev-cmd/tests.rb index 9d93fc9e8..244fbe027 100644 --- a/Library/Homebrew/dev-cmd/tests.rb +++ b/Library/Homebrew/dev-cmd/tests.rb @@ -7,10 +7,21 @@ require "tap"  module Homebrew    module_function +  def run_tests(executable, files, args = []) +    opts = [] +    opts << "--serialize-stdout" if ENV["CI"] + +    system "bundle", "exec", executable, *opts, "--", *args, "--", *files + +    return if $?.success? +    Homebrew.failed = true +  end +    def tests      HOMEBREW_LIBRARY_PATH.cd do        ENV.delete "HOMEBREW_VERBOSE"        ENV.delete "VERBOSE" +      ENV.delete("HOMEBREW_CASK_OPTS")        ENV["HOMEBREW_NO_ANALYTICS_THIS_RUN"] = "1"        ENV["HOMEBREW_DEVELOPER"] = "1"        ENV["TESTOPTS"] = "-v" if ARGV.verbose? @@ -45,27 +56,35 @@ module Homebrew        # Make it easier to reproduce test runs.        ENV["SEED"] = ARGV.next if ARGV.include? "--seed" -      files = Dir.glob("test/**/*_test.rb") +      files = Dir.glob("test/**/*_{spec,test}.rb")                   .reject { |p| !OS.mac? && p.start_with?("test/os/mac/") } +                 .reject { |p| !OS.mac? && p.start_with?("test/cask/") }                   .reject { |p| p.start_with?("test/vendor/bundle/") } -      opts = [] -      opts << "--serialize-stdout" if ENV["CI"] - -      args = [] -      args << "--trace" if ARGV.include? "--trace" +      test_args = [] +      test_args << "--trace" if ARGV.include? "--trace"        if ARGV.value("only")          test_name, test_method = ARGV.value("only").split(":", 2) -        files = Dir.glob("test/{#{test_name},#{test_name}/**/*}_test.rb") -        args << "--name=test_#{test_method}" if test_method +        files = Dir.glob("test/{#{test_name},#{test_name}/**/*}_{spec,test}.rb") +        test_args << "--name=test_#{test_method}" if test_method        end -      args += ARGV.named.select { |v| v[/^TEST(OPTS)?=/] } - -      system "bundle", "exec", "parallel_test", *opts, "--", *args, "--", *files - -      Homebrew.failed = !$?.success? +      test_files = files.select { |p| p.end_with?("_test.rb") } +      spec_files = files.select { |p| p.end_with?("_spec.rb") } + +      test_args += ARGV.named.select { |v| v[/^TEST(OPTS)?=/] } +      run_tests "parallel_test", test_files, test_args + +      spec_args = [ +        "--color", +        "-I", HOMEBREW_LIBRARY_PATH/"test", +        "--require", "spec_helper", +        "--format", "progress", +        "--format", "ParallelTests::RSpec::RuntimeLogger", +        "--out", "tmp/parallel_runtime_rspec.log" +      ] +      run_tests "parallel_rspec", spec_files, spec_args        if (fs_leak_log = HOMEBREW_LIBRARY_PATH/"tmp/fs_leak.log").file?          fs_leak_log_content = fs_leak_log.read  | 
