Commit e0c0b628 authored by Jan Provaznik's avatar Jan Provaznik

Merge branch '282458_remove_default_update_sequence_id_from_jira_connect_workers' into 'master'

Remove default value for udpate_sequence_id

See merge request gitlab-org/gitlab!51006
parents d921fc2f f8d509f8
...@@ -889,7 +889,7 @@ ...@@ -889,7 +889,7 @@
:urgency: :low :urgency: :low
:resource_boundary: :unknown :resource_boundary: :unknown
:weight: 1 :weight: 1
:idempotent: :idempotent: true
:tags: [] :tags: []
- :name: jira_connect:jira_connect_sync_builds - :name: jira_connect:jira_connect_sync_builds
:feature_category: :integrations :feature_category: :integrations
...@@ -913,7 +913,7 @@ ...@@ -913,7 +913,7 @@
:urgency: :low :urgency: :low
:resource_boundary: :unknown :resource_boundary: :unknown
:weight: 1 :weight: 1
:idempotent: :idempotent: true
:tags: [] :tags: []
- :name: jira_connect:jira_connect_sync_project - :name: jira_connect:jira_connect_sync_project
:feature_category: :integrations :feature_category: :integrations
......
...@@ -8,8 +8,9 @@ module JiraConnect ...@@ -8,8 +8,9 @@ module JiraConnect
feature_category :integrations feature_category :integrations
loggable_arguments 1, 2 loggable_arguments 1, 2
worker_has_external_dependencies! worker_has_external_dependencies!
idempotent!
def perform(project_id, branch_name, commit_shas, update_sequence_id = nil) def perform(project_id, branch_name, commit_shas, update_sequence_id)
project = Project.find_by_id(project_id) project = Project.find_by_id(project_id)
return unless project return unless project
......
...@@ -6,10 +6,11 @@ module JiraConnect ...@@ -6,10 +6,11 @@ module JiraConnect
queue_namespace :jira_connect queue_namespace :jira_connect
feature_category :integrations feature_category :integrations
idempotent!
worker_has_external_dependencies! worker_has_external_dependencies!
def perform(merge_request_id, update_sequence_id = nil) def perform(merge_request_id, update_sequence_id)
merge_request = MergeRequest.find_by_id(merge_request_id) merge_request = MergeRequest.find_by_id(merge_request_id)
return unless merge_request && merge_request.project return unless merge_request && merge_request.project
......
---
title: Fix Jira MR status not syncing by making workers idempotent
merge_request: 51006
author:
type: fixed
...@@ -13,82 +13,67 @@ RSpec.describe JiraConnect::SyncBranchWorker do ...@@ -13,82 +13,67 @@ RSpec.describe JiraConnect::SyncBranchWorker do
let(:project_id) { project.id } let(:project_id) { project.id }
let(:branch_name) { 'master' } let(:branch_name) { 'master' }
let(:commit_shas) { %w(b83d6e3 5a62481) } let(:commit_shas) { %w(b83d6e3 5a62481) }
let(:update_sequence_id) { 1 }
subject { described_class.new.perform(project_id, branch_name, commit_shas) }
def expect_jira_sync_service_execute(args) def expect_jira_sync_service_execute(args)
expect_next_instance_of(JiraConnect::SyncService) do |instance| expect_next_instances_of(JiraConnect::SyncService, IdempotentWorkerHelper::WORKER_EXEC_TIMES) do |instance|
expect(instance).to receive(:execute).with(args.merge(update_sequence_id: nil)) expect(instance).to receive(:execute).with(args)
end end
end end
it 'calls JiraConnect::SyncService#execute' do it_behaves_like 'an idempotent worker' do
expect_jira_sync_service_execute( let(:job_args) { [project_id, branch_name, commit_shas, update_sequence_id] }
branches: [instance_of(Gitlab::Git::Branch)],
commits: project.commits_by(oids: commit_shas)
)
subject
end
context 'without branch name' do before do
let(:branch_name) { nil } stub_request(:post, 'https://sample.atlassian.net/rest/devinfo/0.10/bulk').to_return(status: 200, body: '', headers: {})
it 'calls JiraConnect::SyncService#execute' do
expect_jira_sync_service_execute(
branches: nil,
commits: project.commits_by(oids: commit_shas)
)
subject
end end
end
context 'without commits' do
let(:commit_shas) { nil }
it 'calls JiraConnect::SyncService#execute' do it 'calls JiraConnect::SyncService#execute' do
expect_jira_sync_service_execute( expect_jira_sync_service_execute(
branches: [instance_of(Gitlab::Git::Branch)], branches: [instance_of(Gitlab::Git::Branch)],
commits: nil commits: project.commits_by(oids: commit_shas),
update_sequence_id: update_sequence_id
) )
subject subject
end end
end
context 'when project no longer exists' do context 'without branch name' do
let(:project_id) { non_existing_record_id } let(:branch_name) { nil }
it 'does not call JiraConnect::SyncService' do it 'calls JiraConnect::SyncService#execute' do
expect(JiraConnect::SyncService).not_to receive(:new) expect_jira_sync_service_execute(
branches: nil,
commits: project.commits_by(oids: commit_shas),
update_sequence_id: update_sequence_id
)
subject subject
end
end end
end
context 'with update_sequence_id' do context 'without commits' do
let(:update_sequence_id) { 1 } let(:commit_shas) { nil }
let(:request_path) { '/rest/devinfo/0.10/bulk' }
let(:request_body) do it 'calls JiraConnect::SyncService#execute' do
{ expect_jira_sync_service_execute(
repositories: [ branches: [instance_of(Gitlab::Git::Branch)],
Atlassian::JiraConnect::Serializers::RepositoryEntity.represent( commits: nil,
project, update_sequence_id: update_sequence_id
commits: project.commits_by(oids: commit_shas), )
branches: [project.repository.find_branch(branch_name)],
update_sequence_id: update_sequence_id subject
) end
]
}
end end
subject { described_class.new.perform(project_id, branch_name, commit_shas, update_sequence_id) } context 'when project no longer exists' do
let(:project_id) { non_existing_record_id }
it 'sends the reqeust with custom update_sequence_id' do it 'does not call JiraConnect::SyncService' do
expect_next(Atlassian::JiraConnect::Client).to receive(:post).with(request_path, request_body) expect(JiraConnect::SyncService).not_to receive(:new)
subject subject
end
end end
end end
end end
......
...@@ -12,48 +12,31 @@ RSpec.describe JiraConnect::SyncMergeRequestWorker do ...@@ -12,48 +12,31 @@ RSpec.describe JiraConnect::SyncMergeRequestWorker do
let_it_be(:merge_request) { create(:merge_request, source_project: project) } let_it_be(:merge_request) { create(:merge_request, source_project: project) }
let(:merge_request_id) { merge_request.id } let(:merge_request_id) { merge_request.id }
let(:update_sequence_id) { 1 }
subject { described_class.new.perform(merge_request_id) } it_behaves_like 'an idempotent worker' do
let(:job_args) { [merge_request_id, update_sequence_id] }
it 'calls JiraConnect::SyncService#execute' do before do
expect_next_instance_of(JiraConnect::SyncService) do |service| stub_request(:post, 'https://sample.atlassian.net/rest/devinfo/0.10/bulk').to_return(status: 200, body: '', headers: {})
expect(service).to receive(:execute).with(merge_requests: [merge_request], update_sequence_id: nil)
end end
subject it 'calls JiraConnect::SyncService#execute' do
end expect_next_instances_of(JiraConnect::SyncService, IdempotentWorkerHelper::WORKER_EXEC_TIMES) do |service|
expect(service).to receive(:execute).with(merge_requests: [merge_request], update_sequence_id: update_sequence_id)
context 'when MR no longer exists' do end
let(:merge_request_id) { non_existing_record_id }
it 'does not call JiraConnect::SyncService' do
expect(JiraConnect::SyncService).not_to receive(:new)
subject subject
end end
end
context 'with update_sequence_id' do context 'when MR no longer exists' do
let(:update_sequence_id) { 1 } let(:merge_request_id) { non_existing_record_id }
let(:request_path) { '/rest/devinfo/0.10/bulk' }
let(:request_body) do
{
repositories: [
Atlassian::JiraConnect::Serializers::RepositoryEntity.represent(
project,
merge_requests: [merge_request],
update_sequence_id: update_sequence_id
)
]
}
end
subject { described_class.new.perform(merge_request_id, update_sequence_id) }
it 'sends the request with custom update_sequence_id' do it 'does not call JiraConnect::SyncService' do
expect_next(Atlassian::JiraConnect::Client).to receive(:post).with(request_path, request_body) expect(JiraConnect::SyncService).not_to receive(:new)
subject subject
end
end end
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