2016-04-10 22:53:56 -04:00
|
|
|
#: * `test` [`--devel`|`--HEAD`] [`--debug`] [`--keep-tmp`] <formula>:
|
2016-09-22 17:12:13 -04:00
|
|
|
#: Most formulae provide a test method. `brew test` <formula> runs this
|
2016-04-08 16:28:43 +02:00
|
|
|
#: test method. There is no standard output or return code, but it should
|
|
|
|
#: generally indicate to the user if something is wrong with the installed
|
|
|
|
#: formula.
|
|
|
|
#:
|
|
|
|
#: To test the development or head version of a formula, use `--devel` or
|
|
|
|
#: `--HEAD`.
|
|
|
|
#:
|
2017-04-02 10:14:21 +01:00
|
|
|
#: If `--debug` (or `-d`) is passed and the test fails, an interactive debugger will be
|
2016-04-08 16:28:43 +02:00
|
|
|
#: launched with access to IRB or a shell inside the temporary test directory.
|
|
|
|
#:
|
2016-04-10 22:53:56 -04:00
|
|
|
#: If `--keep-tmp` is passed, the temporary files created for the test are
|
|
|
|
#: not deleted.
|
|
|
|
#:
|
2016-04-08 16:28:43 +02:00
|
|
|
#: Example: `brew install jruby && brew test jruby`
|
|
|
|
|
2014-06-19 17:57:36 -05:00
|
|
|
require "extend/ENV"
|
2015-01-13 12:33:50 -05:00
|
|
|
require "formula_assertions"
|
2015-04-13 18:05:41 +08:00
|
|
|
require "sandbox"
|
2015-04-21 16:59:23 +08:00
|
|
|
require "timeout"
|
2012-03-12 21:21:33 -07:00
|
|
|
|
2014-06-18 22:41:47 -05:00
|
|
|
module Homebrew
|
2016-09-26 01:44:51 +02:00
|
|
|
module_function
|
|
|
|
|
2011-03-10 21:28:49 -08:00
|
|
|
def test
|
2012-04-20 13:56:51 -05:00
|
|
|
raise FormulaUnspecifiedError if ARGV.named.empty?
|
2012-02-04 00:01:29 -06:00
|
|
|
|
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
|
|
|
|
|
2015-05-27 21:14:35 +08:00
|
|
|
puts "Testing #{f.full_name}"
|
2014-06-18 23:17:49 -05:00
|
|
|
|
2015-01-13 12:19:56 -05:00
|
|
|
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
|
2015-04-28 22:37:27 -04:00
|
|
|
-I #{HOMEBREW_LOAD_PATH}
|
2015-04-13 18:05:41 +08:00
|
|
|
--
|
|
|
|
#{HOMEBREW_LIBRARY_PATH}/test.rb
|
|
|
|
#{f.path}
|
|
|
|
].concat(ARGV.options_only)
|
|
|
|
|
2015-10-09 20:26:39 +08:00
|
|
|
if f.head?
|
|
|
|
args << "--HEAD"
|
|
|
|
elsif f.devel?
|
|
|
|
args << "--devel"
|
|
|
|
end
|
|
|
|
|
2016-08-14 17:33:17 +01:00
|
|
|
Sandbox.print_sandbox_message if Sandbox.test?
|
2015-07-21 14:47:37 +08:00
|
|
|
|
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)
|
2015-08-25 17:34:52 +01:00
|
|
|
sandbox.allow_write_xcode
|
2015-10-09 17:42:21 +08:00
|
|
|
sandbox.allow_write_path(HOMEBREW_PREFIX/"var/cache")
|
|
|
|
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
|
2015-01-13 12:33:50 -05:00
|
|
|
rescue Assertions::FailedAssertion => e
|
2015-05-27 21:14:35 +08:00
|
|
|
ofail "#{f.full_name}: failed"
|
2013-06-08 21:26:16 -05:00
|
|
|
puts e.message
|
2014-06-18 23:27:19 -05:00
|
|
|
rescue Exception => e
|
2015-05-27 21:14:35 +08:00
|
|
|
ofail "#{f.full_name}: failed"
|
2014-06-18 23:27:19 -05:00
|
|
|
puts e, e.backtrace
|
2015-01-13 12:19:56 -05:00
|
|
|
ensure
|
|
|
|
ENV.replace(env)
|
2011-03-10 21:28:49 -08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|