mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
6c98fbd9c3
Add tests for ActiveSupport::Deprecation.deprecate_methods Modify ActiveSupport::Testing::Deprecation to allow a custom deprecator Leverage ActiveSupport::Testing::Deprecation assert_deprecated Update documentation for ActiveSupport::Deprecation.deprecate_methods Use cases: Using the default deprecator => "removed from Rails X.Y" Passing a custom deprecator in the options hash => "removed from MyGem next-release" Deprecating methods directly from custom deprecator => "removed from MyGem next-release"
36 lines
1.3 KiB
Ruby
36 lines
1.3 KiB
Ruby
require 'active_support/deprecation'
|
|
|
|
module ActiveSupport
|
|
module Testing
|
|
module Deprecation #:nodoc:
|
|
def assert_deprecated(match = nil, deprecator = nil, &block)
|
|
result, warnings = collect_deprecations(deprecator, &block)
|
|
assert !warnings.empty?, "Expected a deprecation warning within the block but received none"
|
|
if match
|
|
match = Regexp.new(Regexp.escape(match)) unless match.is_a?(Regexp)
|
|
assert warnings.any? { |w| w =~ match }, "No deprecation warning matched #{match}: #{warnings.join(', ')}"
|
|
end
|
|
result
|
|
end
|
|
|
|
def assert_not_deprecated(deprecator = nil, &block)
|
|
result, deprecations = collect_deprecations(deprecator, &block)
|
|
assert deprecations.empty?, "Expected no deprecation warning within the block but received #{deprecations.size}: \n #{deprecations * "\n "}"
|
|
result
|
|
end
|
|
|
|
def collect_deprecations(deprecator = nil)
|
|
deprecator ||= ActiveSupport::Deprecation
|
|
old_behavior = deprecator.behavior
|
|
deprecations = []
|
|
deprecator.behavior = Proc.new do |message, callstack|
|
|
deprecations << message
|
|
end
|
|
result = yield
|
|
[result, deprecations]
|
|
ensure
|
|
deprecator.behavior = old_behavior
|
|
end
|
|
end
|
|
end
|
|
end
|