2016-08-24 12:49:21 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe Gitlab::Ci::Config::Entry::Variables do
|
2016-08-24 12:49:21 +05:30
|
|
|
let(:entry) { described_class.new(config) }
|
|
|
|
|
|
|
|
describe 'validations' do
|
|
|
|
context 'when entry config value is correct' do
|
|
|
|
let(:config) do
|
|
|
|
{ 'VARIABLE_1' => 'value 1', 'VARIABLE_2' => 'value 2' }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#value' do
|
|
|
|
it 'returns hash with key value strings' do
|
|
|
|
expect(entry.value).to eq config
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
context 'with numeric keys and values in the config' do
|
|
|
|
let(:config) { { 10 => 20 } }
|
|
|
|
|
|
|
|
it 'converts numeric key and numeric value into strings' do
|
|
|
|
expect(entry.value).to eq('10' => '20')
|
|
|
|
end
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe '#errors' do
|
|
|
|
it 'does not append errors' do
|
|
|
|
expect(entry.errors).to be_empty
|
|
|
|
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
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:config) { [:VAR, 'test'] }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
|
|
|
describe '#errors' do
|
|
|
|
it 'saves errors' do
|
|
|
|
expect(entry.errors)
|
|
|
|
.to include /should be a hash of key value pairs/
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#valid?' do
|
|
|
|
it 'is not valid' do
|
|
|
|
expect(entry).not_to be_valid
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|