Merge branch 'avoid-expect_any_instance_of' into 'master'

Avoid expect_any_instance_of in transfer service spec

See merge request !13191
This commit is contained in:
Rémy Coutable 2017-07-31 15:35:55 +00:00
commit 2519027442
1 changed files with 13 additions and 9 deletions

View File

@ -37,18 +37,18 @@ describe Projects::TransferService do
end
it 'executes system hooks' do
expect_any_instance_of(described_class).to receive(:execute_system_hooks)
transfer_project(project, user, group)
transfer_project(project, user, group) do |service|
expect(service).to receive(:execute_system_hooks)
end
end
end
context 'when transfer fails' do
let!(:original_path) { project_path(project) }
def attempt_project_transfer
def attempt_project_transfer(&block)
expect do
transfer_project(project, user, group)
transfer_project(project, user, group, &block)
end.to raise_error(ActiveRecord::ActiveRecordError)
end
@ -80,9 +80,9 @@ describe Projects::TransferService do
end
it "doesn't run system hooks" do
expect_any_instance_of(described_class).not_to receive(:execute_system_hooks)
attempt_project_transfer
attempt_project_transfer do |service|
expect(service).not_to receive(:execute_system_hooks)
end
end
end
@ -120,7 +120,11 @@ describe Projects::TransferService do
end
def transfer_project(project, user, new_namespace)
Projects::TransferService.new(project, user).execute(new_namespace)
service = Projects::TransferService.new(project, user)
yield(service) if block_given?
service.execute(new_namespace)
end
context 'visibility level' do