aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test/dispatch/subscriber_test.rb
blob: a7f1a2659ad02d07d4c6c94eb37017dc3e959d64 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
require "abstract_unit"
require "rails/subscriber/test_helper"
require "action_dispatch/railties/subscriber"

module DispatcherSubscriberTest
  Boomer = lambda do |env|
    req = ActionDispatch::Request.new(env)
    case req.path
    when "/"
      [200, {}, []]
    else
      raise "puke!"
    end
  end

  App = ActionDispatch::Notifications.new(Boomer)

  def setup
    Rails::Subscriber.add(:action_dispatch, ActionDispatch::Railties::Subscriber.new)
    @app = App
    super

    @events = []
    ActiveSupport::Notifications.subscribe do |*args|
      @events << args
    end
  end

  def set_logger(logger)
    ActionController::Base.logger = logger
  end

  def test_publishes_notifications
    get "/"
    wait

    assert_equal 2, @events.size
    before, after = @events

    assert_equal 'action_dispatch.before_dispatch', before[0]
    assert_kind_of Hash, before[4][:env]
    assert_equal 'GET',  before[4][:env]["REQUEST_METHOD"]

    assert_equal 'action_dispatch.after_dispatch', after[0]
    assert_kind_of Hash, after[4][:env]
    assert_equal 'GET',  after[4][:env]["REQUEST_METHOD"]
  end

  def test_publishes_notifications_even_on_failures
    begin
      get "/puke"
    rescue
    end

    wait

    assert_equal 3, @events.size
    before, after, exception = @events

    assert_equal 'action_dispatch.before_dispatch', before[0]
    assert_kind_of Hash, before[4][:env]
    assert_equal 'GET',  before[4][:env]["REQUEST_METHOD"]

    assert_equal 'action_dispatch.after_dispatch', after[0]
    assert_kind_of Hash, after[4][:env]
    assert_equal 'GET',  after[4][:env]["REQUEST_METHOD"]

    assert_equal 'action_dispatch.exception', exception[0]
    assert_kind_of Hash, exception[4][:env]
    assert_equal 'GET',  exception[4][:env]["REQUEST_METHOD"]
    assert_kind_of RuntimeError, exception[4][:exception]
  end

  def test_subscriber_logs_notifications
    get "/"
    wait

    log = @logger.logged(:info).first
    assert_equal 1, @logger.logged(:info).size

    assert_match %r{^Processing "/" to text/html}, log
    assert_match %r{\(for 127\.0\.0\.1}, log
    assert_match %r{\[GET\]}, log
  end

  def test_subscriber_has_its_logged_flushed_after_request
    assert_equal 0, @logger.flush_count
    get "/"
    wait
    assert_equal 1, @logger.flush_count
  end

  def test_subscriber_has_its_logged_flushed_even_after_busted_requests
    assert_equal 0, @logger.flush_count
    begin
      get "/puke"
    rescue
    end
    wait
    assert_equal 1, @logger.flush_count
  end

  class SyncSubscriberTest < ActionController::IntegrationTest
    include Rails::Subscriber::SyncTestHelper
    include DispatcherSubscriberTest
  end

  class AsyncSubscriberTest < ActionController::IntegrationTest
    include Rails::Subscriber::AsyncTestHelper
    include DispatcherSubscriberTest
  end
end