require 'spec_helper' describe 'openstacklib::policy::base' do shared_examples 'openstacklib::policy::base' do context 'with some basic parameters' do let :title do 'nova-contest_is_admin' end let :params do { :file_path => '/etc/nova/policy.json', :key => 'context_is_admin or owner', :value => 'foo:bar', :file_mode => '0644', :file_user => 'foo', :file_group => 'bar' } end it { should contain_file('/etc/nova/policy.json').with( :mode => '0644', :owner => 'foo', :group => 'bar' )} it { should contain_augeas('/etc/nova/policy.json-context_is_admin or owner-foo:bar').with( :lens => 'Json.lns', :incl => '/etc/nova/policy.json', :changes => 'set dict/entry[*][.="context_is_admin or owner"]/string "foo:bar"', )} it { should contain_augeas('/etc/nova/policy.json-context_is_admin or owner-foo:bar-add').with( :lens => 'Json.lns', :incl => '/etc/nova/policy.json', :changes => [ 'set dict/entry[last()+1] "context_is_admin or owner"', 'set dict/entry[last()]/string "foo:bar"' ], :onlyif => 'match dict/entry[*][.="context_is_admin or owner"] size == 0' )} end end on_supported_os({ :supported_os => OSDefaults.get_supported_os }).each do |os,facts| context "on #{os}" do let (:facts) do facts.merge!(OSDefaults.get_facts()) end it_behaves_like 'openstacklib::policy::base' end end end