debian-mirror-gitlab/spec/services/ci/create_pipeline_service/cache_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

185 lines
4.6 KiB
Ruby
Raw Permalink Normal View History

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,
2023-07-09 08:55:56 +05:30
when: 'on_success',
fallback_keys: []
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',
2023-07-09 08:55:56 +05:30
unprotect: false,
fallback_keys: []
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',
2023-07-09 08:55:56 +05:30
unprotect: false,
fallback_keys: []
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',
2023-07-09 08:55:56 +05:30
unprotect: false,
fallback_keys: []
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',
2023-07-09 08:55:56 +05:30
unprotect: false,
fallback_keys: []
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