Sha256: 51f6ea939092c137cfd87ac0274d084bb069944f332d294197457bcd050ceffe

Contents?: true

Size: 895 Bytes

Versions: 7

Compression:

Stored size: 895 Bytes

Contents

require 'spec_helper'
require 'sinatra/custom_logger'

describe Sinatra::CustomLogger do
  before do
    rack_logger = @rack_logger = double
    mock_app do
      helpers Sinatra::CustomLogger

      before do
        env['rack.logger'] = rack_logger
      end

      get '/' do
        logger.info 'Logged message'
        'Response'
      end
    end
  end

  describe '#logger' do
    it 'falls back to request.logger' do
      expect(@rack_logger).to receive(:info).with('Logged message')
      get '/'
    end

    context 'logger setting is set' do
      before do
        custom_logger = @custom_logger = double
        @app.class_eval do
          configure do
            set :logger, custom_logger
          end
        end
      end

      it 'calls custom logger' do
        expect(@custom_logger).to receive(:info).with('Logged message')
        get '/'
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 2 rubygems

Version Path
mdg-1.0.1 vendor/bundle/ruby/2.3.0/gems/sinatra-contrib-1.4.7/spec/custom_logger_spec.rb
sinatra-contrib-2.0.0.rc1 spec/custom_logger_spec.rb
sinatra-contrib-2.0.0.beta2 spec/custom_logger_spec.rb
sinatra-contrib-2.0.0.beta1 spec/custom_logger_spec.rb
sinatra-contrib-1.4.7 spec/custom_logger_spec.rb
sinatra-contrib-1.4.6 spec/custom_logger_spec.rb
sinatra-contrib-1.4.4 spec/custom_logger_spec.rb