2019-12-26 22:10:19 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2023-05-27 22:25:52 +05:30
|
|
|
RSpec.describe Ci::CreatePipelineService, :yaml_processor_feature_flag_corectness,
|
|
|
|
feature_category: :continuous_integration do
|
2019-12-26 22:10:19 +05:30
|
|
|
context 'cache' do
|
2021-01-29 00:20:46 +05:30
|
|
|
let(:project) { create(:project, :custom_repo, files: files) }
|
2022-03-02 08:16:31 +05:30
|
|
|
let(:user) { project.first_owner }
|
2019-12-26 22:10:19 +05:30
|
|
|
let(:ref) { 'refs/heads/master' }
|
|
|
|
let(:source) { :push }
|
|
|
|
let(:service) { described_class.new(project, user, { ref: ref }) }
|
2021-10-27 15:23:28 +05:30
|
|
|
let(:pipeline) { service.execute(source).payload }
|
2019-12-26 22:10:19 +05:30
|
|
|
let(:job) { pipeline.builds.find_by(name: 'job') }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_ci_pipeline_yaml_file(config)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with cache:key' do
|
|
|
|
let(:files) { { 'some-file' => '' } }
|
|
|
|
|
|
|
|
let(:config) do
|
|
|
|
<<~EOY
|
|
|
|
job:
|
|
|
|
script:
|
|
|
|
- ls
|
|
|
|
cache:
|
|
|
|
key: 'a-key'
|
|
|
|
paths: ['logs/', 'binaries/']
|
|
|
|
untracked: true
|
|
|
|
EOY
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'uses the provided key' do
|
|
|
|
expected = {
|
2022-05-03 16:02:30 +05:30
|
|
|
key: a_string_matching(/^a-key-(?>protected|non_protected)$/),
|
2021-09-30 23:02:18 +05:30
|
|
|
paths: ['logs/', 'binaries/'],
|
|
|
|
policy: 'pull-push',
|
|
|
|
untracked: true,
|
2023-03-17 16:20:25 +05:30
|
|
|
unprotect: false,
|
2021-09-30 23:02:18 +05:30
|
|
|
when: 'on_success'
|
2019-12-26 22:10:19 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(job.cache).to match(a_collection_including(expected))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with cache:key:files' do
|
|
|
|
let(:config) do
|
|
|
|
<<~EOY
|
|
|
|
job:
|
|
|
|
script:
|
|
|
|
- ls
|
|
|
|
cache:
|
|
|
|
paths:
|
|
|
|
- logs/
|
|
|
|
key:
|
|
|
|
files:
|
|
|
|
- file.lock
|
|
|
|
- missing-file.lock
|
|
|
|
EOY
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when file.lock exists' do
|
|
|
|
let(:files) { { 'file.lock' => '' } }
|
|
|
|
|
|
|
|
it 'builds a cache key' do
|
|
|
|
expected = {
|
2021-09-30 23:02:18 +05:30
|
|
|
key: /[a-f0-9]{40}/,
|
|
|
|
paths: ['logs/'],
|
|
|
|
policy: 'pull-push',
|
2023-03-17 16:20:25 +05:30
|
|
|
when: 'on_success',
|
|
|
|
unprotect: false
|
2019-12-26 22:10:19 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(job.cache).to match(a_collection_including(expected))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when file.lock does not exist' do
|
|
|
|
let(:files) { { 'some-file' => '' } }
|
|
|
|
|
|
|
|
it 'uses default cache key' do
|
|
|
|
expected = {
|
2021-09-30 23:02:18 +05:30
|
|
|
key: /default/,
|
|
|
|
paths: ['logs/'],
|
|
|
|
policy: 'pull-push',
|
2023-03-17 16:20:25 +05:30
|
|
|
when: 'on_success',
|
|
|
|
unprotect: false
|
2019-12-26 22:10:19 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(job.cache).to match(a_collection_including(expected))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with cache:key:files and prefix' do
|
|
|
|
let(:config) do
|
|
|
|
<<~EOY
|
|
|
|
job:
|
|
|
|
script:
|
|
|
|
- ls
|
|
|
|
cache:
|
|
|
|
paths:
|
|
|
|
- logs/
|
|
|
|
key:
|
|
|
|
files:
|
|
|
|
- file.lock
|
|
|
|
prefix: '$ENV_VAR'
|
|
|
|
EOY
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when file.lock exists' do
|
|
|
|
let(:files) { { 'file.lock' => '' } }
|
|
|
|
|
|
|
|
it 'builds a cache key' do
|
|
|
|
expected = {
|
2021-09-30 23:02:18 +05:30
|
|
|
key: /\$ENV_VAR-[a-f0-9]{40}/,
|
|
|
|
paths: ['logs/'],
|
|
|
|
policy: 'pull-push',
|
2023-03-17 16:20:25 +05:30
|
|
|
when: 'on_success',
|
|
|
|
unprotect: false
|
2019-12-26 22:10:19 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(job.cache).to match(a_collection_including(expected))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when file.lock does not exist' do
|
|
|
|
let(:files) { { 'some-file' => '' } }
|
|
|
|
|
|
|
|
it 'uses default cache key' do
|
|
|
|
expected = {
|
2021-09-30 23:02:18 +05:30
|
|
|
key: /\$ENV_VAR-default/,
|
|
|
|
paths: ['logs/'],
|
|
|
|
policy: 'pull-push',
|
2023-03-17 16:20:25 +05:30
|
|
|
when: 'on_success',
|
|
|
|
unprotect: false
|
2019-12-26 22:10:19 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(job.cache).to match(a_collection_including(expected))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with too many files' do
|
|
|
|
let(:files) { { 'some-file' => '' } }
|
|
|
|
|
|
|
|
let(:config) do
|
|
|
|
<<~EOY
|
|
|
|
job:
|
|
|
|
script:
|
|
|
|
- ls
|
|
|
|
cache:
|
|
|
|
paths: ['logs/', 'binaries/']
|
|
|
|
untracked: true
|
|
|
|
key:
|
|
|
|
files:
|
|
|
|
- file.lock
|
|
|
|
- other-file.lock
|
|
|
|
- extra-file.lock
|
|
|
|
prefix: 'some-prefix'
|
|
|
|
EOY
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'has errors' do
|
|
|
|
expect(pipeline).to be_persisted
|
|
|
|
expect(pipeline.yaml_errors).to eq("jobs:job:cache:key:files config has too many items (maximum is 2)")
|
|
|
|
expect(job).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|