X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=spec%2Fdefines%2Fsetting_spec.rb;h=16db75145ab8acc97b1a7c367e326974c4022322;hb=2df4e59aad25864f7d674f598d95628f68dfd4e1;hp=5e88eea16ed90b72a6778f9c8c9b1da60d9eb442;hpb=d261d8f11b85407c149924a8b03b0e681777f65a;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/spec/defines/setting_spec.rb b/spec/defines/setting_spec.rb index 5e88eea..16db751 100644 --- a/spec/defines/setting_spec.rb +++ b/spec/defines/setting_spec.rb @@ -2,128 +2,136 @@ require 'spec_helper' describe 'apt::setting' do let(:pre_condition) { 'class { "apt": }' } - let(:facts) { { :lsbdistid => 'Debian', :osfamily => 'Debian' } } + let :facts do + { + os: { distro: { codename: 'jessie' }, family: 'Debian', name: 'Debian', release: { major: '8', full: '8.0' } }, + lsbdistrelease: '8.0', + lsbdistcodename: 'jessie', + operatingsystem: 'Debian', + osfamily: 'Debian', + lsbdistid: 'Debian', + } + end let(:title) { 'conf-teddybear' } - let(:default_params) { { :content => 'di' } } + let(:default_params) { { content: 'di' } } describe 'when using the defaults' do context 'without source or content' do it do - expect { is_expected.to compile }.to raise_error(Puppet::Error, /needs either of /) + is_expected.to raise_error(Puppet::Error, %r{needs either of }) end end context 'with title=conf-teddybear ' do let(:params) { default_params } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear') } + + it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').that_notifies('Class[Apt::Update]') } end context 'with title=pref-teddybear' do let(:title) { 'pref-teddybear' } let(:params) { default_params } - it { is_expected.to contain_file('/etc/apt/preferences.d/50teddybear') } + + it { is_expected.to contain_file('/etc/apt/preferences.d/teddybear.pref').that_notifies('Class[Apt::Update]') } end context 'with title=list-teddybear' do let(:title) { 'list-teddybear' } let(:params) { default_params } - it { is_expected.to contain_file('/etc/apt/sources.list.d/teddybear.list') } + + it { is_expected.to contain_file('/etc/apt/sources.list.d/teddybear.list').that_notifies('Class[Apt::Update]') } end context 'with source' do - let(:params) { { :source => 'puppet:///la/die/dah' } } + let(:params) { { source: 'puppet:///la/die/dah' } } + it { - is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :ensure => 'file', - :owner => 'root', - :group => 'root', - :mode => '0644', - :source => "#{params[:source]}", - })} + is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').that_notifies('Class[Apt::Update]').with(ensure: 'file', + owner: 'root', + group: 'root', + source: params[:source].to_s) + } end context 'with content' do let(:params) { default_params } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :ensure => 'file', - :owner => 'root', - :group => 'root', - :mode => '0644', - :content => "#{params[:content]}", - })} + + it { + is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').that_notifies('Class[Apt::Update]').with(ensure: 'file', + owner: 'root', + group: 'root', + content: params[:content].to_s) + } end end + describe 'settings requiring settings, MODULES-769' do + let(:pre_condition) do + 'class { "apt": } + apt::setting { "list-teddybear": content => "foo" } + ' + end + let(:facts) do + { + os: { family: 'Debian', name: 'Debian', release: { major: '8', full: '8.0' } }, + lsbdistid: 'Debian', + osfamily: 'Debian', + lsbdistcodename: 'jessie', + } + end + let(:title) { 'conf-teddybear' } + let(:default_params) { { content: 'di' } } + + let(:params) { default_params.merge(require: 'Apt::Setting[list-teddybear]') } + + it { is_expected.to compile.with_all_deps } + end + describe 'when trying to pull one over' do context 'with source and content' do - let(:params) { default_params.merge({ :source => 'la' }) } + let(:params) { default_params.merge(source: 'la') } + it do - expect { is_expected.to compile }.to raise_error(Puppet::Error, /cannot have both /) + is_expected.to raise_error(Puppet::Error, %r{cannot have both }) end end context 'with title=ext-teddybear' do let(:title) { 'ext-teddybear' } let(:params) { default_params } + it do - expect { is_expected.to compile }.to raise_error(Puppet::Error, /must start with /) + is_expected.to raise_error(Puppet::Error, %r{must start with either}) end end context 'with ensure=banana' do - let(:params) { default_params.merge({ :ensure => 'banana' }) } + let(:params) { default_params.merge(ensure: 'banana') } + it do - expect { is_expected.to compile }.to raise_error(Puppet::Error, /"banana" does not /) + is_expected.to raise_error(Puppet::Error, %r{Enum\['absent', 'file', 'present'\]}) end end context 'with priority=1.2' do - let(:params) { default_params.merge({ :priority => 1.2 }) } - it do - expect { is_expected.to compile }.to raise_error(Puppet::Error, /be an integer /) - end + let(:params) { default_params.merge(priority: 1.2) } + + it { is_expected.to compile.and_raise_error(%r{expects a value of type}) } end end describe 'with priority=100' do - let(:params) { default_params.merge({ :priority => 100 }) } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/100teddybear') } - end + let(:params) { default_params.merge(priority: 100) } - describe 'with ensure=absent' do - let(:params) { default_params.merge({ :ensure => 'absent' }) } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :ensure => 'absent', - })} + it { is_expected.to contain_file('/etc/apt/apt.conf.d/100teddybear').that_notifies('Class[Apt::Update]') } end - describe 'with file_perms' do - context "{'owner' => 'roosevelt'}" do - let(:params) { default_params.merge({ :file_perms => {'owner' => 'roosevelt'} }) } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :owner => 'roosevelt', - :group => 'root', - :mode => '0644', - })} - end - - context "'group' => 'roosevelt'}" do - let(:params) { default_params.merge({ :file_perms => {'group' => 'roosevelt'} }) } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :owner => 'root', - :group => 'roosevelt', - :mode => '0644', - })} - end + describe 'with ensure=absent' do + let(:params) { default_params.merge(ensure: 'absent') } - context "'owner' => 'roosevelt'}" do - let(:params) { default_params.merge({ :file_perms => {'mode' => '0600'} }) } - it { is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').with({ - :owner => 'root', - :group => 'root', - :mode => '0600', - })} - end + it { + is_expected.to contain_file('/etc/apt/apt.conf.d/50teddybear').that_notifies('Class[Apt::Update]').with(ensure: 'absent') + } end end