debian-mirror-gitlab/spec/lib/peek/views/rugged_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

43 lines
1.4 KiB
Ruby
Raw Permalink Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Peek::Views::Rugged, :request_store do
2019-10-12 21:52:04 +05:30
subject { described_class.new }
let(:project) { create(:project) }
before do
2019-12-04 20:38:33 +05:30
allow(Gitlab::PerformanceBar).to receive(:enabled_for_request?).and_return(true)
2019-10-12 21:52:04 +05:30
end
it 'returns no results' do
expect(subject.results).to eq({})
end
it 'returns aggregated results' do
2020-06-23 00:09:42 +05:30
::Gitlab::RuggedInstrumentation.add_query_time(1.234)
2019-10-12 21:52:04 +05:30
::Gitlab::RuggedInstrumentation.increment_query_count
::Gitlab::RuggedInstrumentation.increment_query_count
::Gitlab::RuggedInstrumentation.add_call_details(feature: :rugged_test,
args: [project.repository.raw, 'HEAD'],
duration: 0.123)
::Gitlab::RuggedInstrumentation.add_call_details(feature: :rugged_test2,
args: [project.repository, 'refs/heads/master'],
duration: 0.456)
results = subject.results
expect(results[:calls]).to eq(2)
expect(results[:duration]).to eq('1234.00ms')
expect(results[:details].count).to eq(2)
expected = [
[project.repository.raw.to_s, "HEAD"],
[project.repository.to_s, "refs/heads/master"]
]
expect(results[:details].map { |data| data[:args] }).to match_array(expected)
end
end