Sha256: a1dab451e9a745830357ee5499e0afee6c4837a8223a70b2359a5c9e3ecac048

Contents?: true

Size: 1.63 KB

Versions: 9

Compression:

Stored size: 1.63 KB

Contents

# frozen_string_literal: true
# rubocop:todo all

require 'spec_helper'

describe Mongo::Monitoring::CommandLogSubscriber do

  describe '#started' do

    let(:filter) do
      (1...100).reduce({}) do |hash, i|
        hash[i] = i
        hash
      end
    end

    let(:command) do
      { find: 'users', filter: filter }
    end

    let(:event) do
      Mongo::Monitoring::Event::CommandStarted.new(
        'find',
        'users',
        Mongo::Address.new('127.0.0.1:27017'),
        12345,
        67890,
        command
      )
    end

    before do
      Mongo::Logger.level = Logger::DEBUG
    end

    after do
      Mongo::Logger.level = Logger::INFO
    end

    context 'when truncating the logs' do

      context 'when no option is provided' do

        let(:subscriber) do
          described_class.new
        end

        it 'truncates the logs at 250 characters' do
          expect(subscriber).to receive(:truncate).with(command).and_call_original
          subscriber.started(event)
        end
      end

      context 'when true option is provided' do

        let(:subscriber) do
          described_class.new(truncate_logs: true)
        end

        it 'truncates the logs at 250 characters' do
          expect(subscriber).to receive(:truncate).with(command).and_call_original
          subscriber.started(event)
        end
      end
    end

    context 'when not truncating the logs' do

      let(:subscriber) do
        described_class.new(truncate_logs: false)
      end

      it 'does not truncate the logs' do
        expect(subscriber).to_not receive(:truncate)
        subscriber.started(event)
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 2 rubygems

Version Path
mongo-2.21.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.20.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mogno-2.20.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mogno-1.0.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.20.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.19.3 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.19.2 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.19.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.19.0 spec/mongo/monitoring/command_log_subscriber_spec.rb