summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-02-13 10:41:59 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-02-13 10:41:59 +0000
commit63ca916ed414649e294b8dab1a30872c865a9faf (patch)
treeb7071ae4cc9f4884572db5c4a56d3a0e638a2a03 /lib
parent0224758a7a0ceddb68e705184f7bebe6f07f4b82 (diff)
* lib/test/unit.rb (Test::Unit::RequireFiles#non_options): skip
test suites failed to load instead of mere messages. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@30863 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/test/unit.rb16
1 files changed, 14 insertions, 2 deletions
diff --git a/lib/test/unit.rb b/lib/test/unit.rb
index fd50d8100d..c9637b97e7 100644
--- a/lib/test/unit.rb
+++ b/lib/test/unit.rb
@@ -166,6 +166,9 @@ module Test
end
module RequireFiles
+ path = File.expand_path('../../rubygems/custom_require.rb', __FILE__)
+ CUSTOM_REQUIRE = /\A#{Regexp.quote(path)}:\d+:in `require'\z/ #'
+
def non_options(files, options)
return false if !super
result = false
@@ -177,8 +180,17 @@ module Test
begin
require path
result = true
- rescue LoadError
- puts "#{f}: #{$!}"
+ rescue LoadError => e
+ Class.new(Test::Unit::TestCase) do
+ message = e.message
+ / -- (?<failed>.*)/ =~ message
+ define_singleton_method(:to_s) {failed}
+ backtrace = e.backtrace
+ backtrace.shift while CUSTOM_REQUIRE =~ backtrace.first
+ /(?<file>.*):(?<line>\d+):in\s`/ =~ backtrace.first
+ line = line.to_i
+ define_method(:test_require_failed) {eval "skip(message)", nil, file, line}
+ end
end
}
result