mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
c81af6ae72
We sometimes say "✂️ newline after `private`" in a code review (e.g. https://github.com/rails/rails/pull/18546#discussion_r23188776, https://github.com/rails/rails/pull/34832#discussion_r244847195). Now `Layout/EmptyLinesAroundAccessModifier` cop have new enforced style `EnforcedStyle: only_before` (https://github.com/rubocop-hq/rubocop/pull/7059). That cop and enforced style will reduce the our code review cost.
46 lines
912 B
Ruby
46 lines
912 B
Ruby
# frozen_string_literal: true
|
|
|
|
require "abstract_unit"
|
|
|
|
class DispatcherTest < ActiveSupport::TestCase
|
|
class Foo
|
|
cattr_accessor :a, :b
|
|
end
|
|
|
|
class DummyApp
|
|
def call(env)
|
|
[200, {}, "response"]
|
|
end
|
|
end
|
|
|
|
def setup
|
|
Foo.a, Foo.b = 0, 0
|
|
ActionDispatch::Callbacks.reset_callbacks(:call)
|
|
end
|
|
|
|
def test_before_and_after_callbacks
|
|
ActionDispatch::Callbacks.before { |*args| Foo.a += 1; Foo.b += 1 }
|
|
ActionDispatch::Callbacks.after { |*args| Foo.a += 1; Foo.b += 1 }
|
|
|
|
dispatch
|
|
assert_equal 2, Foo.a
|
|
assert_equal 2, Foo.b
|
|
|
|
dispatch
|
|
assert_equal 4, Foo.a
|
|
assert_equal 4, Foo.b
|
|
|
|
dispatch do
|
|
raise "error"
|
|
end rescue nil
|
|
assert_equal 6, Foo.a
|
|
assert_equal 6, Foo.b
|
|
end
|
|
|
|
private
|
|
def dispatch(&block)
|
|
ActionDispatch::Callbacks.new(block || DummyApp.new).call(
|
|
"rack.input" => StringIO.new("")
|
|
)
|
|
end
|
|
end
|