summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/grape_logging/loggers/urgency_logger_spec.rb
blob: 464534f02713b220627dfaeb418aefdf02852ea9 (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
39
40
41
42
43
44
45
46
47
48
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Gitlab::GrapeLogging::Loggers::UrgencyLogger do
  def endpoint(options, namespace: '')
    Struct.new(:options, :namespace).new(options, namespace)
  end

  let(:api_class) do
    Class.new(API::Base) do
      namespace 'testing' do
        # rubocop:disable Rails/HttpPositionalArguments
        # This is not the get that performs a request, but the one from Grape
        get 'test', urgency: :high do
          {}
        end
        # rubocop:enable Rails/HttpPositionalArguments
      end
    end
  end

  describe ".parameters" do
    where(:request_env, :expected_parameters) do
      [
        [{}, {}],
        [{ 'api.endpoint' => endpoint({}) }, {}],
        [{ 'api.endpoint' => endpoint({ for: 'something weird' }) }, {}],
        [
          { 'api.endpoint' => endpoint({ for: api_class, path: [] }) },
          { request_urgency: :default, target_duration_s: 1 }
        ],
        [
          { 'api.endpoint' => endpoint({ for: api_class, path: ['test'] }, namespace: '/testing') },
          { request_urgency: :high, target_duration_s: 0.25 }
        ]
      ]
    end

    with_them do
      let(:request) { double('request', env: request_env) }

      subject { described_class.new.parameters(request, nil) }

      it { is_expected.to eq(expected_parameters) }
    end
  end
end