zammad/spec/integration/gitlab_spec.rb
Simon Bärlocher dc09c35781
Fixes #6036 - GitLab integration not working after update to 18.10.
Closes #6037 - Accept work_items URLs in addition to issues URLs.
2026-03-24 20:27:59 +01:00

114 lines
3.4 KiB
Ruby

# Copyright (C) 2012-2026 Zammad Foundation, https://zammad-foundation.org/
require 'rails_helper'
require 'integration/git_integration_base_examples'
RSpec.describe GitLab, integration: true, required_envs: %w[GITLAB_ENDPOINT GITLAB_APITOKEN GITLAB_ISSUE_LINK] do
let(:invalid_issue_url) { "https://#{URI.parse(ENV['GITLAB_ISSUE_LINK']).host}/group/project/-/issues/1" }
let(:issue_data) do
{
id: '1',
title: 'Example issue',
url: ENV['GITLAB_ISSUE_LINK'],
icon_state: 'open',
milestone: 'important milestone',
assignees: ['zammad-robot'],
labels: [
{
color: '#FF0000',
text_color: '#FFFFFF',
title: 'critical'
},
{
color: '#0033CC',
text_color: '#FFFFFF',
title: 'label1'
},
{
color: '#D1D100',
text_color: '#1F1E24',
title: 'special'
}
],
}
end
let(:instance) { described_class.new(endpoint: ENV['GITLAB_ENDPOINT'], api_token: ENV['GITLAB_APITOKEN']) }
it_behaves_like 'Git Integration Base', issue_type: :gitlab
describe '#issues_by_urls' do
let(:result) { instance.issues_by_urls([ issue_url ]) }
context 'when issue exists' do
let(:issue_url) { ENV['GITLAB_ISSUE_LINK'] }
it 'returns a issues list' do
expect(result[:issues].size).to eq(1)
end
it 'returns issue data in the issues list' do
expect(result[:issues][0]).to eq(issue_data)
end
it 'returns no url replacements' do
expect(result[:url_replacements].size).to eq(0)
end
end
context 'when issue does not exists' do
let(:issue_url) { invalid_issue_url }
it 'returns no issues' do
expect(result[:issues].size).to eq(0)
end
it 'returns no url replacements' do
expect(result[:url_replacements].size).to eq(0)
end
end
end
describe '#issue_by_url' do
let(:result) { instance.issue_by_url(issue_url) }
context 'when issue exists' do
let(:issue_url) { ENV['GITLAB_ISSUE_LINK'] }
it 'returns issue data' do
expect(result).to eq(issue_data)
end
end
context 'when issue does not exists' do
let(:issue_url) { invalid_issue_url }
it 'returns nil' do
expect(result).to be_nil
end
end
end
describe '#variables' do
describe 'Zammad ignores relative GitLab URLs #3830' do
let(:endpoint) { ENV['GITLAB_ENDPOINT'].sub('api/graphql', 'subfolder/api/graphql') }
let(:instance) { described_class.new(endpoint:, api_token: ENV['GITLAB_APITOKEN']) }
let(:issue_url) { "https://#{URI.parse(ENV['GITLAB_ISSUE_LINK']).host}/subfolder/group/project/-/issues/1" }
let(:linked_issue) { GitLab::LinkedIssue.new(instance.client) }
it 'does remove the subfolder from the fullpath to get the issue correctly' do
expect(linked_issue.send(:variables, issue_url)[:fullpath]).to eq('group/project')
end
end
describe 'work_items URL format' do
let(:linked_issue) { GitLab::LinkedIssue.new(instance.client) }
let(:work_item_url) { "https://#{URI.parse(ENV['GITLAB_ISSUE_LINK']).host}/group/project/-/work_items/42" }
it 'accepts work_items URLs in addition to issues URLs' do
expect(linked_issue.send(:variables, work_item_url)).to include(fullpath: 'group/project', issue_id: '42')
end
end
end
end