Implement expect_next_instance_of
and use it
We need this because `expect_any_instance_of` doesn't work on prepended models. Now we could use the same code between CE/EE
This commit is contained in:
parent
7c11ed8c91
commit
562f357ba5
7 changed files with 30 additions and 11 deletions
|
@ -25,7 +25,9 @@ describe Gitlab::BitbucketImport::ProjectCreator do
|
|||
end
|
||||
|
||||
it 'creates project' do
|
||||
allow_any_instance_of(Project).to receive(:add_import_job)
|
||||
expect_next_instance_of(Project) do |project|
|
||||
expect(project).to receive(:add_import_job)
|
||||
end
|
||||
|
||||
project_creator = described_class.new(repo, 'vim', namespace, user, access_params)
|
||||
project = project_creator.execute
|
||||
|
|
|
@ -21,7 +21,9 @@ describe Gitlab::GitlabImport::ProjectCreator do
|
|||
end
|
||||
|
||||
it 'creates project' do
|
||||
allow_any_instance_of(Project).to receive(:add_import_job)
|
||||
expect_next_instance_of(Project) do |project|
|
||||
expect(project).to receive(:add_import_job)
|
||||
end
|
||||
|
||||
project_creator = described_class.new(repo, namespace, user, access_params)
|
||||
project = project_creator.execute
|
||||
|
|
|
@ -16,7 +16,9 @@ describe Gitlab::GoogleCodeImport::ProjectCreator do
|
|||
end
|
||||
|
||||
it 'creates project' do
|
||||
allow_any_instance_of(Project).to receive(:add_import_job)
|
||||
expect_next_instance_of(Project) do |project|
|
||||
expect(project).to receive(:add_import_job)
|
||||
end
|
||||
|
||||
project_creator = described_class.new(repo, namespace, user)
|
||||
project = project_creator.execute
|
||||
|
|
|
@ -17,7 +17,10 @@ describe Gitlab::LegacyGithubImport::ProjectCreator do
|
|||
|
||||
before do
|
||||
namespace.add_owner(user)
|
||||
allow_any_instance_of(Project).to receive(:add_import_job)
|
||||
|
||||
expect_next_instance_of(Project) do |project|
|
||||
expect(project).to receive(:add_import_job)
|
||||
end
|
||||
end
|
||||
|
||||
describe '#execute' do
|
||||
|
|
|
@ -69,6 +69,7 @@ RSpec.configure do |config|
|
|||
config.include StubFeatureFlags
|
||||
config.include StubGitlabCalls
|
||||
config.include StubGitlabData
|
||||
config.include ExpectNextInstanceOf
|
||||
config.include TestEnv
|
||||
config.include Devise::Test::ControllerHelpers, type: :controller
|
||||
config.include Devise::Test::IntegrationHelpers, type: :feature
|
||||
|
|
13
spec/support/helpers/expect_next_instance_of.rb
Normal file
13
spec/support/helpers/expect_next_instance_of.rb
Normal file
|
@ -0,0 +1,13 @@
|
|||
module ExpectNextInstanceOf
|
||||
def expect_next_instance_of(klass, *new_args)
|
||||
receive_new = receive(:new)
|
||||
receive_new.with(*new_args) if new_args.any?
|
||||
|
||||
expect(klass).to receive_new
|
||||
.and_wrap_original do |method, *original_args|
|
||||
method.call(*original_args).tap do |instance|
|
||||
yield(instance)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
|
@ -18,12 +18,8 @@ describe UpdateMergeRequestsWorker do
|
|||
end
|
||||
|
||||
it 'executes MergeRequests::RefreshService with expected values' do
|
||||
expect(MergeRequests::RefreshService).to receive(:new)
|
||||
.with(project, user).and_wrap_original do |method, *args|
|
||||
method.call(*args).tap do |refresh_service|
|
||||
expect(refresh_service)
|
||||
.to receive(:execute).with(oldrev, newrev, ref)
|
||||
end
|
||||
expect_next_instance_of(MergeRequests::RefreshService, project, user) do |refresh_service|
|
||||
expect(refresh_service).to receive(:execute).with(oldrev, newrev, ref)
|
||||
end
|
||||
|
||||
perform
|
||||
|
|
Loading…
Reference in a new issue