Commit 17fc5fc5 authored by Michael Kozono's avatar Michael Kozono

Prevent unnecessary `select`s and `remove_key`s

parent e4e7e9c3
...@@ -248,15 +248,17 @@ module Gitlab ...@@ -248,15 +248,17 @@ module Gitlab
return unless self.authorized_keys_enabled? return unless self.authorized_keys_enabled?
batch_read_key_ids do |ids_in_file| batch_read_key_ids do |ids_in_file|
ids_in_file.uniq!
keys_in_db = Key.where(id: ids_in_file) keys_in_db = Key.where(id: ids_in_file)
if ids_in_file.size > keys_in_db.count
return unless ids_in_file.size > keys_in_db.count # optimization
ids_to_remove = ids_in_file - keys_in_db.pluck(:id) ids_to_remove = ids_in_file - keys_in_db.pluck(:id)
ids_to_remove.each do |id| ids_to_remove.each do |id|
remove_key("key-#{id}") remove_key("key-#{id}")
end end
end end
end end
end
# Iterate over all ssh key IDs from gitlab shell, in batches # Iterate over all ssh key IDs from gitlab shell, in batches
# #
......
...@@ -289,6 +289,43 @@ describe Gitlab::Shell, lib: true do ...@@ -289,6 +289,43 @@ describe Gitlab::Shell, lib: true do
expect(find_in_authorized_keys_file(@another_key.id)).to be_truthy expect(find_in_authorized_keys_file(@another_key.id)).to be_truthy
end end
end end
context 'when keys there are duplicate keys in the file that are not in the DB' do
before do
gitlab_shell.remove_all_keys
gitlab_shell.add_key('key-1234', 'ssh-rsa ASDFASDF')
gitlab_shell.add_key('key-1234', 'ssh-rsa ASDFASDF')
end
it 'removes the keys' do
expect(find_in_authorized_keys_file(1234)).to be_truthy
gitlab_shell.remove_keys_not_found_in_db
expect(find_in_authorized_keys_file(1234)).to be_falsey
end
it 'does not run remove more than once per key (in a batch)' do
expect(gitlab_shell).to receive(:remove_key).with('key-1234').once
gitlab_shell.remove_keys_not_found_in_db
end
end
context 'when keys there are duplicate keys in the file that ARE in the DB' do
before do
gitlab_shell.remove_all_keys
@key = create(:key)
gitlab_shell.add_key(@key.shell_id, @key.key)
end
it 'does not remove the key' do
gitlab_shell.remove_keys_not_found_in_db
expect(find_in_authorized_keys_file(@key.id)).to be_truthy
end
it 'does not need to run a SELECT query for that batch, on account of that key' do
expect_any_instance_of(ActiveRecord::Relation).not_to receive(:pluck)
gitlab_shell.remove_keys_not_found_in_db
end
end
end end
describe '#batch_read_key_ids' do describe '#batch_read_key_ids' do
......
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