Sha256: 1d1f6ea934ec78ea300ed3ef367b7138e89dff07ed414c134896626e1101e854

Contents?: true

Size: 1.32 KB

Versions: 7

Compression:

Stored size: 1.32 KB

Contents

require 'spec_helper'

describe MailRoom::Logger::Structured do

  subject { described_class.new $stdout }

  let!(:now) { Time.now }
  let(:message) { { action: 'exciting development', message: 'testing 123' } }

  before do
    Time.stubs(:now).returns(now)
  end

  [:debug, :info, :warn, :error, :fatal].each do |level|
    it "logs #{level}" do
      expect { subject.send(level, message) }.to output(json_matching(level.to_s.upcase, message)).to_stdout_from_any_process
    end
  end

  it 'logs unknown' do
    expect { subject.unknown(message) }.to output(json_matching("ANY", message)).to_stdout_from_any_process
  end

  it 'only accepts hashes' do
    expect { subject.unknown("just a string!") }.to raise_error(ArgumentError, /must be a Hash/)
  end

  context 'logging a hash as a message' do
    it 'merges the contents' do
      input = {
          additional_field: "some value"
      }
      expected = {
          severity: 'DEBUG',
          time: now,
          additional_field: "some value"
      }

      expect { subject.debug(input) }.to output(as_regex(expected)).to_stdout_from_any_process
    end
  end

  def json_matching(level, message)
    contents = {
        severity: level,
        time: now
    }.merge(message)

    as_regex(contents)
  end

  def as_regex(contents)
    /#{Regexp.quote(contents.to_json)}/
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
gitlab-mail_room-0.0.9 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.8 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.7 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.6 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.4 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.3 spec/lib/logger/structured_spec.rb
gitlab-mail_room-0.0.2 spec/lib/logger/structured_spec.rb