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
|
2019-02-13 22:33:31 +05:30
|
|
|
it 'returns artifacts configuration' do
|
2016-09-13 17:45:13 +05:30
|
|
|
expect(entry.value).to eq config
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#valid?' do
|
|
|
|
it 'is valid' do
|
|
|
|
expect(entry).to be_valid
|
|
|
|
end
|
|
|
|
end
|
2018-11-18 11:00:15 +05:30
|
|
|
|
|
|
|
context "when value includes 'reports' keyword" do
|
|
|
|
let(:config) { { paths: %w[public/], reports: { junit: 'junit.xml' } } }
|
|
|
|
|
|
|
|
it 'returns general artifact and report-type artifacts configuration' do
|
|
|
|
expect(entry.value).to eq config
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
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
|
2018-11-18 11:00:15 +05:30
|
|
|
|
|
|
|
context "when 'reports' keyword is not hash" do
|
|
|
|
let(:config) { { paths: %w[public/], reports: 'junit.xml' } }
|
|
|
|
|
|
|
|
it 'reports error' do
|
|
|
|
expect(entry.errors)
|
|
|
|
.to include 'artifacts reports should be a hash'
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|