Commit 02b5d064 authored by Douwe Maan's avatar Douwe Maan

Merge branch 'fix-pull-mirror-setting-nil' into 'master'

Fix unsetting credentials data for pull mirrors

Closes #3308

See merge request !2810
parents 71f09bb7 afec33d8
---
title: Fix unsetting credentials data for pull mirrors
merge_request: 2810
author:
type: fixed
...@@ -5,6 +5,16 @@ module EE ...@@ -5,6 +5,16 @@ module EE
bits: 4096 bits: 4096
}.freeze }.freeze
CREDENTIALS_FIELDS = %i[
auth_method
password
ssh_known_hosts
ssh_known_hosts_verified_at
ssh_known_hosts_verified_by_id
ssh_private_key
user
].freeze
extend ActiveSupport::Concern extend ActiveSupport::Concern
included do included do
...@@ -26,14 +36,22 @@ module EE ...@@ -26,14 +36,22 @@ module EE
project&.import_url&.start_with?('ssh://') project&.import_url&.start_with?('ssh://')
end end
%i[auth_method user password ssh_private_key ssh_known_hosts ssh_known_hosts_verified_at ssh_known_hosts_verified_by_id].each do |name| CREDENTIALS_FIELDS.each do |name|
define_method(name) do define_method(name) do
credentials[name] if credentials.present? credentials[name] if credentials.present?
end end
define_method("#{name}=") do |value| define_method("#{name}=") do |value|
self.credentials ||= {} self.credentials ||= {}
self.credentials[name] = value
# Removal of the password, username, etc, generally causes an update of
# the value to the empty string. Detect and gracefully handle this case.
if value.present?
self.credentials[name] = value
else
self.credentials.delete(name)
nil
end
end end
end end
......
...@@ -62,6 +62,34 @@ describe ProjectImportData do ...@@ -62,6 +62,34 @@ describe ProjectImportData do
end end
end end
describe 'credential fields accessors' do
let(:accessors) { %i[auth_method password ssh_known_hosts ssh_known_hosts_verified_at ssh_known_hosts_verified_by_id ssh_private_key user] }
it { expect(described_class::CREDENTIALS_FIELDS).to contain_exactly(*accessors) }
where(:field) { described_class::CREDENTIALS_FIELDS }
with_them do
it 'sets the value in the credentials hash' do
import_data.send("#{field}=", 'foo')
expect(import_data.credentials[field]).to eq('foo')
end
it 'sets a not-present value to nil' do
import_data.send("#{field}=", '')
expect(import_data.credentials[field]).to be_nil
end
it 'returns the data in the credentials hash' do
import_data.credentials[field] = 'foo'
expect(import_data.send(field)).to eq('foo')
end
end
end
describe '#ssh_import?' do describe '#ssh_import?' do
where(:import_url, :expected) do where(:import_url, :expected) do
'ssh://example.com' | true 'ssh://example.com' | true
......
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