class Test::Unit::AutoRunner

Constants

ADDITIONAL_OPTIONS
COLLECTORS
PREPARE_HOOKS
RUNNERS

Attributes

base[RW]
collector[W]
color_scheme[RW]
exclude[RW]
filters[RW]
listeners[RW]
pattern[RW]
runner[W]
runner_options[R]
suite[R]
to_run[RW]
workdir[RW]

Public Class Methods

collector(id) click to toggle source
# File lib/test/unit/autorunner.rb, line 37
def collector(id)
  COLLECTORS[id.to_s]
end
default_runner() click to toggle source
# File lib/test/unit/autorunner.rb, line 24
def default_runner
  runner(@@default_runner)
end
default_runner=(id) click to toggle source
# File lib/test/unit/autorunner.rb, line 28
def default_runner=(id)
  @@default_runner = id
end
need_auto_run=(need) click to toggle source
# File lib/test/unit/autorunner.rb, line 74
def need_auto_run=(need)
  @@need_auto_run = need
end
need_auto_run?() click to toggle source
# File lib/test/unit/autorunner.rb, line 70
def need_auto_run?
  @@need_auto_run
end
new(standalone) { |self| ... } click to toggle source
# File lib/test/unit/autorunner.rb, line 129
def initialize(standalone)
  @standalone = standalone
  @runner = default_runner
  @collector = default_collector
  @filters = []
  @to_run = []
  @color_scheme = ColorScheme.default
  @runner_options = {}
  @default_arguments = []
  @workdir = nil
  @listeners = []
  config_file = "test-unit.yml"
  if File.exist?(config_file)
    load_config(config_file)
  else
    load_global_config
  end
  yield(self) if block_given?
end
prepare(hook=Proc.new) click to toggle source
# File lib/test/unit/autorunner.rb, line 49
def prepare(hook=Proc.new)
  PREPARE_HOOKS << hook
end
register_collector(id, collector_builder=Proc.new) click to toggle source
# File lib/test/unit/autorunner.rb, line 32
def register_collector(id, collector_builder=Proc.new)
  COLLECTORS[id] = collector_builder
  COLLECTORS[id.to_s] = collector_builder
end
register_color_scheme(id, scheme) click to toggle source
# File lib/test/unit/autorunner.rb, line 41
def register_color_scheme(id, scheme)
  ColorScheme[id] = scheme
end
register_runner(id, runner_builder=Proc.new) click to toggle source
# File lib/test/unit/autorunner.rb, line 14
def register_runner(id, runner_builder=Proc.new)
  RUNNERS[id] = runner_builder
  RUNNERS[id.to_s] = runner_builder
end
run(force_standalone=false, default_dir=nil, argv=ARGV, &block) click to toggle source
# File lib/test/unit/autorunner.rb, line 53
def run(force_standalone=false, default_dir=nil, argv=ARGV, &block)
  r = new(force_standalone || standalone?, &block)
  r.base = default_dir
  r.prepare
  r.process_args(argv)
  r.run
end
runner(id) click to toggle source
# File lib/test/unit/autorunner.rb, line 19
def runner(id)
  RUNNERS[id.to_s]
end
setup_option(option_builder=Proc.new) click to toggle source
# File lib/test/unit/autorunner.rb, line 45
def setup_option(option_builder=Proc.new)
  ADDITIONAL_OPTIONS << option_builder
end
standalone?() click to toggle source
# File lib/test/unit/autorunner.rb, line 61
def standalone?
  return false unless("-e" == $0)
  ObjectSpace.each_object(Class) do |klass|
    return false if(klass < TestCase)
  end
  true
end

Public Instance Methods

