aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/cmd/test.rb
blob: b47a85ed479bf73c9f6cac1caf91c1cee39fae73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
require "extend/ENV"
require "timeout"

module Homebrew
  TEST_TIMEOUT_SECONDS = 5*60

  if defined?(Gem)
    begin
      gem "minitest", "< 5.0.0"
    rescue Gem::LoadError
      require "test/unit/assertions"
    else
      require "minitest/unit"
      require "test/unit/assertions"
    end
  else
    require "test/unit/assertions"
  end

  if defined?(MiniTest::Assertion)
    FailedAssertion = MiniTest::Assertion
  elsif defined?(Minitest::Assertion)
    FailedAssertion = Minitest::Assertion
  else
    FailedAssertion = Test::Unit::AssertionFailedError
  end

  require "formula_assertions"

  def test
    raise FormulaUnspecifiedError if ARGV.named.empty?

    ENV.extend(Stdenv)
    ENV.setup_build_environment

    ARGV.formulae.each do |f|
      # Cannot test uninstalled formulae
      unless f.installed?
        ofail "Testing requires the latest version of #{f.name}"
        next
      end

      # Cannot test formulae without a test method
      unless f.test_defined?
        ofail "#{f.name} defines no test"
        next
      end

      puts "Testing #{f.name}"

      f.extend(Test::Unit::Assertions)
      f.extend(Homebrew::Assertions)

      begin
        # tests can also return false to indicate failure
        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
      end
    end
  end
end