summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/app_logger_spec.rb
blob: 4eb0d628291c0b038c6cd52b508a1a50dfffd7f0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Gitlab::AppLogger, feature_category: :shared do
  subject { described_class }

  specify { expect(described_class.primary_logger).to be Gitlab::AppJsonLogger }

  context 'when UNSTRUCTURED_RAILS_LOG is enabled' do
    before do
      stub_env('UNSTRUCTURED_RAILS_LOG', 'true')
    end

    it 'builds two Logger instances' do
      expect(Gitlab::Logger).to receive(:new).and_call_original
      expect(Gitlab::JsonLogger).to receive(:new).and_call_original

      subject.info('Hello World!')
    end

    it 'logs info to multiple loggers' do
      expect_any_instance_of(Gitlab::AppTextLogger).to receive(:info).and_call_original
      expect_any_instance_of(Gitlab::AppJsonLogger).to receive(:info).and_call_original

      subject.info('Hello World!')
    end
  end

  context 'when UNSTRUCTURED_RAILS_LOG is disabled' do
    it 'logs info to only the AppJsonLogger' do
      expect_any_instance_of(Gitlab::AppTextLogger).not_to receive(:info).and_call_original
      expect_any_instance_of(Gitlab::AppJsonLogger).to receive(:info).and_call_original

      subject.info('Hello World!')
    end
  end
end