2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe Gitlab::Ci::Config::Entry::Artifacts do
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:entry) { described_class.new(config) }
|
|
|
|
|
|
|
|
describe 'validation' do
|
|
|
|
context 'when entry config value is correct' do
|
|
|
|
let(:config) { { paths: %w[public/] } }
|
|
|
|
|
|
|
|
describe '#value' do
|
|
|
|
it 'returns artifacs configuration' do
|
|
|
|
expect(entry.value).to eq config
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#valid?' do
|
|
|
|
it 'is valid' do
|
|
|
|
expect(entry).to be_valid
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when entry value is not correct' do
|
|
|
|
describe '#errors' do
|
|
|
|
context 'when value of attribute is invalid' do
|
|
|
|
let(:config) { { name: 10 } }
|
|
|
|
|
|
|
|
it 'reports error' do
|
|
|
|
expect(entry.errors)
|
|
|
|
.to include 'artifacts name should be a string'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is an unknown key present' do
|
|
|
|
let(:config) { { test: 100 } }
|
|
|
|
|
|
|
|
it 'reports error' do
|
|
|
|
expect(entry.errors)
|
|
|
|
.to include 'artifacts config contains unknown keys: test'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|