51 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
require 'spec_helper'
 | 
						|
 | 
						|
RSpec.describe Gitlab::SidekiqMiddleware::InstrumentationLogger do
 | 
						|
  let(:job) { { 'jid' => 123 } }
 | 
						|
  let(:queue) { 'test_queue' }
 | 
						|
  let(:worker) do
 | 
						|
    Class.new do
 | 
						|
      def self.name
 | 
						|
        'TestDWorker'
 | 
						|
      end
 | 
						|
 | 
						|
      include ApplicationWorker
 | 
						|
 | 
						|
      def perform(*args); end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  subject { described_class.new }
 | 
						|
 | 
						|
  before do
 | 
						|
    stub_const('TestWorker', worker)
 | 
						|
  end
 | 
						|
 | 
						|
  describe '#call', :request_store do
 | 
						|
    let(:instrumentation_values) do
 | 
						|
      {
 | 
						|
        cpu_s: 10,
 | 
						|
        db_count: 0,
 | 
						|
        db_cached_count: 0,
 | 
						|
        db_write_count: 0,
 | 
						|
        gitaly_calls: 0,
 | 
						|
        redis_calls: 0
 | 
						|
      }
 | 
						|
    end
 | 
						|
 | 
						|
    before do
 | 
						|
      allow(::Gitlab::InstrumentationHelper).to receive(:add_instrumentation_data) do |values|
 | 
						|
        values.merge!(instrumentation_values)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    it 'merges all instrumentation data in the job' do
 | 
						|
      expect { |b| subject.call(worker, job, queue, &b) }.to yield_control
 | 
						|
 | 
						|
      expect(job[:instrumentation]).to eq(instrumentation_values)
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |