X-Git-Url: https://review.fuel-infra.org/gitweb?a=blobdiff_plain;f=spec%2Fdefines%2Fsource_spec.rb;h=3900158a1612cc48b8995195c40e5dae655515d0;hb=bca85cd945f8511edb0aa2dcf5e549772abea805;hp=06363e608cc7d409f1f7802b22bbb20ae9dc737d;hpb=ea4f615735d5fb6bb6b0fcbd735da76e0bb45c06;p=puppet-modules%2Fpuppetlabs-apt.git diff --git a/spec/defines/source_spec.rb b/spec/defines/source_spec.rb index 06363e6..3900158 100644 --- a/spec/defines/source_spec.rb +++ b/spec/defines/source_spec.rb @@ -11,27 +11,36 @@ describe 'apt::source' do 'my_source' end - context 'mostly defaults' do - let :facts do - { - :lsbdistid => 'Debian', - :lsbdistcodename => 'wheezy', - :osfamily => 'Debian' - } + context 'defaults' do + context 'without location' do + let :facts do + { + :lsbdistid => 'Debian', + :lsbdistcodename => 'wheezy', + :osfamily => 'Debian' + } + end + it do + expect { + is_expected.to compile + }.to raise_error(Puppet::Error, /source entry without specifying a location/) + end end + context 'with location' do + let :facts do + { + :lsbdistid => 'Debian', + :lsbdistcodename => 'wheezy', + :osfamily => 'Debian' + } + end + let(:params) { { :location => 'hello.there', } } - let :params do - { - :include_deb => false, - :include_src => true, + it { is_expected.to contain_apt__setting('list-my_source').with({ + :ensure => 'present', + }).without_content(/# my_source\ndeb-src hello.there wheezy main\n/) } end - - it { is_expected.to contain_apt__setting('list-my_source').with({ - :ensure => 'present', - }).with_content(/# my_source\ndeb-src wheezy main\n/) - - } end describe 'no defaults' do @@ -42,6 +51,31 @@ describe 'apt::source' do :osfamily => 'Debian' } end + + context 'with complex pin' do + let :params do + { + :location => 'hello.there', + :pin => { 'release' => 'wishwash', + 'explanation' => 'wishwash', + 'priority' => 1001, }, + } + end + + it { is_expected.to contain_apt__setting('list-my_source').with({ + :ensure => 'present', + }).with_content(/hello.there wheezy main\n/) + } + + it { is_expected.to contain_apt__pin('my_source').that_comes_before('Apt::Setting[list-my_source]').with({ + :ensure => 'present', + :priority => 1001, + :explanation => 'wishwash', + :release => 'wishwash', + }) + } + end + context 'with simple key' do let :params do { @@ -49,11 +83,10 @@ describe 'apt::source' do :location => 'http://debian.mirror.iweb.ca/debian/', :release => 'sid', :repos => 'testing', - :include_src => false, :key => GPG_KEY_ID, :pin => '10', :architecture => 'x86_64', - :trusted_source => true, + :allow_unsigned => true, } end @@ -71,7 +104,7 @@ describe 'apt::source' do it { is_expected.to contain_apt__key("Add key: #{GPG_KEY_ID} from Apt::Source my_source").that_comes_before('Apt::Setting[list-my_source]').with({ :ensure => 'present', - :key => GPG_KEY_ID, + :id => GPG_KEY_ID, }) } end @@ -83,13 +116,12 @@ describe 'apt::source' do :location => 'http://debian.mirror.iweb.ca/debian/', :release => 'sid', :repos => 'testing', - :include_src => false, :key => { 'id' => GPG_KEY_ID, 'server' => 'pgp.mit.edu', 'content' => 'GPG key content', 'source' => 'http://apt.puppetlabs.com/pubkey.gpg',}, :pin => '10', :architecture => 'x86_64', - :trusted_source => true, + :allow_unsigned => true, } end @@ -107,7 +139,7 @@ describe 'apt::source' do it { is_expected.to contain_apt__key("Add key: #{GPG_KEY_ID} from Apt::Source my_source").that_comes_before('Apt::Setting[list-my_source]').with({ :ensure => 'present', - :key => GPG_KEY_ID, + :id => GPG_KEY_ID, :server => 'pgp.mit.edu', :content => 'GPG key content', :source => 'http://apt.puppetlabs.com/pubkey.gpg', @@ -122,11 +154,10 @@ describe 'apt::source' do :location => 'http://debian.mirror.iweb.ca/debian/', :release => 'sid', :repos => 'testing', - :include_src => false, :key => GPG_KEY_ID, :pin => '10', :architecture => 'x86_64', - :trusted_source => true, + :allow_unsigned => true, } end @@ -150,7 +181,7 @@ describe 'apt::source' do end end - context 'trusted_source true' do + context 'allow_unsigned true' do let :facts do { :lsbdistid => 'Debian', @@ -160,14 +191,14 @@ describe 'apt::source' do end let :params do { - :include_src => false, - :trusted_source => true, + :location => 'hello.there', + :allow_unsigned => true, } end it { is_expected.to contain_apt__setting('list-my_source').with({ :ensure => 'present', - }).with_content(/# my_source\ndeb \[trusted=yes\] wheezy main\n/) + }).with_content(/# my_source\ndeb \[trusted=yes\] hello.there wheezy main\n/) } end @@ -181,15 +212,15 @@ describe 'apt::source' do end let :params do { - :include_deb => false, - :include_src => true, + :location => 'hello.there', + :include => {'deb' => false, 'src' => true,}, :architecture => 'x86_64', } end it { is_expected.to contain_apt__setting('list-my_source').with({ :ensure => 'present', - }).with_content(/# my_source\ndeb-src \[arch=x86_64 \] wheezy main\n/) + }).with_content(/# my_source\ndeb-src \[arch=x86_64 \] hello.there wheezy main\n/) } end @@ -221,6 +252,7 @@ describe 'apt::source' do :osfamily => 'Debian' } end + let(:params) { { :location => 'hello.there', } } it do expect { @@ -228,5 +260,28 @@ describe 'apt::source' do }.to raise_error(Puppet::Error, /lsbdistcodename fact not available: release parameter required/) end end + + context 'invalid pin' do + let :facts do + { + :lsbdistid => 'Debian', + :lsbdistcodename => 'wheezy', + :osfamily => 'Debian' + } + end + let :params do + { + :location => 'hello.there', + :pin => true, + } + end + + it do + expect { + is_expected.to compile + }.to raise_error(Puppet::Error, /invalid value for pin/) + end + end + end end