Files
puppet-nova/spec/functions/to_array_of_json_strings_spec.rb
Takashi Kajinami 9b27968a04 Stop accepting encoded JSON string
... to avoid redundant parsing of json content from a given string.

This also allows us to add more strict validation later using Struct
data type.

Change-Id: I2a8bbd266d5e97a06b89c131bbd86e3710a68923
2025-03-17 01:43:38 +09:00

42 lines
1.3 KiB
Ruby

require 'spec_helper'
describe 'to_array_of_json_strings' do
it 'exists' do
is_expected.not_to eq(nil)
end
it 'fails with no arguments' do
is_expected.to run.with_params.and_raise_error(Puppet::ParseError)
end
it 'fails with too many arguments' do
is_expected.to run.with_params('arg1', 'arg2').and_raise_error(Puppet::ParseError)
end
it 'fails with a formatted json string' do
data = '{"valid": "json", "syntax": "here"}'
is_expected.to run.with_params(data).and_raise_error(Puppet::ParseError)
end
it 'fails with a hash' do
data = {:some => "entry"}
is_expected.to run.with_params(data).and_raise_error(Puppet::ParseError)
end
it 'fails unless array does not have hashes' do
data = ['{"valid": "json", "syntax": "here"}']
is_expected.to run.with_params(data).and_raise_error(Puppet::ParseError)
end
it 'fails if array but only some entries are valid' do
data = [{:some => "entry"}, '{"valid": "json", "syntax": "here"}']
is_expected.to run.with_params(data).and_raise_error(Puppet::ParseError)
end
it 'works with an array of hashes' do
data = [{:some => "entry"}, {:with => "data"}]
retval = ['{"some":"entry"}','{"with":"data"}']
is_expected.to run.with_params(data).and_return(retval)
end
end