keyword_display(keywords) click to toggle source
# File lib/test/unit/autorunner.rb, line 366
def keyword_display(keywords)
  keywords = keywords.collect do |keyword, _|
    keyword.to_s
  end.uniq.sort

  i = 0
  keywords.collect do |keyword|
    if (i > 0 and keyword[0] == keywords[i - 1][0]) or
        ((i < keywords.size - 1) and (keyword[0] == keywords[i + 1][0]))
      n = 2
    else
      n = 1
    end
    i += 1
    keyword.sub(%r^(.{#{n}})([A-Za-z]+)(?=\w*$)/, '\1[\2]')
  end.join(", ")
end
load_config(file) click to toggle source
# File lib/test/unit/autorunner.rb, line 399
def load_config(file)
  require 'yaml'
  config = YAML.load(File.read(file))
  runner_name = config["runner"]
  @runner = self.class.runner(runner_name) || @runner
  @collector = self.class.collector(config["collector"]) || @collector
  (config["color_schemes"] || {}).each do |name, options|
    ColorScheme[name] = options
  end
  runner_options = {}
  (config["#{runner_name}_options"] || {}).each do |key, value|
    key = key.to_sym
    value = ColorScheme[value] if key == :color_scheme
    if key == :arguments
      @default_arguments.concat(value.split)
    else
      runner_options[key.to_sym] = value
    end
  end
  @runner_options = @runner_options.merge(runner_options)
end
options() click to toggle source
# File lib/test/unit/autorunner.rb, line 167
def options
  @options ||= OptionParser.new do |o|
    o.banner = "Test::Unit automatic runner."
    o.banner << "\nUsage: #{$0} [options] [-- untouched arguments]"

    o.on('-r', '--runner=RUNNER', RUNNERS,
         "Use the given RUNNER.",
         "(" + keyword_display(RUNNERS) + ")") do |r|
      @runner = r
    end

    o.on('--collector=COLLECTOR', COLLECTORS,
         "Use the given COLLECTOR.",
         "(" + keyword_display(COLLECTORS) + ")") do |collector|
      @collector = collector
    end

    if (@standalone)
      o.on('-b', '--basedir=DIR', "Base directory of test suites.") do |b|
        @base = b
      end

      o.on('-w', '--workdir=DIR', "Working directory to run tests.") do |w|
        @workdir = w
      end

      o.on('-a', '--add=TORUN', Array,
           "Add TORUN to the list of things to run;",
           "can be a file or a directory.") do |a|
        @to_run.concat(a)
      end

      @pattern = []
      o.on('-p', '--pattern=PATTERN', Regexp,
           "Match files to collect against PATTERN.") do |e|
        @pattern << e
      end

      @exclude = []
      o.on('-x', '--exclude=PATTERN', Regexp,
           "Ignore files to collect against PATTERN.") do |e|
        @exclude << e
      end
    end

    o.on('-n', '--name=NAME', String,
         "Runs tests matching NAME.",
         "(patterns may be used).") do |name|
      name = (%r{\A/(.*)/\Z} =~ name ? Regexp.new($1) : name)
      @filters << lambda do |test|
        return true if name === test.method_name
        test_name_without_class_name = test.name.gsub(%r\(.+?\)\z/, "")
        if test_name_without_class_name != test.method_name
          return true if name === test_name_without_class_name
        end
        false
      end
    end

    o.on('--ignore-name=NAME', String,
         "Ignores tests matching NAME.",
         "(patterns may be used).") do |n|
      n = (%r{\A/(.*)/\Z} =~ n ? Regexp.new($1) : n)
      case n
      when Regexp
        @filters << proc {|t| n =~ t.method_name ? false : true}
      else
        @filters << proc {|t| n != t.method_name}
      end
    end

    o.on('-t', '--testcase=TESTCASE', String,
         "Runs tests in TestCases matching TESTCASE.",
         "(patterns may be used).") do |n|
      n = (%r{\A/(.*)/\Z} =~ n ? Regexp.new($1) : n)
      case n
      when Regexp
        @filters << proc{|t| n =~ t.class.name ? true : false}
      else
        @filters << proc{|t| n == t.class.name}
      end
    end

    o.on('--ignore-testcase=TESTCASE', String,
         "Ignores tests in TestCases matching TESTCASE.",
         "(patterns may be used).") do |n|
      n = (%r{\A/(.*)/\Z} =~ n ? Regexp.new($1) : n)
      case n
      when Regexp
        @filters << proc {|t| n =~ t.class.name ? false : true}
      else
        @filters << proc {|t| n != t.class.name}
      end
    end

    o.on('--location=LOCATION', String,
         "Runs tests that defined in LOCATION.",
         "LOCATION is one of PATH:LINE, PATH or LINE") do |location|
      if %r\A\d+\z/ =~ location
        path = nil
        line = location.to_i
      else
        path, line, = location.split(%r:(\d+)/, 2)
        line = line.to_i unless line.nil?
      end
      @filters << lambda do |test|
        test.class.test_defined?(:path => path,
                                 :line => line,
                                 :method_name => test.method_name)
      end
    end

    priority_filter = Proc.new do |test|
      if @filters == [priority_filter]
        Priority::Checker.new(test).need_to_run?
      else
        nil
      end
    end
    o.on("--[no-]priority-mode",
         "Runs some tests based on their priority.") do |priority_mode|
      if priority_mode
        Priority.enable
        @filters |= [priority_filter]
      else
        Priority.disable
        @filters -= [priority_filter]
      end
    end

    o.on("--default-priority=PRIORITY",
         Priority.available_values,
         "Uses PRIORITY as default priority",
         "(#{keyword_display(Priority.available_values)})") do |priority|
      Priority.default = priority
    end

    o.on('-I', "--load-path=DIR[#{File::PATH_SEPARATOR}DIR...]",
         "Appends directory list to $LOAD_PATH.") do |dirs|
      $LOAD_PATH.concat(dirs.split(File::PATH_SEPARATOR))
    end

    color_schemes = ColorScheme.all
    o.on("--color-scheme=SCHEME", color_schemes,
         "Use SCHEME as color scheme.",
         "(#{keyword_display(color_schemes)})") do |scheme|
      @color_scheme = scheme
    end

    o.on("--config=FILE",
         "Use YAML fomat FILE content as configuration file.") do |file|
      load_config(file)
    end

    o.on("--order=ORDER", TestCase::AVAILABLE_ORDERS,
         "Run tests in a test case in ORDER order.",
         "(#{keyword_display(TestCase::AVAILABLE_ORDERS)})") do |order|
      TestCase.test_order = order
    end

    assertion_message_class = Test::Unit::Assertions::AssertionMessage
    o.on("--max-diff-target-string-size=SIZE", Integer,
         "Shows diff if both expected result string size and " +
         "actual result string size are " +
         "less than or equal SIZE in bytes.",
         "(#{assertion_message_class.max_diff_target_string_size})") do |size|
      assertion_message_class.max_diff_target_string_size = size
    end

    ADDITIONAL_OPTIONS.each do |option_builder|
      option_builder.call(self, o)
    end

    o.on('--',
         "Stop processing options so that the",
         "remaining options will be passed to the",
         "test."){o.terminate}

    o.on('-h', '--help', 'Display this help.'){puts o; exit}

    o.on_tail
    o.on_tail('Deprecated options:')

    o.on_tail('--console', 'Console runner (use --runner).') do
      warn("Deprecated option (--console).")
      @runner = self.class.runner(:console)
    end

    if RUNNERS[:fox]
      o.on_tail('--fox', 'Fox runner (use --runner).') do
        warn("Deprecated option (--fox).")
        @runner = self.class.runner(:fox)
      end
    end

    o.on_tail
  end
end
prepare() click to toggle source
# File lib/test/unit/autorunner.rb, line 149
def prepare
  PREPARE_HOOKS.each do |handler|
    handler.call(self)
  end
end
process_args(args=ARGV) click to toggle source
# File lib/test/unit/autorunner.rb, line 155
def process_args(args=ARGV)
  begin
    args.unshift(*@default_arguments)
    options.order!(args) {|arg| @to_run << arg}
  rescue OptionParser::ParseError => e
    puts e
    puts options
    exit(false)
  end
  not @to_run.empty?
end
run() click to toggle source
# File lib/test/unit/autorunner.rb, line 384
def run
  self.class.need_auto_run = false
  suite = @collector[self]
  return false if suite.nil?
  return true if suite.empty?
  runner = @runner[self]
  return false if runner.nil?
  @runner_options[:color_scheme] ||= @color_scheme
  @runner_options[:listeners] ||= []
  @runner_options[:listeners].concat(@listeners)
  change_work_directory do
    runner.run(suite, @runner_options).passed?
  end
end