2018-09-11 10:26:57 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-09-08 08:09:26 -04:00
|
|
|
require 'spec_helper'
|
2018-09-07 16:03:05 -04:00
|
|
|
|
2018-10-16 09:09:36 -04:00
|
|
|
describe Gitlab::Ci::Config::External::Mapper do
|
2019-01-02 06:51:15 -05:00
|
|
|
set(:project) { create(:project, :repository) }
|
2018-12-01 06:39:13 -05:00
|
|
|
set(:user) { create(:user) }
|
2019-01-02 06:51:15 -05:00
|
|
|
|
|
|
|
let(:local_file) { '/lib/gitlab/ci/templates/non-existent-file.yml' }
|
|
|
|
let(:remote_url) { 'https://gitlab.com/gitlab-org/gitlab-ce/blob/1234/.gitlab-ci-1.yml' }
|
|
|
|
let(:template_file) { 'Auto-DevOps.gitlab-ci.yml' }
|
2019-01-14 05:55:51 -05:00
|
|
|
let(:expandset) { Set.new }
|
2019-01-02 06:51:15 -05:00
|
|
|
|
2018-09-07 16:03:05 -04:00
|
|
|
let(:file_content) do
|
|
|
|
<<~HEREDOC
|
|
|
|
image: 'ruby:2.2'
|
|
|
|
HEREDOC
|
|
|
|
end
|
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
before do
|
|
|
|
WebMock.stub_request(:get, remote_url).to_return(body: file_content)
|
|
|
|
end
|
|
|
|
|
2018-09-07 16:03:05 -04:00
|
|
|
describe '#process' do
|
2019-01-14 05:55:51 -05:00
|
|
|
subject { described_class.new(values, project: project, sha: '123456', user: user, expandset: expandset).process }
|
2018-09-07 16:03:05 -04:00
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
context "when single 'include' keyword is defined" do
|
2018-09-07 16:03:05 -04:00
|
|
|
context 'when the string is a local file' do
|
|
|
|
let(:values) do
|
2019-01-02 06:51:15 -05:00
|
|
|
{ include: local_file,
|
|
|
|
image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns File instances' do
|
|
|
|
expect(subject).to contain_exactly(
|
|
|
|
an_instance_of(Gitlab::Ci::Config::External::File::Local))
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
2019-01-02 06:51:15 -05:00
|
|
|
end
|
2018-09-07 16:03:05 -04:00
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
context 'when the key is a local file hash' do
|
|
|
|
let(:values) do
|
|
|
|
{ include: { 'local' => local_file },
|
|
|
|
image: 'ruby:2.2' }
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns File instances' do
|
2019-01-02 06:51:15 -05:00
|
|
|
expect(subject).to contain_exactly(
|
|
|
|
an_instance_of(Gitlab::Ci::Config::External::File::Local))
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the string is a remote file' do
|
|
|
|
let(:values) do
|
2019-01-02 06:51:15 -05:00
|
|
|
{ include: remote_url, image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns File instances' do
|
|
|
|
expect(subject).to contain_exactly(
|
|
|
|
an_instance_of(Gitlab::Ci::Config::External::File::Remote))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the key is a remote file hash' do
|
|
|
|
let(:values) do
|
|
|
|
{ include: { 'remote' => remote_url },
|
|
|
|
image: 'ruby:2.2' }
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
it 'returns File instances' do
|
|
|
|
expect(subject).to contain_exactly(
|
|
|
|
an_instance_of(Gitlab::Ci::Config::External::File::Remote))
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
2019-01-02 06:51:15 -05:00
|
|
|
end
|
2018-09-07 16:03:05 -04:00
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
context 'when the key is a template file hash' do
|
|
|
|
let(:values) do
|
|
|
|
{ include: { 'template' => template_file },
|
|
|
|
image: 'ruby:2.2' }
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns File instances' do
|
2019-01-02 06:51:15 -05:00
|
|
|
expect(subject).to contain_exactly(
|
|
|
|
an_instance_of(Gitlab::Ci::Config::External::File::Template))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the key is a hash of file and remote' do
|
|
|
|
let(:values) do
|
|
|
|
{ include: { 'local' => local_file, 'remote' => remote_url },
|
|
|
|
image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns ambigious specification error' do
|
|
|
|
expect { subject }.to raise_error(described_class::AmbigiousSpecificationError)
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when 'include' is defined as an array" do
|
|
|
|
let(:values) do
|
2019-01-02 06:51:15 -05:00
|
|
|
{ include: [remote_url, local_file],
|
|
|
|
image: 'ruby:2.2' }
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
it 'returns Files instances' do
|
|
|
|
expect(subject).to all(respond_to(:valid?))
|
|
|
|
expect(subject).to all(respond_to(:content))
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
2019-01-02 06:51:15 -05:00
|
|
|
end
|
2018-09-07 16:03:05 -04:00
|
|
|
|
2019-01-02 06:51:15 -05:00
|
|
|
context "when 'include' is defined as an array of hashes" do
|
|
|
|
let(:values) do
|
|
|
|
{ include: [{ remote: remote_url }, { local: local_file }],
|
|
|
|
image: 'ruby:2.2' }
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns Files instances' do
|
|
|
|
expect(subject).to all(respond_to(:valid?))
|
|
|
|
expect(subject).to all(respond_to(:content))
|
|
|
|
end
|
2019-01-02 06:51:15 -05:00
|
|
|
|
|
|
|
context 'when it has ambigious match' do
|
|
|
|
let(:values) do
|
|
|
|
{ include: [{ remote: remote_url, local: local_file }],
|
|
|
|
image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns ambigious specification error' do
|
|
|
|
expect { subject }.to raise_error(described_class::AmbigiousSpecificationError)
|
|
|
|
end
|
|
|
|
end
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "when 'include' is not defined" do
|
|
|
|
let(:values) do
|
|
|
|
{
|
|
|
|
image: 'ruby:2.2'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns an empty array' do
|
|
|
|
expect(subject).to be_empty
|
|
|
|
end
|
|
|
|
end
|
2019-01-14 05:55:51 -05:00
|
|
|
|
|
|
|
context "when duplicate 'include' is defined" do
|
|
|
|
let(:values) do
|
|
|
|
{ include: [
|
|
|
|
{ 'local' => local_file },
|
|
|
|
{ 'local' => local_file }
|
|
|
|
],
|
|
|
|
image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'raises an exception' do
|
|
|
|
expect { subject }.to raise_error(described_class::DuplicateIncludesError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when too many 'includes' are defined" do
|
|
|
|
let(:values) do
|
|
|
|
{ include: [
|
|
|
|
{ 'local' => local_file },
|
|
|
|
{ 'remote' => remote_url }
|
|
|
|
],
|
|
|
|
image: 'ruby:2.2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_const("#{described_class}::MAX_INCLUDES", 1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'raises an exception' do
|
|
|
|
expect { subject }.to raise_error(described_class::TooManyIncludesError)
|
|
|
|
end
|
|
|
|
end
|
2018-09-07 16:03:05 -04:00
|
|
|
end
|
|
|
|
end
|