summaryrefslogtreecommitdiff
path: root/lib/test
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-19 15:59:35 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-10-19 15:59:35 +0000
commit8fe3d0285fce27fc206a593c7131e8df72808f41 (patch)
tree141311d22801550eaa92b07d19d7af9d7debda20 /lib/test
parent295c75cb7ccaee5d3050f60f9daff85e2f6ae050 (diff)
* lib/test/unit.rb (Test::Unit.setup_argv): call given block for
filtering files. * test/runner.rb: search srcdir/test/arg, srcdir/arg. * bin/testrb: show usage if no files given. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19849 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/test')
-rw-r--r--lib/test/unit.rb38
1 files changed, 20 insertions, 18 deletions
diff --git a/lib/test/unit.rb b/lib/test/unit.rb
index b96676679d..0674ad4bfb 100644
--- a/lib/test/unit.rb
+++ b/lib/test/unit.rb
@@ -8,35 +8,39 @@ module Test
TEST_UNIT_IMPLEMENTATION = 'test/unit compatibility layer using minitest'
def self.setup_argv(original_argv=ARGV)
- argv = []
- files = nil
+ minitest_argv = []
+ files = []
reject = []
original_argv = original_argv.dup
while arg = original_argv.shift
case arg
when '-v'
- argv << '-v'
+ minitest_argv << '-v'
when '-n', '--name'
- argv << arg
- argv << original_argv.shift
+ minitest_argv << arg
+ minitest_argv << original_argv.shift
when '-x'
reject << original_argv.shift
else
- files ||= []
- if File.directory? arg
- files.concat Dir["#{arg}/**/test_*.rb"]
- elsif File.file? arg
- files << arg
- else
- raise ArgumentError, "file not found: #{arg}"
- end
+ files << arg
end
end
- if files == nil
- files = Dir["test/**/test_*.rb"]
+ if block_given?
+ files = yield files
end
+ files.map! {|f|
+ if File.directory? f
+ Dir["#{f}/**/test_*.rb"]
+ elsif File.file? f
+ f
+ else
+ raise ArgumentError, "file not found: #{f}"
+ end
+ }
+ files.flatten!
+
reject_pat = Regexp.union(reject.map {|r| /#{r}/ })
files.reject! {|f| reject_pat =~ f }
@@ -52,9 +56,7 @@ module Test
end
}
- argv.concat files
-
- ARGV.replace argv
+ ARGV.replace minitest_argv
end
module Assertions