aboutsummaryrefslogtreecommitdiffstats
path: root/activeresource/test/cases/log_subscriber_test.rb
blob: f0330e8f51a7a75be71ab3c4c7be0219af24d980 (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
require "abstract_unit"
require "fixtures/person"
require "rails/log_subscriber/test_helper"
require "active_resource/railties/log_subscriber"
require "active_support/core_ext/hash/conversions"

# TODO: This test should be part of Railties
class LogSubscriberTest < ActiveSupport::TestCase
  include Rails::LogSubscriber::TestHelper

  def setup
    super

    @matz = { :id => 1, :name => 'Matz' }.to_xml(:root => 'person')
    ActiveResource::HttpMock.respond_to do |mock|
      mock.get "/people/1.xml", {}, @matz
    end

    Rails::LogSubscriber.add(:active_resource, ActiveResource::Railties::LogSubscriber.new)
  end

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

  def test_request_notification
    matz = Person.find(1)
    wait
    assert_equal 2, @logger.logged(:info).size
    assert_equal "GET http://37s.sunrise.i:3000/people/1.xml", @logger.logged(:info)[0]
    assert_match(/\-\-\> 200 200 106/, @logger.logged(:info)[1])
  end
end