2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe Gitlab::Ci::Config::Entry::Commands do
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:entry) { described_class.new(config) }
|
|
|
|
|
|
|
|
context 'when entry config value is an array' do
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:config) { %w(ls pwd) }
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
describe '#value' do
|
|
|
|
it 'returns array of strings' do
|
|
|
|
expect(entry.value).to eq config
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#errors' do
|
|
|
|
it 'does not append errors' do
|
|
|
|
expect(entry.errors).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when entry config value is a string' do
|
|
|
|
let(:config) { 'ls' }
|
|
|
|
|
|
|
|
describe '#value' do
|
|
|
|
it 'returns array with single element' do
|
|
|
|
expect(entry.value).to eq ['ls']
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#valid?' do
|
|
|
|
it 'is valid' do
|
|
|
|
expect(entry).to be_valid
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when entry value is not valid' do
|
|
|
|
let(:config) { 1 }
|
|
|
|
|
|
|
|
describe '#errors' do
|
|
|
|
it 'saves errors' do
|
|
|
|
expect(entry.errors)
|
2018-11-18 11:00:15 +05:30
|
|
|
.to include 'commands config should be an array of strings or a string'
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|