require 'spec_helper' describe Gitlab::Ci::Build::Policy::Refs do describe '#satisfied_by?' do context 'when matching ref' do let(:pipeline) { build_stubbed(:ci_pipeline, ref: 'master') } it 'is satisfied when pipeline branch matches' do expect(described_class.new(%w[master deploy])) .to be_satisfied_by(pipeline) end it 'is not satisfied when pipeline branch does not match' do expect(described_class.new(%w[feature fix])) .not_to be_satisfied_by(pipeline) end end context 'when maching tags' do context 'when pipeline runs for a tag' do let(:pipeline) do build_stubbed(:ci_pipeline, ref: 'feature', tag: true) end it 'is satisfied when tags matcher is specified' do expect(described_class.new(%w[master tags])) .to be_satisfied_by(pipeline) end end context 'when pipeline is not created for a tag' do let(:pipeline) do build_stubbed(:ci_pipeline, ref: 'feature', tag: false) end it 'is not satisfied when tag match is specified' do expect(described_class.new(%w[master tags])) .not_to be_satisfied_by(pipeline) end end end context 'when also matching a path' do let(:pipeline) do build_stubbed(:ci_pipeline, ref: 'master') end it 'is satisfied when provided patch matches specified one' do expect(described_class.new(%w[master@some/repository])) .to be_satisfied_by(pipeline, path: 'some/repository') end it 'is not satisfied when path differs' do expect(described_class.new(%w[master@some/fork/repository])) .not_to be_satisfied_by(pipeline, path: 'some/repository') end end context 'when maching a source' do let(:pipeline) { build_stubbed(:ci_pipeline, source: :push) } it 'is satisifed when provided source keyword matches' do expect(described_class.new(%w[pushes])) .to be_satisfied_by(pipeline) end it 'is not satisfied when provided source keyword does not match' do expect(described_class.new(%w[triggers])) .not_to be_satisfied_by(pipeline) end end context 'when matching a ref by a regular expression' do let(:pipeline) { build_stubbed(:ci_pipeline, ref: 'docs-something') } it 'is satisfied when regexp matches pipeline ref' do expect(described_class.new(['/docs-.*/'])) .to be_satisfied_by(pipeline) end it 'is not satisfied when regexp does not match pipeline ref' do expect(described_class.new(['/fix-.*/'])) .not_to be_satisfied_by(pipeline) end end end end