Sha256: 15148a7092237cd043d36444e711ff4c94d75727a5d919690bbda192f1769f54

Contents?: true

Size: 1.48 KB

Versions: 1

Compression:

Stored size: 1.48 KB

Contents

require 'spec_helper'

describe Silencer::Logger do
  before(:each) do
    @app = lambda { |env| [200, {}, ''] }

    Rails.logger = stub('ActiveSupport::BufferedLogger').tap do |l|
      l.stub(:level).and_return(::Logger::INFO)
      l.stub(:level=).and_return(true)
    end
  end

  it 'allows log writing when not implemented' do
    Rails.logger.should_not_receive(:level=).with(::Logger::ERROR)

    Silencer::Logger.new(@app).call(Rack::MockRequest.env_for("/"))
  end

  it 'quiets the log when configured with a silenced path' do
    Rails.logger.should_not_receive(:info)
    Rails.logger.should_receive(:level=).with(::Logger::ERROR).once

    Silencer::Logger.new(@app, :silence => ['/']).call(Rack::MockRequest.env_for("/"))
  end

  it 'quiets the log when configured with a regex' do
    Rails.logger.should_not_receive(:info)
    Rails.logger.should_receive(:level=).with(::Logger::ERROR).once

    Silencer::Logger.new(@app, :silence => [/assets/]).call(Rack::MockRequest.env_for("/assets/application.css"))
  end

  it 'quiets the log when passed a custom header "X-SILENCE-LOGGER"' do
    Rails.logger.should_not_receive(:info)
    Rails.logger.should_receive(:level=).with(::Logger::ERROR).once

    Silencer::Logger.new(@app).call(Rack::MockRequest.env_for("/", 'X-SILENCE-LOGGER' => 'true'))
  end

  it 'does not tamper with the response' do
    response = Silencer::Logger.new(@app).call(Rack::MockRequest.env_for("/", 'X-SILENCE-LOGGER' => 'true'))
    response[0].should eq(200)
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
silencer-0.2.0 spec/silencer_spec.rb