Sha256: ec5eb80948b2b4c51733b5cd612123b1bd3e599b277ae5972c22ca5afb6ff8c4

Contents?: true

Size: 1.73 KB

Versions: 57

Compression:

Stored size: 1.73 KB

Contents

require "spec_helper"

if defined?(::Rails)
  describe Timber::Integrations::Rails::RackLogger do
    describe described_class::InstanceMethods do
      let(:time) { Time.utc(2016, 9, 1, 12, 0, 0) }
      let(:io) { StringIO.new }
      let(:logger) do
        logger = Timber::Logger.new(io)
        logger.level = ::Logger::INFO
        logger
      end

      around(:each) do |example|
        class RailsRackLoggerController < ActionController::Base
          layout nil

          def index
            render json: {}
          end

          def method_for_action(action_name)
            action_name
          end
        end

        ::RailsApp.routes.draw do
          get '/rails_rack_logger' => 'rails_rack_logger#index'
        end

        with_rails_logger(logger) do
          Timecop.freeze(time) { example.run }
        end

        Object.send(:remove_const, :RailsRackLoggerController)
      end

      describe "#started_request_message" do
        it "should mute the default rails logs" do
          allow(::Rails).to receive(:env).and_return(ActiveSupport::StringInquirer.new("production")) # Rails 3.2.X

          dispatch_rails_request("/rails_rack_logger")

          lines = clean_lines(io.string.split("\n"))
          expect(lines.length).to eq(3)
          expect(lines[0]).to start_with("Started GET \"/rails_rack_logger\" @metadata")
          expect(lines[1]).to start_with("Processing by RailsRackLoggerController#index as HTML @metadata")
          expect(lines[2]).to start_with("Completed 200 OK in 0.0ms @metadata")
        end
      end
    end

    # Remove blank lines since Rails does this to space out requests in the logs
    def clean_lines(lines)
      lines.select { |line| !line.start_with?(" @metadat") }
    end
  end
end

Version data entries

57 entries across 57 versions & 1 rubygems

Version Path
timber-2.0.17 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.16 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.15 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.14 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.12 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.11 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.10 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.9 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.8 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.7 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.6 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.5 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.4 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.3 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.2 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.1 spec/timber/integrations/rails/rack_logger_spec.rb
timber-2.0.0 spec/timber/integrations/rails/rack_logger_spec.rb