Sha256: bddcae8c03dce584f5e880d0d1063460c565cb5fd84e4c5db5bb6332cbd770f0

Contents?: true

Size: 1.63 KB

Versions: 18

Compression:

Stored size: 1.63 KB

Contents

# frozen_string_literal: true
# encoding: utf-8

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

18 entries across 18 versions & 1 rubygems

Version Path
mongo-2.16.4 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.17.4 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.18.3 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.18.2 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.17.3 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.18.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.18.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.17.2 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.16.3 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.18.0.beta1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.16.2 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.17.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.16.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.17.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.16.0 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.15.1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.16.0.alpha1 spec/mongo/monitoring/command_log_subscriber_spec.rb
mongo-2.15.0 spec/mongo/monitoring/command_log_subscriber_spec.rb