Commit a52eff6c authored by Nick Thomas's avatar Nick Thomas

Prevent a database update on Geo secondaries

parent 0f4a6d0f
module Keys module Keys
class LastUsedService class LastUsedService
prepend ::EE::Keys::LastUsedService
TIMEOUT = 1.day.to_i TIMEOUT = 1.day.to_i
attr_reader :key attr_reader :key
......
module EE
module Keys
module LastUsedService
def update?
raise NotImplementedError unless defined?(super)
!::Gitlab::Geo.secondary? && super
end
end
end
end
require 'spec_helper'
describe Keys::LastUsedService do
it 'does not run on Geo secondaries', :clean_gitlab_redis_shared_state do
key = create(:key, last_used_at: 1.year.ago)
original_time = key.last_used_at
allow(::Gitlab::Geo).to receive(:secondary?).and_return(true)
described_class.new(key).execute
expect(key.reload.last_used_at).to be_like_time(original_time)
end
end
...@@ -26,12 +26,7 @@ describe Keys::LastUsedService do ...@@ -26,12 +26,7 @@ describe Keys::LastUsedService do
# make sure we _only_ update last_used_at and not always updated_at. # make sure we _only_ update last_used_at and not always updated_at.
key = create(:key, last_used_at: 1.year.ago) key = create(:key, last_used_at: 1.year.ago)
recorder = ActiveRecord::QueryRecorder.new do expect { described_class.new(key).execute }.not_to change { key.updated_at }
described_class.new(key).execute
end
expect(recorder.count).to eq(1)
expect(recorder.log[0]).not_to include('updated_at')
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment