Commit c9451120 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Add Gitaly integration tests for only: changes feature

parent b772e7f4
...@@ -3,73 +3,105 @@ require 'spec_helper' ...@@ -3,73 +3,105 @@ require 'spec_helper'
describe Gitlab::Ci::Build::Policy::Changes do describe Gitlab::Ci::Build::Policy::Changes do
set(:project) { create(:project) } set(:project) { create(:project) }
let(:pipeline) do describe '#satisfied_by?' do
build(:ci_empty_pipeline, project: project, describe 'paths matching matching' do
ref: 'master', let(:pipeline) do
source: :push, build(:ci_empty_pipeline, project: project,
sha: '1234abcd', ref: 'master',
before_sha: '0123aabb') source: :push,
end sha: '1234abcd',
before_sha: '0123aabb')
end
let(:ci_build) do let(:ci_build) do
build(:ci_build, pipeline: pipeline, project: project, ref: 'master') build(:ci_build, pipeline: pipeline, project: project, ref: 'master')
end end
let(:seed) { double('build seed', to_resource: ci_build) } let(:seed) { double('build seed', to_resource: ci_build) }
before do before do
allow(pipeline).to receive(:modified_paths) do allow(pipeline).to receive(:modified_paths) do
%w[some/modified/ruby/file.rb some/other_file.txt some/.dir/file] %w[some/modified/ruby/file.rb some/other_file.txt some/.dir/file]
end end
end end
describe '#satisfied_by?' do it 'is satisfied by matching literal path' do
it 'is satisfied by matching literal path' do policy = described_class.new(%w[some/other_file.txt])
policy = described_class.new(%w[some/other_file.txt])
expect(policy).to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end end
it 'is satisfied by matching simple pattern' do it 'is satisfied by matching simple pattern' do
policy = described_class.new(%w[some/*.txt]) policy = described_class.new(%w[some/*.txt])
expect(policy).to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end end
it 'is satisfied by matching recusive pattern' do it 'is satisfied by matching recusive pattern' do
policy = described_class.new(%w[some/**/*.rb]) policy = described_class.new(%w[some/**/*.rb])
expect(policy).to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end end
it 'is satisfied by matching a pattern with a dot' do it 'is satisfied by matching a pattern with a dot' do
policy = described_class.new(%w[some/*/file]) policy = described_class.new(%w[some/*/file])
expect(policy).to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end end
it 'is not satisfied when pattern does not match path' do it 'is not satisfied when pattern does not match path' do
policy = described_class.new(%w[some/*.rb]) policy = described_class.new(%w[some/*.rb])
expect(policy).not_to be_satisfied_by(pipeline, seed) expect(policy).not_to be_satisfied_by(pipeline, seed)
end end
it 'is not satisfied when pattern does not match' do
policy = described_class.new(%w[invalid/*.md])
expect(policy).not_to be_satisfied_by(pipeline, seed)
end
context 'when pipelines does not run for a branch update' do
before do
pipeline.before_sha = Gitlab::Git::BLANK_SHA
end
it 'is not satisfied when pattern does not match' do it 'is always satisfied' do
policy = described_class.new(%w[invalid/*.md]) policy = described_class.new(%w[invalid/*])
expect(policy).not_to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end
end
end end
context 'when pipelines does not run for a branch update' do describe 'gitaly integration' do
before do set(:project) { create(:project, :repository) }
pipeline.before_sha = Gitlab::Git::BLANK_SHA
let(:pipeline) do
create(:ci_empty_pipeline, project: project,
ref: 'master',
source: :push,
sha: '498214d',
before_sha: '281d3a7')
end
let(:build) do
create(:ci_build, pipeline: pipeline, project: project, ref: 'master')
end end
it 'is always satisfied' do let(:seed) { double('build seed', to_resource: build) }
policy = described_class.new(%w[invalid/*])
it 'is satisfied by changes introduced by a push' do
policy = described_class.new(['with space/*.md'])
expect(policy).to be_satisfied_by(pipeline, seed) expect(policy).to be_satisfied_by(pipeline, seed)
end end
it 'is not satisfied by changes that are not in the push' do
policy = described_class.new(%w[files/js/commit.js])
expect(policy).not_to be_satisfied_by(pipeline, seed)
end
end end
end end
end end
...@@ -1354,7 +1354,7 @@ module Gitlab ...@@ -1354,7 +1354,7 @@ module Gitlab
end.to raise_error(Gitlab::Ci::YamlProcessor::ValidationError, "jobs:rspec dependencies should be an array of strings") end.to raise_error(Gitlab::Ci::YamlProcessor::ValidationError, "jobs:rspec dependencies should be an array of strings")
end end
it 'returns errors if pipeline variables expression is invalid' do it 'returns errors if pipeline variables expression policy is invalid' do
config = YAML.dump({ rspec: { script: 'test', only: { variables: ['== null'] } } }) config = YAML.dump({ rspec: { script: 'test', only: { variables: ['== null'] } } })
expect { Gitlab::Ci::YamlProcessor.new(config) } expect { Gitlab::Ci::YamlProcessor.new(config) }
...@@ -1362,6 +1362,14 @@ module Gitlab ...@@ -1362,6 +1362,14 @@ module Gitlab
'jobs:rspec:only variables invalid expression syntax') 'jobs:rspec:only variables invalid expression syntax')
end end
it 'returns errors if pipeline changes policy is invalid' do
config = YAML.dump({ rspec: { script: 'test', only: { changes: [1] } } })
expect { Gitlab::Ci::YamlProcessor.new(config) }
.to raise_error(Gitlab::Ci::YamlProcessor::ValidationError,
'jobs:rspec:only changes should be an array of strings')
end
it 'returns errors if extended hash configuration is invalid' do it 'returns errors if extended hash configuration is invalid' do
config = YAML.dump({ rspec: { extends: 'something', script: 'test' } }) config = YAML.dump({ rspec: { extends: 'something', script: 'test' } })
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment