模块 Test::Unit::ExceptionHandler::ClassMethods
公共实例方法
exception_handler(*method_name_or_handlers, &block) 点击切换源代码
@overload exception_handler
(method_name)
Add an exception handler method. @param method_name [Symbol] The method name that handles exception raised in tests. @return [void]
@overload exception_handler
(&callback)
Add an exception handler. @yield [test, exception] Gives the test and the exception. @yieldparam test [Test::Unit::TestCase] The test where the exception is raised. @yieldparam exception [Exception] The exception that is raised in running the test. @yieldreturn [Boolean] Whether the handler handles the exception or not. The handler must return _true_ if the handler handles test exception, _false_ otherwise. @return [void]
这是一个为扩展 test-unit 的开发者提供的公共 API。
# File test-unit-3.6.7/lib/test/unit/exception-handler.rb, line 52 def exception_handler(*method_name_or_handlers, &block) if block_given? exception_handlers.unshift(block) else method_name_or_handlers.each do |method_name_or_handler| if method_name_or_handler.respond_to?(:call) handler = method_name_or_handler exception_handlers.unshift(handler) else method_name = method_name_or_handler attribute(:exception_handler, true, {}, method_name) end end end end
exception_handlers() 点击切换源代码
# File test-unit-3.6.7/lib/test/unit/exception-handler.rb, line 25 def exception_handlers ExceptionHandler.exception_handlers end
unregister_exception_handler(*method_name_or_handlers) 点击切换源代码
# File test-unit-3.6.7/lib/test/unit/exception-handler.rb, line 68 def unregister_exception_handler(*method_name_or_handlers) method_name_or_handlers.each do |method_name_or_handler| if method_name_or_handler.respond_to?(:call) handler = method_name_or_handler exception_handlers.delete(handler) else method_name = method_name_or_handler attribute(:exception_handler, false, {}, method_name) end end end