Commit 5e47b9a9 authored by allison.browne's avatar allison.browne

Combine InlineHash specs into fewer examples

parent 5335b855
...@@ -6,93 +6,64 @@ describe Gitlab::Utils::InlineHash do ...@@ -6,93 +6,64 @@ describe Gitlab::Utils::InlineHash do
describe '.merge_keys' do describe '.merge_keys' do
subject { described_class.merge_keys(source) } subject { described_class.merge_keys(source) }
context 'with string keys' do let(:source) do
let(:source) do {
{ nested_param: {
nested_param: { key: :Value
key: 'Value' },
}, 'root_param' => 'Root',
'root_param' => 'Root', unnested_symbol_key: :unnested_symbol_value,
'very' => { 12 => 22,
'deep' => { 'very' => {
'nested' => { 'deep' => {
'param' => 'Deep nested value' 'nested' => {
} 'param' => 'Deep nested value'
} }
} }
} }
end }
end
it 'transforms a nested hash into a one-level hash' do
is_expected.to eq(
'nested_param.key' => 'Value',
'root_param' => 'Root',
'very.deep.nested.param' => 'Deep nested value'
)
end
it 'retains key insertion order' do
expect(subject.keys)
.to eq(%w(nested_param.key root_param very.deep.nested.param))
end
context 'with a custom connector' do
subject { described_class.merge_keys(source, connector: '::') }
it 'uses the connector to merge keys' do
is_expected.to eq(
'nested_param::key' => 'Value',
'root_param' => 'Root',
'very::deep::nested::param' => 'Deep nested value'
)
end
end
context 'with a starter prefix' do it 'transforms a nested hash into a one-level hash' do
subject { described_class.merge_keys(source, prefix: 'options') } is_expected.to eq(
'nested_param.key' => :Value,
'root_param' => 'Root',
:unnested_symbol_key => :unnested_symbol_value,
12 => 22,
'very.deep.nested.param' => 'Deep nested value'
)
end
it 'prefixes all the keys' do it 'retains key insertion order' do
is_expected.to eq( expect(subject.keys)
'options.nested_param.key' => 'Value', .to eq(['nested_param.key', 'root_param', :unnested_symbol_key, 12, 'very.deep.nested.param'])
'options.root_param' => 'Root',
'options.very.deep.nested.param' => 'Deep nested value'
)
end
end
end end
context 'with un-nested symbol or numeric keys' do context 'with a custom connector' do
let(:unested_symbol_key_source) do subject { described_class.merge_keys(source, connector: '::') }
{
unnested_symbol_key: :unnested_symbol_value, it 'uses the connector to merge keys' do
is_expected.to eq(
'nested_param::key' => :Value,
'root_param' => 'Root',
:unnested_symbol_key => :unnested_symbol_value,
12 => 22, 12 => 22,
nested_symbol_key: { 'very::deep::nested::param' => 'Deep nested value'
nested_symbol_key_2: :nested_symbol_value )
}
}
end end
end
context 'without prefix' do context 'with a starter prefix' do
subject { described_class.merge_keys(unested_symbol_key_source) } subject { described_class.merge_keys(source, prefix: 'options') }
it 'converts only nested keys to inline strings' do
is_expected.to eq(
:unnested_symbol_key => :unnested_symbol_value,
12 => 22,
'nested_symbol_key.nested_symbol_key_2' => :nested_symbol_value
)
end
end
context 'with prefix' do it 'prefixes all the keys' do
subject { described_class.merge_keys(unested_symbol_key_source, prefix: 'options') } is_expected.to eq(
it 'converts prefixed keys to inline strings' do 'options.nested_param.key' => :Value,
is_expected.to eq( 'options.root_param' => 'Root',
'options.unnested_symbol_key' => :unnested_symbol_value, 'options.unnested_symbol_key' => :unnested_symbol_value,
'options.12' => 22, 'options.12' => 22,
'options.nested_symbol_key.nested_symbol_key_2' => :nested_symbol_value 'options.very.deep.nested.param' => 'Deep nested value'
) )
end
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment