debian-mirror-gitlab/spec/lib/gitlab/ci/build/cache_spec.rb

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

66 lines
2.3 KiB
Ruby
Raw Normal View History

2021-04-17 20:07:23 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Ci::Build::Cache do
describe '.initialize' do
2021-06-08 01:23:25 +05:30
context 'when the cache is an array' do
it 'instantiates an array of cache seeds' do
cache_config = [{ key: 'key-a' }, { key: 'key-b' }]
pipeline = double(::Ci::Pipeline)
cache_seed_a = double(Gitlab::Ci::Pipeline::Seed::Build::Cache)
cache_seed_b = double(Gitlab::Ci::Pipeline::Seed::Build::Cache)
allow(Gitlab::Ci::Pipeline::Seed::Build::Cache).to receive(:new).and_return(cache_seed_a, cache_seed_b)
cache = described_class.new(cache_config, pipeline)
expect(Gitlab::Ci::Pipeline::Seed::Build::Cache).to have_received(:new).with(pipeline, { key: 'key-a' })
expect(Gitlab::Ci::Pipeline::Seed::Build::Cache).to have_received(:new).with(pipeline, { key: 'key-b' })
expect(cache.instance_variable_get(:@cache)).to eq([cache_seed_a, cache_seed_b])
2021-04-17 20:07:23 +05:30
end
2021-06-08 01:23:25 +05:30
end
2021-04-17 20:07:23 +05:30
2021-06-08 01:23:25 +05:30
context 'when the cache is a hash' do
2021-04-17 20:07:23 +05:30
it 'instantiates a cache seed' do
cache_config = { key: 'key-a' }
pipeline = double(::Ci::Pipeline)
cache_seed = double(Gitlab::Ci::Pipeline::Seed::Build::Cache)
allow(Gitlab::Ci::Pipeline::Seed::Build::Cache).to receive(:new).and_return(cache_seed)
cache = described_class.new(cache_config, pipeline)
expect(Gitlab::Ci::Pipeline::Seed::Build::Cache).to have_received(:new).with(pipeline, cache_config)
2021-06-08 01:23:25 +05:30
expect(cache.instance_variable_get(:@cache)).to eq([cache_seed])
2021-04-17 20:07:23 +05:30
end
end
end
describe '#cache_attributes' do
2021-06-08 01:23:25 +05:30
context 'when there are no caches' do
it 'returns an empty hash' do
cache_config = []
2021-04-17 20:07:23 +05:30
pipeline = double(::Ci::Pipeline)
cache = described_class.new(cache_config, pipeline)
attributes = cache.cache_attributes
2021-06-08 01:23:25 +05:30
expect(attributes).to eq({})
2021-04-17 20:07:23 +05:30
end
end
2021-06-08 01:23:25 +05:30
context 'when there are caches' do
it 'returns the structured attributes for the caches' do
cache_config = [{ key: 'key-a' }, { key: 'key-b' }]
pipeline = double(::Ci::Pipeline)
cache = described_class.new(cache_config, pipeline)
2021-04-17 20:07:23 +05:30
2021-06-08 01:23:25 +05:30
attributes = cache.cache_attributes
2021-04-17 20:07:23 +05:30
2021-06-08 01:23:25 +05:30
expect(attributes).to eq({
options: { cache: cache_config }
})
2021-04-17 20:07:23 +05:30
end
end
end
end