Commit 9a29eb16 authored by Mayra Cabrera's avatar Mayra Cabrera

Merge branch 'fix-jira-sync-commits' into 'master'

Fix syncing of commits to Jira

See merge request gitlab-org/gitlab-ee!16098
parents d00c78a5 40c97196
...@@ -14,7 +14,7 @@ module EE ...@@ -14,7 +14,7 @@ module EE
return unless jira_subscription_exists? return unless jira_subscription_exists?
branch_to_sync = branch_name if Atlassian::JiraIssueKeyExtractor.has_keys?(branch_name) branch_to_sync = branch_name if Atlassian::JiraIssueKeyExtractor.has_keys?(branch_name)
commits_to_sync = limited_commits.select { |commit| Atlassian::JiraIssueKeyExtractor.has_keys?(commit.safe_message) }.map(&:hash) 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)
......
...@@ -111,10 +111,16 @@ describe Git::BranchPushService do ...@@ -111,10 +111,16 @@ describe Git::BranchPushService do
context 'Jira Connect hooks' do context 'Jira Connect hooks' do
set(:project) { create(:project, :repository) } set(:project) { create(:project, :repository) }
let(:branch_to_sync) { nil }
let(:commits_to_sync) { [] }
shared_examples 'enqueues Jira sync worker' do shared_examples 'enqueues Jira sync worker' do
it do it do
Sidekiq::Testing.fake! do Sidekiq::Testing.fake! do
expect(JiraConnect::SyncBranchWorker).to receive(:perform_async)
.with(project.id, branch_to_sync, commits_to_sync)
.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)
end end
end end
...@@ -144,12 +150,15 @@ describe Git::BranchPushService do ...@@ -144,12 +150,15 @@ describe Git::BranchPushService do
end end
context 'branch name contains Jira issue key' do context 'branch name contains Jira issue key' do
let(:ref) { 'refs/heads/branch-JIRA-123' } let(:branch_to_sync) { 'branch-JIRA-123' }
let(:ref) { "refs/heads/#{branch_to_sync}" }
it_behaves_like 'enqueues Jira sync worker' it_behaves_like 'enqueues Jira sync worker'
end end
context 'commit message contains Jira issue key' do context 'commit message contains Jira issue key' do
let(:commits_to_sync) { [newrev] }
before do before do
allow_any_instance_of(Commit).to receive(:safe_message).and_return('Commit with key JIRA-123') allow_any_instance_of(Commit).to receive(:safe_message).and_return('Commit with key JIRA-123')
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