Create a task that runs a set of tests.

Example:

Rake::TestTask.new do |t|
  t.libs << "test"
  t.test_files = FileList['test/test*.rb']
  t.verbose = true
end

If rake is invoked with a “TEST=filename” command line option, then the list of test files will be overridden to include only the filename specified on the command line. This provides an easy way to run just one test.

If rake is invoked with a “TESTOPTS=options” command line option, then the given options are passed to the test process after a '–'. This allows Test::Unit options to be passed to the test suite.

Examples:

rake test                           # run tests normally
rake test TEST=just_one_file.rb     # run just one test file.
rake test TESTOPTS="-v"             # run in verbose mode
rake test TESTOPTS="--runner=fox"   # use the fox test runner
Methods
D
F
L
N
R
T
Attributes
[RW] libs

List of directories to added to $LOAD_PATH before running the tests. (default is 'lib')

[RW] loader

Style of test loader to use. Options are:

  • :rake – Rake provided test loading script (default).

  • :testrb – Ruby provided test loading script.

  • :direct – Load tests using command line loader.

[RW] name

Name of test task. (default is :test)

[RW] options

Test options passed to the test suite. An explicit TESTOPTS=opts on the command line will override this. (default is NONE)

[RW] pattern

Glob pattern to match test files. (default is 'test/test*.rb')

[RW] ruby_opts

Array of commandline options to pass to ruby when running test loader.

[RW] verbose

True if verbose test output desired. (default is false)

[RW] warning

Request that the tests be run with the warning flag set. E.g. warning=true implies “ruby -w” used to run the tests.

Class Public methods
new(name=:test)

Create a testing task.

# File ../ruby/lib/rake/testtask.rb, line 79
def initialize(name=:test)
  @name = name
  @libs = ["lib"]
  @pattern = nil
  @options = nil
  @test_files = nil
  @verbose = false
  @warning = false
  @loader = :rake
  @ruby_opts = []
  yield self if block_given?
  @pattern = 'test/test*.rb' if @pattern.nil? && @test_files.nil?
  define
end
Instance Public methods
define()

Create the tasks defined by this task lib.

# File ../ruby/lib/rake/testtask.rb, line 95
def define
  desc "Run tests" + (@name==:test ? "" : " for #{@name}")
  task @name do
    FileUtilsExt.verbose(@verbose) do
      ruby "#{ruby_opts_string} #{run_code} #{file_list_string} #{option_list}"
    end
  end
  self
end
file_list_string()
# File ../ruby/lib/rake/testtask.rb, line 125
def file_list_string
  file_list.collect { |fn| "\"#{fn}\"" }.join(' ')
end
lib_path()
# File ../ruby/lib/rake/testtask.rb, line 121
def lib_path
  @libs.join(File::PATH_SEPARATOR)
end
ruby_opts_string()
# File ../ruby/lib/rake/testtask.rb, line 114
def ruby_opts_string
  opts = @ruby_opts.dup
  opts.unshift( "-I\"#{lib_path}\"" ) unless @libs.empty?
  opts.unshift( "-w" ) if @warning
  opts.join(" ")
end
ruby_version()
# File ../ruby/lib/rake/testtask.rb, line 149
def ruby_version
  RUBY_VERSION
end
run_code()
# File ../ruby/lib/rake/testtask.rb, line 153
def run_code
  case @loader
  when :direct
    "-e \"ARGV.each{|f| require f}\""
  when :testrb
    "-S testrb #{fix}"
  when :rake
    "-I\"#{rake_lib_dir}\" \"#{rake_loader}\""
  end
end
test_files=(list)

Explicitly define the list of test files to be included in a test. list is expected to be an array of file names (a FileList is acceptable). If both pattern and test_files are used, then the list of test files is the union of the two.

# File ../ruby/lib/rake/testtask.rb, line 74
def test_files=(list)
  @test_files = list
end