Module: Buildr::TestFramework

Defined in:
lib/buildr/core/test.rb,
lib/buildr/java/test_result.rb

Overview

:nodoc:

Defined Under Namespace

Modules: JRubyBased Classes: Base, Java, JavaBDD, TestResult

Class Method Summary collapse

Class Method Details

.add(framework) ⇒ Object Also known as: <<

Adds a test framework to the list of supported frameworks.

For example:

Buildr::TestFramework << Buildr::JUnit


49
50
51
52
# File 'lib/buildr/core/test.rb', line 49

def add(framework)
  @frameworks ||= []
  @frameworks |= [framework]
end

.frameworksObject

Returns a list of available test frameworks.



56
57
58
# File 'lib/buildr/core/test.rb', line 56

def frameworks
  @frameworks ||= []
end

.has?(name) ⇒ Boolean

Returns true if the specified test framework exists.

Returns:

  • (Boolean)


26
27
28
# File 'lib/buildr/core/test.rb', line 26

def has?(name)
  frameworks.any? { |framework| framework.to_sym == name.to_sym }
end

.select(name) ⇒ Object

Select a test framework by its name.



31
32
33
# File 'lib/buildr/core/test.rb', line 31

def select(name)
  frameworks.detect { |framework| framework.to_sym == name.to_sym }
end

.select_from(project) ⇒ Object

Identify which test framework applies for this project.



36
37
38
39
40
41
42
43
# File 'lib/buildr/core/test.rb', line 36

def select_from(project)
  # Look for a suitable test framework based on the compiled language,
  # which may return multiple candidates, e.g. JUnit and TestNG for Java.
  # Pick the one used in the parent project, if not, whichever comes first.
  candidates = frameworks.select { |framework| framework.applies_to?(project) }
  parent = project.parent
  parent && candidates.detect { |framework| framework.to_sym == parent.test.framework } || candidates.first
end