52 lines
1.1 KiB
Ruby
Raw Normal View History

2014-06-19 17:57:36 -05:00
require "extend/ENV"
require "timeout"
2014-09-18 14:16:07 -05:00
require "debrew"
require "formula_assertions"
module Homebrew
2013-06-04 20:34:34 +01:00
TEST_TIMEOUT_SECONDS = 5*60
2011-03-10 21:28:49 -08:00
def test
raise FormulaUnspecifiedError if ARGV.named.empty?
2013-08-19 12:32:59 -05:00
ENV.extend(Stdenv)
ENV.setup_build_environment
2011-03-10 21:28:49 -08:00
ARGV.formulae.each do |f|
# Cannot test uninstalled formulae
unless f.installed?
ofail "Testing requires the latest version of #{f.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?
ofail "#{f.name} defines no test"
2011-03-10 21:28:49 -08:00
next
end
puts "Testing #{f.name}"
f.extend(Assertions)
2014-09-18 14:16:07 -05:00
f.extend(Debrew::Formula) if ARGV.debug?
env = ENV.to_hash
2011-03-10 21:28:49 -08:00
begin
# tests can also return false to indicate failure
2013-06-04 20:34:34 +01:00
Timeout::timeout TEST_TIMEOUT_SECONDS do
2014-09-18 14:16:07 -05:00
raise if f.run_test == false
2013-06-04 20:34:34 +01:00
end
rescue Assertions::FailedAssertion => e
ofail "#{f.name}: failed"
puts e.message
rescue Exception => e
ofail "#{f.name}: failed"
puts e, e.backtrace
ensure
ENV.replace(env)
2011-03-10 21:28:49 -08:00
end
end
end
end