Class: Buildr::TestFramework::Base
Overview
Base class for all test frameworks, with common functionality. Extend and over-ride as you see fit (see JUnit as an example).
Direct Known Subclasses
Instance Attribute Summary collapse
-
#options ⇒ Object
readonly
Options for this test framework.
-
#task ⇒ Object
readonly
The test task we belong to.
Class Method Summary collapse
-
.applies_to?(project) ⇒ Boolean
Returns true if this framework applies to the current project.
-
.dependencies ⇒ Object
Returns a list of dependencies for this framework.
-
.to_sym ⇒ Object
The framework’s identifier (e.g. :junit).
Instance Method Summary collapse
-
#dependencies ⇒ Object
Returns a list of dependenices for this framework.
-
#initialize(test_task, options) ⇒ Base
constructor
Construct a new test framework with the specified options.
-
#run(tests, dependencies) ⇒ Object
TestTask calls this method to run the named (and only those) tests.
-
#tests(dependencies) ⇒ Object
TestTask calls this method to return a list of test names that can be run in this project.
Constructor Details
#initialize(test_task, options) ⇒ Base
Construct a new test framework with the specified options. Note that options may change before the framework is run.
89 90 91 92 |
# File 'lib/buildr/core/test.rb', line 89 def initialize(test_task, ) @options = @task = test_task end |
Instance Attribute Details
#options ⇒ Object (readonly)
Options for this test framework.
95 96 97 |
# File 'lib/buildr/core/test.rb', line 95 def @options end |
#task ⇒ Object (readonly)
The test task we belong to
97 98 99 |
# File 'lib/buildr/core/test.rb', line 97 def task @task end |
Class Method Details
.applies_to?(project) ⇒ Boolean
Returns true if this framework applies to the current project. For example, JUnit returns true if the tests are written in Java.
75 76 77 |
# File 'lib/buildr/core/test.rb', line 75 def applies_to?(project) raise 'Not implemented' end |
.dependencies ⇒ Object
Returns a list of dependencies for this framework. Default is an empty list, override to add dependencies.
81 82 83 |
# File 'lib/buildr/core/test.rb', line 81 def dependencies @dependencies ||= [] end |
.to_sym ⇒ Object
The framework’s identifier (e.g. :junit). Inferred from the class name.
69 70 71 |
# File 'lib/buildr/core/test.rb', line 69 def to_sym @symbol ||= name.split('::').last.downcase.to_sym end |
Instance Method Details
#dependencies ⇒ Object
Returns a list of dependenices for this framework. Defaults to calling the #dependencies method on the class.
101 102 103 |
# File 'lib/buildr/core/test.rb', line 101 def dependencies self.class.dependencies end |
#run(tests, dependencies) ⇒ Object
TestTask calls this method to run the named (and only those) tests. This method returns the list of tests that ran successfully.
118 119 120 |
# File 'lib/buildr/core/test.rb', line 118 def run(tests, dependencies) raise 'Not implemented' end |
#tests(dependencies) ⇒ Object
TestTask calls this method to return a list of test names that can be run in this project. It then applies the include/exclude patterns to arrive at the list of tests that will be run, and call the #run method with that list.
This method should return a list suitable for using with the #run method, but also suitable for the user to manage. For example, JUnit locates all the tests in the test.compile.target directory, and returns the class names, which are easier to work with than file names.
112 113 114 |
# File 'lib/buildr/core/test.rb', line 112 def tests(dependencies) raise 'Not implemented' end |