Commit b61f203c authored by Andy Soiron's avatar Andy Soiron

Pass update_sequence_id to JiraConnect workers

Step two of the three step deployment to make JiraConnect
workers idempotent. This makes sure the update_sequence_id
is used in all invocations of JiraConnect::SyncMergeRequestWorker
and JiraConnect::SyncBranchWorker.
parent 75071e5b
...@@ -118,7 +118,7 @@ module Git ...@@ -118,7 +118,7 @@ module Git
commits_to_sync = limited_commits.select { |commit| Atlassian::JiraIssueKeyExtractor.has_keys?(commit.safe_message) }.map(&:sha) commits_to_sync = limited_commits.select { |commit| Atlassian::JiraIssueKeyExtractor.has_keys?(commit.safe_message) }.map(&:sha)
if branch_to_sync || commits_to_sync.any? if branch_to_sync || commits_to_sync.any?
JiraConnect::SyncBranchWorker.perform_async(project.id, branch_to_sync, commits_to_sync) JiraConnect::SyncBranchWorker.perform_async(project.id, branch_to_sync, commits_to_sync, Atlassian::JiraConnect::Client.generate_update_sequence_id)
end end
end end
......
...@@ -58,7 +58,7 @@ module MergeRequests ...@@ -58,7 +58,7 @@ module MergeRequests
return unless project.jira_subscription_exists? return unless project.jira_subscription_exists?
if Atlassian::JiraIssueKeyExtractor.has_keys?(merge_request.title, merge_request.description) if Atlassian::JiraIssueKeyExtractor.has_keys?(merge_request.title, merge_request.description)
JiraConnect::SyncMergeRequestWorker.perform_async(merge_request.id) JiraConnect::SyncMergeRequestWorker.perform_async(merge_request.id, Atlassian::JiraConnect::Client.generate_update_sequence_id)
end end
end end
......
...@@ -718,10 +718,10 @@ RSpec.describe Git::BranchPushService, services: true do ...@@ -718,10 +718,10 @@ RSpec.describe Git::BranchPushService, services: true do
end end
shared_examples 'enqueues Jira sync worker' do shared_examples 'enqueues Jira sync worker' do
specify do specify :aggregate_failures do
Sidekiq::Testing.fake! do Sidekiq::Testing.fake! do
expect(JiraConnect::SyncBranchWorker).to receive(:perform_async) expect(JiraConnect::SyncBranchWorker).to receive(:perform_async)
.with(project.id, branch_to_sync, commits_to_sync) .with(project.id, branch_to_sync, commits_to_sync, kind_of(Numeric))
.and_call_original .and_call_original
expect { subject.execute }.to change(JiraConnect::SyncBranchWorker.jobs, :size).by(1) expect { subject.execute }.to change(JiraConnect::SyncBranchWorker.jobs, :size).by(1)
......
...@@ -20,7 +20,8 @@ RSpec.describe MergeRequests::BaseService do ...@@ -20,7 +20,8 @@ RSpec.describe MergeRequests::BaseService do
describe '#execute_hooks' do describe '#execute_hooks' do
shared_examples 'enqueues Jira sync worker' do shared_examples 'enqueues Jira sync worker' do
it do specify :aggregate_failures do
expect(JiraConnect::SyncMergeRequestWorker).to receive(:perform_async).with(kind_of(Numeric), kind_of(Numeric)).and_call_original
Sidekiq::Testing.fake! do Sidekiq::Testing.fake! do
expect { subject.execute }.to change(JiraConnect::SyncMergeRequestWorker.jobs, :size).by(1) expect { subject.execute }.to change(JiraConnect::SyncMergeRequestWorker.jobs, :size).by(1)
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