diff --git a/README.md b/README.md index 4220775b99..8c3819b262 100644 --- a/README.md +++ b/README.md @@ -291,6 +291,8 @@ Specifies a custom Apt configuration file. * `priority`: *Optional.* Determines the order in which Apt processes the configuration file. Files with lower priority numbers are loaded first. Valid options: a string containing an integer. Default: '50'. +* `notify_update`: *Optional.* Specifies whether to trigger an `apt-get update` run. Valid options: 'true' and 'false'. Default: 'true'. + #### Define: `apt::key` Manages the GPG keys that Apt uses to authenticate packages. @@ -323,7 +325,7 @@ The `apt::key` define makes use of the `apt_key` type, but includes extra functi #### Define: `apt::pin` -Manages Apt pins. +Manages Apt pins. Does not trigger an `apt-get update` run. **Note:** For context on these parameters, we recommend reading the man page ['apt_preferences(5)'](http://linux.die.net/man/5/apt_preferences) diff --git a/manifests/conf.pp b/manifests/conf.pp index c0cd55ba9e..97b70a1eeb 100644 --- a/manifests/conf.pp +++ b/manifests/conf.pp @@ -1,7 +1,8 @@ define apt::conf ( - $content = undef, - $ensure = present, - $priority = '50', + $content = undef, + $ensure = present, + $priority = '50', + $notify_update = undef, ) { unless $ensure == 'absent' { @@ -11,8 +12,9 @@ } apt::setting { "conf-${name}": - ensure => $ensure, - priority => $priority, - content => template('apt/_conf_header.erb', 'apt/conf.erb'), + ensure => $ensure, + priority => $priority, + content => template('apt/_conf_header.erb', 'apt/conf.erb'), + notify_update => $notify_update, } } diff --git a/manifests/pin.pp b/manifests/pin.pp index bcccf28b7c..cc896896d7 100644 --- a/manifests/pin.pp +++ b/manifests/pin.pp @@ -72,8 +72,9 @@ $file_name = regsubst($title, '[^0-9a-z\-_\.]', '_', 'IG') apt::setting { "pref-${file_name}": - ensure => $ensure, - priority => $order, - content => template('apt/_header.erb', 'apt/pin.pref.erb'), + ensure => $ensure, + priority => $order, + content => template('apt/_header.erb', 'apt/pin.pref.erb'), + notify_update => false, } } diff --git a/spec/defines/conf_spec.rb b/spec/defines/conf_spec.rb index f0192d61c4..c74bf1aca3 100644 --- a/spec/defines/conf_spec.rb +++ b/spec/defines/conf_spec.rb @@ -9,12 +9,15 @@ end describe "when creating an apt preference" do - let :params do + let :default_params do { :priority => '00', :content => "Apt::Install-Recommends 0;\nApt::AutoRemove::InstallRecommends 1;\n" } end + let :params do + default_params + end let :filename do "/etc/apt/apt.conf.d/00norecommends" @@ -28,6 +31,22 @@ 'mode' => '0644', }) } + + context "with notify_update = true (default)" do + let :params do + default_params + end + it { is_expected.to contain_apt__setting("conf-#{title}").with_notify_update(true) } + end + + context "with notify_update = false" do + let :params do + default_params.merge({ + :notify_update => false + }) + end + it { is_expected.to contain_apt__setting("conf-#{title}").with_notify_update(false) } + end end describe "when creating a preference without content" do