119 lines
3.2 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2014-06-19 17:57:36 -05:00
require "extend/ENV"
2015-04-13 18:05:41 +08:00
require "sandbox"
require "timeout"
2019-04-17 18:25:08 +09:00
require "cli/parser"
module Homebrew
2016-09-26 01:44:51 +02:00
module_function
def test_args
Homebrew::CLI::Parser.new do
usage_banner <<~EOS
`test` [<options>] <formula>
Run the test method provided by an installed formula.
There is no standard output or return code, but generally it should notify the
user if something is wrong with the installed formula.
*Example:* `brew install jruby && brew test jruby`
EOS
switch "--devel",
description: "Test the development version of a formula."
switch "--HEAD",
description: "Test the head version of a formula."
switch "--keep-tmp",
description: "Keep the temporary files created for the test."
switch :verbose
switch :debug
conflicts "--devel", "--HEAD"
end
end
2011-03-10 21:28:49 -08:00
def test
test_args.parse
raise FormulaUnspecifiedError if ARGV.named.empty?
require "formula_assertions"
2015-05-17 21:13:09 +08:00
ARGV.resolved_formulae.each do |f|
2011-03-10 21:28:49 -08:00
# Cannot test uninstalled formulae
unless f.installed?
2015-05-27 21:14:35 +08:00
ofail "Testing requires the latest version of #{f.full_name}"
2011-03-10 21:28:49 -08:00
next
end
# Cannot test formulae without a test method
2013-01-07 17:34:56 -06:00
unless f.test_defined?
2015-05-27 21:14:35 +08:00
ofail "#{f.full_name} defines no test"
2011-03-10 21:28:49 -08:00
next
end
# Don't test unlinked formulae
if !ARGV.force? && !f.keg_only? && !f.linked?
ofail "#{f.full_name} is not linked"
next
end
# Don't test formulae missing test dependencies
missing_test_deps = f.recursive_dependencies do |_, dependency|
Dependency.prune if dependency.installed?
next if dependency.test?
2018-09-17 02:45:00 +02:00
Dependency.prune if dependency.optional?
Dependency.prune if dependency.build?
end.map(&:to_s)
unless missing_test_deps.empty?
ofail "#{f.full_name} is missing test dependencies: #{missing_test_deps.join(" ")}"
next
end
2015-05-27 21:14:35 +08:00
puts "Testing #{f.full_name}"
env = ENV.to_hash
2011-03-10 21:28:49 -08:00
begin
2015-04-13 18:05:41 +08:00
args = %W[
#{RUBY_PATH}
-W0
2018-07-17 14:23:33 +02:00
-I #{$LOAD_PATH.join(File::PATH_SEPARATOR)}
2015-04-13 18:05:41 +08:00
--
#{HOMEBREW_LIBRARY_PATH}/test.rb
#{f.path}
].concat(ARGV.options_only)
if f.head?
args << "--HEAD"
elsif f.devel?
args << "--devel"
end
2015-04-13 18:05:41 +08:00
Utils.safe_fork do
2016-08-14 17:33:17 +01:00
if Sandbox.test?
2015-04-13 18:05:41 +08:00
sandbox = Sandbox.new
2015-04-26 21:59:47 -04:00
f.logs.mkpath
2016-05-27 01:53:08 -04:00
sandbox.record_log(f.logs/"test.sandbox.log")
2015-04-13 18:05:41 +08:00
sandbox.allow_write_temp_and_cache
sandbox.allow_write_log(f)
sandbox.allow_write_xcode
sandbox.allow_write_path(HOMEBREW_PREFIX/"var/cache")
sandbox.allow_write_path(HOMEBREW_PREFIX/"var/homebrew/locks")
sandbox.allow_write_path(HOMEBREW_PREFIX/"var/log")
sandbox.allow_write_path(HOMEBREW_PREFIX/"var/run")
2015-04-13 18:05:41 +08:00
sandbox.exec(*args)
else
exec(*args)
end
2013-06-04 20:34:34 +01:00
end
rescue Exception => e # rubocop:disable Lint/RescueException
ofail "#{f.full_name}: failed"
puts e, e.backtrace
ensure
ENV.replace(env)
2011-03-10 21:28:49 -08:00
end
end
end
end