2016-04-08 11:54:52 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Gitlab::Metrics::Subscribers::RailsCache do
|
|
|
|
let(:transaction) { Gitlab::Metrics::Transaction.new }
|
|
|
|
let(:subscriber) { described_class.new }
|
|
|
|
|
|
|
|
let(:event) { double(:event, duration: 15.2) }
|
|
|
|
|
|
|
|
describe '#cache_read' do
|
|
|
|
it 'increments the cache_read duration' do
|
|
|
|
expect(subscriber).to receive(:increment).
|
2016-05-15 14:47:41 -04:00
|
|
|
with(:cache_read, event.duration)
|
2016-04-08 11:54:52 -04:00
|
|
|
|
|
|
|
subscriber.cache_read(event)
|
|
|
|
end
|
2016-06-29 11:03:20 -04:00
|
|
|
|
|
|
|
context 'with a transaction' do
|
|
|
|
before do
|
|
|
|
allow(subscriber).to receive(:current_transaction).
|
|
|
|
and_return(transaction)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with hit event' do
|
|
|
|
let(:event) { double(:event, duration: 15.2, payload: { hit: true }) }
|
|
|
|
|
|
|
|
it 'increments the cache_read_hit count' do
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_read_hit_count, 1)
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(any_args).at_least(1) # Other calls
|
|
|
|
|
|
|
|
subscriber.cache_read(event)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when super operation is fetch' do
|
|
|
|
let(:event) { double(:event, duration: 15.2, payload: { hit: true, super_operation: :fetch }) }
|
|
|
|
|
|
|
|
it 'does not increment cache read miss' do
|
|
|
|
expect(transaction).not_to receive(:increment).
|
|
|
|
with(:cache_read_hit_count, 1)
|
|
|
|
|
|
|
|
subscriber.cache_read(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with miss event' do
|
|
|
|
let(:event) { double(:event, duration: 15.2, payload: { hit: false }) }
|
|
|
|
|
|
|
|
it 'increments the cache_read_miss count' do
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_read_miss_count, 1)
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(any_args).at_least(1) # Other calls
|
|
|
|
|
|
|
|
subscriber.cache_read(event)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when super operation is fetch' do
|
|
|
|
let(:event) { double(:event, duration: 15.2, payload: { hit: false, super_operation: :fetch }) }
|
|
|
|
|
|
|
|
it 'does not increment cache read miss' do
|
|
|
|
expect(transaction).not_to receive(:increment).
|
|
|
|
with(:cache_read_miss_count, 1)
|
|
|
|
|
|
|
|
subscriber.cache_read(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-04-08 11:54:52 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
describe '#cache_write' do
|
|
|
|
it 'increments the cache_write duration' do
|
|
|
|
expect(subscriber).to receive(:increment).
|
2016-05-15 14:47:41 -04:00
|
|
|
with(:cache_write, event.duration)
|
2016-04-08 11:54:52 -04:00
|
|
|
|
|
|
|
subscriber.cache_write(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#cache_delete' do
|
|
|
|
it 'increments the cache_delete duration' do
|
|
|
|
expect(subscriber).to receive(:increment).
|
2016-05-15 14:47:41 -04:00
|
|
|
with(:cache_delete, event.duration)
|
2016-04-08 11:54:52 -04:00
|
|
|
|
|
|
|
subscriber.cache_delete(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#cache_exist?' do
|
|
|
|
it 'increments the cache_exists duration' do
|
|
|
|
expect(subscriber).to receive(:increment).
|
2016-05-15 14:47:41 -04:00
|
|
|
with(:cache_exists, event.duration)
|
2016-04-08 11:54:52 -04:00
|
|
|
|
|
|
|
subscriber.cache_exist?(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-06-29 11:03:20 -04:00
|
|
|
describe '#cache_fetch_hit' do
|
|
|
|
context 'without a transaction' do
|
|
|
|
it 'returns' do
|
|
|
|
expect(transaction).not_to receive(:increment)
|
|
|
|
|
|
|
|
subscriber.cache_fetch_hit(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a transaction' do
|
|
|
|
before do
|
|
|
|
allow(subscriber).to receive(:current_transaction).
|
|
|
|
and_return(transaction)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'increments the cache_read_hit count' do
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_read_hit_count, 1)
|
|
|
|
|
|
|
|
subscriber.cache_fetch_hit(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#cache_generate' do
|
|
|
|
context 'without a transaction' do
|
|
|
|
it 'returns' do
|
|
|
|
expect(transaction).not_to receive(:increment)
|
|
|
|
|
|
|
|
subscriber.cache_generate(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a transaction' do
|
|
|
|
before do
|
|
|
|
allow(subscriber).to receive(:current_transaction).
|
|
|
|
and_return(transaction)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'increments the cache_fetch_miss count' do
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_read_miss_count, 1)
|
|
|
|
|
|
|
|
subscriber.cache_generate(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-04-08 11:54:52 -04:00
|
|
|
describe '#increment' do
|
|
|
|
context 'without a transaction' do
|
|
|
|
it 'returns' do
|
|
|
|
expect(transaction).not_to receive(:increment)
|
|
|
|
|
|
|
|
subscriber.increment(:foo, 15.2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a transaction' do
|
|
|
|
before do
|
|
|
|
allow(subscriber).to receive(:current_transaction).
|
|
|
|
and_return(transaction)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'increments the total and specific cache duration' do
|
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_duration, event.duration)
|
|
|
|
|
2016-05-15 14:47:41 -04:00
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_count, 1)
|
|
|
|
|
2016-04-08 11:54:52 -04:00
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_delete_duration, event.duration)
|
|
|
|
|
2016-05-15 14:47:41 -04:00
|
|
|
expect(transaction).to receive(:increment).
|
|
|
|
with(:cache_delete_count, 1)
|
|
|
|
|
|
|
|
subscriber.increment(:cache_delete, event.duration)
|
2016-04-08 11:54:52 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|