aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/dev-cmd/tests.rb
diff options
context:
space:
mode:
authorMarkus Reiter2017-02-10 21:21:57 +0100
committerMarkus Reiter2017-02-11 15:59:54 +0100
commitc4ac30830273c9a638b4a7c32d31b0ab22bb39f8 (patch)
treee361fdf160a148caa2952f5b64da9846c7102660 /Library/Homebrew/dev-cmd/tests.rb
parentab785ca4146eb027e639a43f4efd8925886dfc85 (diff)
downloadbrew-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.rb45
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