63 lines
1.4 KiB
Ruby
Raw Normal View History

require 'extend/ENV'
require 'hardware'
require 'keg'
2013-06-04 20:34:34 +01:00
require 'timeout'
2011-03-10 21:28:49 -08:00
module Homebrew extend self
2013-06-04 20:34:34 +01:00
TEST_TIMEOUT_SECONDS = 5*60
if defined?(Gem)
begin
gem "minitest", "< 5.0.0"
rescue Gem::LoadError
require "test/unit/assertions"
FailedAssertion = Test::Unit::AssertionFailedError
else
require "minitest/unit"
require "test/unit/assertions"
FailedAssertion = MiniTest::Assertion
end
else
require "test/unit/assertions"
FailedAssertion = Test::Unit::AssertionFailedError
end
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(Test::Unit::Assertions)
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
raise if f.test == false
end
rescue FailedAssertion => e
ofail "#{f.name}: failed"
puts e.message
rescue Exception => e
ofail "#{f.name}: failed"
puts e, e.backtrace
2011-03-10 21:28:49 -08:00
end
end
end
end