Commit b9132102 authored by Giorgenes Gelatti's avatar Giorgenes Gelatti

Refactor transfer service

Refactor transfer service code
and specs to improve code quality
and specs efficiency
parent f495e00a
...@@ -54,9 +54,7 @@ module Groups ...@@ -54,9 +54,7 @@ module Groups
npm_packages = ::Packages::GroupPackagesFinder.new(current_user, group, package_type: :npm).execute npm_packages = ::Packages::GroupPackagesFinder.new(current_user, group, package_type: :npm).execute
return true if different_root_ancestor? && npm_packages.exists? different_root_ancestor? && npm_packages.exists?
false
end end
def different_root_ancestor? def different_root_ancestor?
......
...@@ -6198,38 +6198,40 @@ RSpec.describe Project do ...@@ -6198,38 +6198,40 @@ RSpec.describe Project do
subject { project.has_packages?(package_type) } subject { project.has_packages?(package_type) }
shared_examples 'returning true examples' do shared_examples 'has_package' do
context 'package of package_type exists' do
let!(:package) { create("#{package_type}_package", project: project) } let!(:package) { create("#{package_type}_package", project: project) }
it { is_expected.to be true } it { is_expected.to be true }
end end
shared_examples 'returning false examples' do context 'package of package_type does not exist' do
it { is_expected.to be false } it { is_expected.to be false }
end end
end
context 'with maven packages' do context 'with maven packages' do
it_behaves_like 'returning true examples' do it_behaves_like 'has_package' do
let(:package_type) { :maven } let(:package_type) { :maven }
end end
end end
context 'with npm packages' do context 'with npm packages' do
it_behaves_like 'returning true examples' do it_behaves_like 'has_package' do
let(:package_type) { :npm } let(:package_type) { :npm }
end end
end end
context 'with conan packages' do context 'with conan packages' do
it_behaves_like 'returning true examples' do it_behaves_like 'has_package' do
let(:package_type) { :conan } let(:package_type) { :conan }
end end
end end
context 'with no package type' do context 'calling has_package? with nil' do
it_behaves_like 'returning false examples' do
let(:package_type) { nil } let(:package_type) { nil }
end
it { is_expected.to be false }
end end
end end
......
...@@ -9,7 +9,7 @@ RSpec.describe Groups::TransferService do ...@@ -9,7 +9,7 @@ RSpec.describe Groups::TransferService do
let(:transfer_service) { described_class.new(group, user) } let(:transfer_service) { described_class.new(group, user) }
context 'handling packages' do context 'handling packages' do
let(:group) { create(:group, :public) } let_it_be(:group) { create(:group, :public) }
let(:project) { create(:project, :public, namespace: group) } let(:project) { create(:project, :public, namespace: group) }
let(:new_group) { create(:group, :public) } let(:new_group) { create(:group, :public) }
...@@ -28,6 +28,7 @@ RSpec.describe Groups::TransferService do ...@@ -28,6 +28,7 @@ RSpec.describe Groups::TransferService do
transfer_service.execute(new_group) transfer_service.execute(new_group)
expect(transfer_service.error).to eq('Transfer failed: Group contains projects with NPM packages.') expect(transfer_service.error).to eq('Transfer failed: Group contains projects with NPM packages.')
expect(group.parent).not_to eq(new_group)
end end
end end
...@@ -49,7 +50,7 @@ RSpec.describe Groups::TransferService do ...@@ -49,7 +50,7 @@ RSpec.describe Groups::TransferService do
it 'allows transfer' do it 'allows transfer' do
transfer_service.execute(new_group) transfer_service.execute(new_group)
expect(transfer_service.error).not_to be expect(transfer_service.error).to be nil
expect(group.parent).to eq(new_group) expect(group.parent).to eq(new_group)
end end
end end
...@@ -69,7 +70,7 @@ RSpec.describe Groups::TransferService do ...@@ -69,7 +70,7 @@ RSpec.describe Groups::TransferService do
it 'allows transfer' do it 'allows transfer' do
transfer_service.execute(nil) transfer_service.execute(nil)
expect(transfer_service.error).not_to be expect(transfer_service.error).to be nil
expect(group.parent).to be_nil expect(group.parent).to be_nil
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