diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-02-13 10:41:59 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-02-13 10:41:59 +0000 |
commit | 63ca916ed414649e294b8dab1a30872c865a9faf (patch) | |
tree | b7071ae4cc9f4884572db5c4a56d3a0e638a2a03 /lib/test | |
parent | 0224758a7a0ceddb68e705184f7bebe6f07f4b82 (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/test')
-rw-r--r-- | lib/test/unit.rb | 16 |
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 |