Commit 81605504 authored by Bob Van Landuyt's avatar Bob Van Landuyt

Remove membership from fork network when unlinking

parent df7f530d
...@@ -16,6 +16,7 @@ module Projects ...@@ -16,6 +16,7 @@ module Projects
refresh_forks_count(@project.forked_from_project) refresh_forks_count(@project.forked_from_project)
@project.forked_project_link.destroy @project.forked_project_link.destroy
@project.fork_network_member.destroy
end end
def refresh_forks_count(project) def refresh_forks_count(project)
......
require 'spec_helper' require 'spec_helper'
describe Projects::UnlinkForkService do describe Projects::UnlinkForkService do
subject { described_class.new(fork_project, user) } include ProjectForksHelper
let(:fork_link) { create(:forked_project_link) } subject { described_class.new(forked_project, user) }
let(:fork_project) { fork_link.forked_to_project }
let(:fork_link) { forked_project.forked_project_link }
let(:project) { create(:project, :public) }
let(:forked_project) { fork_project(project, user) }
let(:user) { create(:user) } let(:user) { create(:user) }
context 'with opened merge request on the source project' do context 'with opened merge request on the source project' do
let(:merge_request) { create(:merge_request, source_project: fork_project, target_project: fork_link.forked_from_project) } let(:merge_request) { create(:merge_request, source_project: forked_project, target_project: fork_link.forked_from_project) }
let(:mr_close_service) { MergeRequests::CloseService.new(fork_project, user) } let(:mr_close_service) { MergeRequests::CloseService.new(forked_project, user) }
before do before do
allow(MergeRequests::CloseService).to receive(:new) allow(MergeRequests::CloseService).to receive(:new)
.with(fork_project, user) .with(forked_project, user)
.and_return(mr_close_service) .and_return(mr_close_service)
end end
...@@ -25,13 +28,24 @@ describe Projects::UnlinkForkService do ...@@ -25,13 +28,24 @@ describe Projects::UnlinkForkService do
end end
it 'remove fork relation' do it 'remove fork relation' do
expect(fork_project.forked_project_link).to receive(:destroy) expect(forked_project.forked_project_link).to receive(:destroy)
subject.execute
end
it 'removes the link to the fork network' do
expect(forked_project.fork_network_member).to be_present
expect(forked_project.fork_network).to be_present
subject.execute subject.execute
forked_project.reload
expect(forked_project.fork_network_member).to be_nil
expect(forked_project.reload.fork_network).to be_nil
end end
it 'refreshes the forks count cache of the source project' do it 'refreshes the forks count cache of the source project' do
source = fork_project.forked_from_project source = forked_project.forked_from_project
expect(source.forks_count).to eq(1) expect(source.forks_count).to eq(1)
......
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