class apt::backports (
- Optional[Variant[String, Stdlib::Compat::String]] $location = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $release = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $repos = undef,
- Optional[Variant[String, Stdlib::Compat::String, Hash, Stdlib::Compat::Hash]] $key = undef,
- Optional[Variant[Integer, Stdlib::Compat::Integer, String, Stdlib::Compat::String, Hash, Stdlib::Compat::Hash]] $pin = 200,
+ Optional[String] $location = undef,
+ Optional[String] $release = undef,
+ Optional[String] $repos = undef,
+ Optional[Variant[String, Hash]] $key = undef,
+ Optional[Variant[Integer, String, Hash]] $pin = 200,
){
if $location {
- validate_legacy(String, 'validate_string', $location)
$_location = $location
}
if $release {
- validate_legacy(String, 'validate_string', $release)
$_release = $release
}
if $repos {
- validate_legacy(String, 'validate_string', $repos)
$_repos = $repos
}
if $key {
- unless is_hash($key) {
- validate_legacy(String, 'validate_string', $key)
- }
$_key = $key
}
if ($facts['lsbdistid'] == 'Debian' or $facts['lsbdistid'] == 'Ubuntu') {
define apt::conf (
- Optional[Variant[String, Stdlib::Compat::String]] $content = undef,
- Enum['present', 'absent'] $ensure = present,
- Variant[String, Stdlib::Compat::String, Integer, Stdlib::Compat::Integer] $priority = 50,
- Optional[Boolean] $notify_update = undef,
+ Optional[String] $content = undef,
+ Enum['present', 'absent'] $ensure = present,
+ Variant[String, Integer] $priority = 50,
+ Optional[Boolean] $notify_update = undef,
) {
unless $ensure == 'absent' {
# Manage APT (Advanced Packaging Tool)
#
class apt (
- Variant[Hash, Stdlib::Compat::Hash] $update_defaults,
- Variant[Hash, Stdlib::Compat::Hash] $purge_defaults,
- Variant[Hash, Stdlib::Compat::Hash] $proxy_defaults,
- Variant[Hash, Stdlib::Compat::Hash] $include_defaults,
- Variant[String, Stdlib::Compat::String] $provider,
- Variant[String, Stdlib::Compat::String] $keyserver,
- Optional[Variant[String, Stdlib::Compat::String]] $ppa_options,
- Optional[Variant[String, Stdlib::Compat::String]] $ppa_package,
- Optional[Variant[Hash, Stdlib::Compat::Hash]] $backports,
- Variant[Hash, Stdlib::Compat::Hash] $confs = {},
- Variant[Hash, Stdlib::Compat::Hash] $update = {},
- Variant[Hash, Stdlib::Compat::Hash] $purge = {},
- Variant[Hash, Stdlib::Compat::Hash] $proxy = {},
- Variant[Hash, Stdlib::Compat::Hash] $sources = {},
- Variant[Hash, Stdlib::Compat::Hash] $keys = {},
- Variant[Hash, Stdlib::Compat::Hash] $ppas = {},
- Variant[Hash, Stdlib::Compat::Hash] $pins = {},
- Variant[Hash, Stdlib::Compat::Hash] $settings = {},
- Variant[String, Stdlib::Compat::String] $root = '/etc/apt',
- Variant[String, Stdlib::Compat::String] $sources_list = "${root}/sources.list",
- Variant[String, Stdlib::Compat::String] $sources_list_d = "${root}/sources.list.d",
- Variant[String, Stdlib::Compat::String] $conf_d = "${root}/apt.conf.d",
- Variant[String, Stdlib::Compat::String] $preferences = "${root}/preferences",
- Variant[String, Stdlib::Compat::String] $preferences_d = "${root}/preferences.d",
- Variant[Hash, Stdlib::Compat::Hash] $config_files = { conf => { path => $conf_d, ext => '' }, pref => { path => $preferences_d, ext => '.pref' }, list => { path => $sources_list_d, ext => '.list' } },
- Variant[Hash, Stdlib::Compat::Hash] $source_key_defaults = { 'server' => $keyserver, 'options' => undef, 'content' => undef, 'source' => undef },
+ Hash $update_defaults,
+ Hash $purge_defaults,
+ Hash $proxy_defaults,
+ Hash $include_defaults,
+ String $provider,
+ String $keyserver,
+ Optional[String] $ppa_options,
+ Optional[String] $ppa_package,
+ Optional[Hash] $backports,
+ Hash $confs = {},
+ Hash $update = {},
+ Hash $purge = {},
+ Hash $proxy = {},
+ Hash $sources = {},
+ Hash $keys = {},
+ Hash $ppas = {},
+ Hash $pins = {},
+ Hash $settings = {},
+ String $root = '/etc/apt',
+ String $sources_list = "${root}/sources.list",
+ String $sources_list_d = "${root}/sources.list.d",
+ String $conf_d = "${root}/apt.conf.d",
+ String $preferences = "${root}/preferences",
+ String $preferences_d = "${root}/preferences.d",
+ Hash $config_files = { conf => { path => $conf_d, ext => '' }, pref => { path => $preferences_d, ext => '.pref' }, list => { path => $sources_list_d, ext => '.list' } },
+ Hash $source_key_defaults = { 'server' => $keyserver, 'options' => undef, 'content' => undef, 'source' => undef },
) {
if $facts['osfamily'] != 'Debian' {
}
$frequency_options = ['always','daily','weekly','reluctantly']
- validate_legacy(Hash, 'validate_hash', $update)
+
if $update['frequency'] {
validate_re($update['frequency'], $frequency_options)
}
if $update['timeout'] {
- unless is_integer($update['timeout']) {
- fail('timeout value for update must be an integer')
- }
+ assert_type(Integer, $update['timeout'])
}
if $update['tries'] {
- unless is_integer($update['tries']) {
- fail('tries value for update must be an integer')
- }
+ assert_type(Integer, $update['tries'])
}
$_update = merge($::apt::update_defaults, $update)
include ::apt::update
- validate_legacy(Hash, 'validate_hash', $purge)
if $purge['sources.list'] {
- validate_legacy(Boolean, 'validate_bool', $purge['sources.list'])
+ assert_type(Boolean, $purge['sources.list'])
}
if $purge['sources.list.d'] {
- validate_legacy(Boolean, 'validate_bool', $purge['sources.list.d'])
+ assert_type(Boolean, $purge['sources.list.d'])
}
if $purge['preferences'] {
- validate_legacy(Boolean, 'validate_bool', $purge['preferences'])
+ assert_type(Boolean, $purge['preferences'])
}
if $purge['preferences.d'] {
- validate_legacy(Boolean, 'validate_bool', $purge['preferences.d'])
+ assert_type(Boolean, $purge['preferences.d'])
}
$_purge = merge($::apt::purge_defaults, $purge)
- validate_hash($proxy)
if $proxy['ensure'] {
validate_re($proxy['ensure'], ['file', 'present', 'absent'])
}
if $proxy['host'] {
- validate_legacy(String, 'validate_string', $proxy['host'])
+ assert_type(String, $proxy['host'])
}
if $proxy['port'] {
- unless is_integer($proxy['port']) {
- fail('$proxy port must be an integer')
- }
+ assert_type(Integer, $proxy['port'])
}
- if $proxy['https'] {
- validate_legacy(Boolean, 'validate_bool', $proxy['https'])
+ if $proxy['https']{
+ assert_type(Boolean, $proxy['https'])
}
$_proxy = merge($apt::proxy_defaults, $proxy)
- validate_legacy(Hash, 'validate_hash', $confs)
- validate_legacy(Hash, 'validate_hash', $sources)
- validate_legacy(Hash, 'validate_hash', $keys)
- validate_legacy(Hash, 'validate_hash', $settings)
- validate_legacy(Hash, 'validate_hash', $ppas)
- validate_legacy(Hash, 'validate_hash', $pins)
-
$confheadertmp = epp('apt/_conf_header.epp')
$proxytmp = epp('apt/proxy.epp', {'proxies' => $_proxy})
$updatestamptmp = epp('apt/15update-stamp.epp')
# == Define: apt::key
define apt::key (
- Variant[String, Stdlib::Compat::String] $id = $title,
- Enum['present', 'absent'] $ensure = present,
- Optional[Variant[String, Stdlib::Compat::String]] $content = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $source = undef,
- Variant[String, Stdlib::Compat::String] $server = $::apt::keyserver,
- Optional[Variant[String, Stdlib::Compat::String]] $options = undef,
- Optional[Variant[String, Stdlib::Compat::String, Hash, Stdlib::Compat::Hash]] $key = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_content = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_source = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_server = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_options = undef,
+ String $id = $title,
+ Enum['present', 'absent'] $ensure = present,
+ Optional[String] $content = undef,
+ Optional[String] $source = undef,
+ String $server = $::apt::keyserver,
+ Optional[String] $options = undef,
+ Optional[Variant[String, Hash]] $key = undef,
+ Optional[String] $key_content = undef,
+ Optional[String] $key_source = undef,
+ Optional[String] $key_server = undef,
+ Optional[String] $key_options = undef,
) {
if $key != undef {
}
validate_re($_id, ['\A(0x)?[0-9a-fA-F]{8}\Z', '\A(0x)?[0-9a-fA-F]{16}\Z', '\A(0x)?[0-9a-fA-F]{40}\Z'])
- validate_re($ensure, ['\A(absent|present)\Z',])
-
- if $_content {
- validate_legacy(String, 'validate_string', $_content)
- }
if $_source {
validate_re($_source, ['\Ahttps?:\/\/', '\Aftp:\/\/', '\A\/\w+'])
validate_re($_server,['\A((hkp|http|https):\/\/)?([a-z\d])([a-z\d-]{0,61}\.)+[a-z\d]+(:\d{2,5})?$'])
}
- if $_options {
- validate_legacy(String, 'validate_string', $_options)
- }
-
case $ensure {
present: {
if defined(Anchor["apt_key ${_id} absent"]){
# pin a release in apt, useful for unstable repositories
define apt::pin(
- Optional[Enum['file', 'present', 'absent']] $ensure = present,
- Optional[Variant[String, Stdlib::Compat::String]] $explanation = undef,
- Variant[Integer, Stdlib::Compat::Integer] $order = 50,
- Variant[String, Stdlib::Compat::String, Stdlib::Compat::Array, Array] $packages = '*',
- Variant[Numeric, String, Stdlib::Compat::String] $priority = 0,
- Optional[Variant[String, Stdlib::Compat::String]] $release = '', # a=
- Optional[Variant[String, Stdlib::Compat::String]] $origin = '',
- Optional[Variant[String, Stdlib::Compat::String]] $version = '',
- Optional[Variant[String, Stdlib::Compat::String]] $codename = '', # n=
- Optional[Variant[String, Stdlib::Compat::String]] $release_version = '', # v=
- Optional[Variant[String, Stdlib::Compat::String]] $component = '', # c=
- Optional[Variant[String, Stdlib::Compat::String]] $originator = '', # o=
- Optional[Variant[String, Stdlib::Compat::String]] $label = '', # l=
+ Optional[Enum['file', 'present', 'absent']] $ensure = present,
+ Optional[String] $explanation = undef,
+ Variant[Integer] $order = 50,
+ Variant[String, Array] $packages = '*',
+ Variant[Numeric, String] $priority = 0,
+ Optional[String] $release = '', # a=
+ Optional[String] $origin = '',
+ Optional[String] $version = '',
+ Optional[String] $codename = '', # n=
+ Optional[String] $release_version = '', # v=
+ Optional[String] $component = '', # c=
+ Optional[String] $originator = '', # o=
+ Optional[String] $label = '', # l=
) {
if $explanation {
# ppa.pp
define apt::ppa(
- Variant[String, Stdlib::Compat::String] $ensure = 'present',
- Optional[Variant[String, Stdlib::Compat::String]] $options = $::apt::ppa_options,
- Optional[Variant[String, Stdlib::Compat::String]] $release = $facts['lsbdistcodename'],
- Optional[Variant[String, Stdlib::Compat::String]] $package_name = $::apt::ppa_package,
- Boolean $package_manage = false,
+ String $ensure = 'present',
+ Optional[String] $options = $::apt::ppa_options,
+ Optional[String] $release = $facts['lsbdistcodename'],
+ Optional[String] $package_name = $::apt::ppa_package,
+ Boolean $package_manage = false,
) {
unless $release {
fail('lsbdistcodename fact not available: release parameter required')
define apt::setting (
- Variant[String, Stdlib::Compat::String, Integer, Stdlib::Compat::Integer, Array, Stdlib::Compat::Array] $priority = 50,
- Optional[Enum['file', 'present', 'absent']] $ensure = file,
- Optional[Variant[String, Stdlib::Compat::String]] $source = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $content = undef,
- Optional[Boolean] $notify_update = true,
-
+ Variant[String, Integer] $priority = 50,
+ Optional[Enum['file', 'present', 'absent']] $ensure = file,
+ Optional[String] $source = undef,
+ Optional[String] $content = undef,
+ Boolean $notify_update = true,
) {
if $content and $source {
fail('apt::setting needs either of content or source')
}
- if $notify_update {
- validate_legacy(Boolean, 'validate_bool', $notify_update)
- }
-
$title_array = split($title, '-')
$setting_type = $title_array[0]
$base_name = join(delete_at($title_array, 0), '-')
validate_re($priority, '^\d+$', 'apt::setting priority must be an integer or a zero-padded integer')
}
- if $source {
- validate_legacy(String, 'validate_string', $source)
- }
-
- if $content {
- validate_legacy(String, 'validate_string', $content)
- }
-
if ($setting_type == 'list') or ($setting_type == 'pref') {
$_priority = ''
} else {
# source.pp
# add an apt source
define apt::source(
- Optional[Variant[String, Stdlib::Compat::String]] $location = undef,
- Variant[String, Stdlib::Compat::String] $comment = $name,
- Variant[String, Stdlib::Compat::String] $ensure = present,
- Optional[Variant[String, Stdlib::Compat::String]] $release = undef,
- Variant[String, Stdlib::Compat::String] $repos = 'main',
- Optional[Variant[Hash, Stdlib::Compat::Hash]] $include = {},
- Optional[Variant[String, Stdlib::Compat::String, Hash, Stdlib::Compat::Hash]] $key = undef,
- $pin = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $architecture = undef,
- Boolean $allow_unsigned = false,
- Boolean $notify_update = true,
- Optional[Variant[String, Stdlib::Compat::String]] $key_server = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_content = undef,
- Optional[Variant[String, Stdlib::Compat::String]] $key_source = undef,
- Optional[Boolean] $include_src = undef,
- Optional[Boolean] $include_deb = undef,
- $required_packages = undef,
- $trusted_source = undef,
+ Optional[String] $location = undef,
+ String $comment = $name,
+ String $ensure = present,
+ Optional[String] $release = undef,
+ String $repos = 'main',
+ Optional[Variant[Hash]] $include = {},
+ Optional[Variant[String, Hash]] $key = undef,
+ $pin = undef,
+ Optional[String] $architecture = undef,
+ Boolean $allow_unsigned = false,
+ Boolean $notify_update = true,
+ Optional[String] $key_server = undef,
+ Optional[String] $key_content = undef,
+ Optional[String] $key_source = undef,
+ Optional[Boolean] $include_src = undef,
+ Optional[Boolean] $include_deb = undef,
+ $required_packages = undef,
+ $trusted_source = undef,
) {
- validate_legacy(String, 'validate_string', $architecture, $comment, $location, $repos)
- validate_legacy(Boolean, 'validate_bool', $allow_unsigned)
- validate_legacy(Hash, 'validate_hash', $include)
-
# This is needed for compat with 1.8.x
include ::apt
it do
expect {
subject.call
- }.to raise_error(Puppet::Error, /expects a value of type String, Hash,/)
+ }.to raise_error(Puppet::Error, /expects a value of type String or Hash, got Boolean/)
end
end
context 'invalid pin' do
it do
expect {
subject.call
- }.to raise_error(Puppet::Error, /parameter 'pin' expects a value of type Integer, Pattern/)
+ }.to raise_error(Puppet::Error, /expects a value of type Integer, String, or Hash, got Boolean/)
end
end
end
end
let :params do {
- :key => GPG_KEY_ID,
+ :id => GPG_KEY_ID,
} end
it 'contains the apt_key' do
describe 'set a bunch of things!' do
let :params do {
- :key_content => 'GPG key content',
+ :content => 'GPG key content',
:key_source => 'http://apt.puppetlabs.com/pubkey.gpg',
:key_server => 'pgp.mit.edu',
:key_options => 'debug',
:ensure => 'present',
:source => 'http://apt.puppetlabs.com/pubkey.gpg',
:server => 'pgp.mit.edu',
- :content => params[:key_content],
+ :content => params[:content],
:options => 'debug',
})
end
context 'invalid content' do
let :params do {
- :key_content => [],
+ :content => [],
} end
it 'fails' do
expect { subject.call }.to raise_error(/expects a String value/)
describe 'duplication' do
context 'two apt::key resources for same key, different titles' do
let :pre_condition do
- "#{super()}\napt::key { 'duplicate': key => '#{title}', }"
+ "#{super()}\napt::key { 'duplicate': id => '#{title}', }"
end
it 'contains the duplicate apt::key resource' do
is_expected.to contain_apt__key('duplicate').with({
- :key => title,
+ :id => title,
:ensure => 'present',
})
end
context 'two apt::key resources, different ensure' do
let :pre_condition do
- "#{super()}\napt::key { 'duplicate': key => '#{title}', ensure => 'absent', }"
+ "#{super()}\napt::key { 'duplicate': id => '#{title}', ensure => 'absent', }"
end
it 'informs the user of the impossibility' do
expect { subject.call }.to raise_error(/already ensured as absent/)