module ActiveSupport::Testing::Deprecation

def assert_deprecated(match = nil, deprecator = nil, &block)

end
CustomDeprecator.warn "foo should no longer be used"
assert_deprecated(CustomDeprecator) do

If the +match+ is omitted (or explicitly +nil+), any deprecation warning will match.

end
CustomDeprecator.warn "foo should no longer be used"
assert_deprecated('foo', CustomDeprecator) do

The +match+ object may be a +Regexp+, or +String+ appearing in the message.

end
CustomDeprecator.warn "foo should no longer be used"
assert_deprecated(/foo/, CustomDeprecator) do

Asserts that a matching deprecation warning was emitted by the given deprecator during the execution of the yielded block.

assert_deprecated(match, deprecator, &block)
assert_deprecated(deprecator, &block)
:call-seq:
#
def assert_deprecated(match = nil, deprecator = nil, &block)
  match, deprecator = nil, match if match.is_a?(ActiveSupport::Deprecation)
  unless deprecator
    raise ArgumentError, "No deprecator given"
  end
  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| match.match?(w) }, "No deprecation warning matched #{match}: #{warnings.join(', ')}"
  end
  result
end

def assert_not_deprecated(deprecator, &block)

end
CustomDeprecator.warn "message" # passes assertion, different deprecator
assert_not_deprecated(ActiveSupport::Deprecation.new) do

end
CustomDeprecator.warn "message" # fails assertion
assert_not_deprecated(CustomDeprecator) do

Asserts that no deprecation warnings are emitted by the given deprecator during the execution of the yielded block.
def assert_not_deprecated(deprecator, &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)

end # => [:result, ["message"]]
:result
ActiveSupport::Deprecation.new.warn "other message"
CustomDeprecator.warn "message"
collect_deprecations(CustomDeprecator) do

+deprecator+ during the execution of the yielded block.
Returns the return value of the block and an array of all the deprecation warnings emitted by the given
def collect_deprecations(deprecator)
  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