chef 16.0.257 → 16.0.275
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +30 -16
- data/chef.gemspec +1 -1
- data/lib/chef/knife/environment_compare.rb +1 -1
- data/lib/chef/knife/list.rb +1 -1
- data/lib/chef/knife/supermarket_install.rb +1 -1
- data/lib/chef/knife/yaml_convert.rb +2 -2
- data/lib/chef/provider/execute.rb +1 -1
- data/lib/chef/provider/package/freebsd/base.rb +2 -1
- data/lib/chef/provider/package/homebrew.rb +1 -1
- data/lib/chef/provider/package/macports.rb +0 -2
- data/lib/chef/provider/package/windows.rb +26 -51
- data/lib/chef/provider/user/dscl.rb +1 -1
- data/lib/chef/resource/alternatives.rb +65 -4
- data/lib/chef/resource/apt_package.rb +31 -2
- data/lib/chef/resource/apt_preference.rb +34 -5
- data/lib/chef/resource/apt_repository.rb +22 -15
- data/lib/chef/resource/apt_update.rb +6 -4
- data/lib/chef/resource/archive_file.rb +5 -4
- data/lib/chef/resource/bash.rb +1 -1
- data/lib/chef/resource/batch.rb +1 -1
- data/lib/chef/resource/bff_package.rb +1 -1
- data/lib/chef/resource/breakpoint.rb +1 -1
- data/lib/chef/resource/build_essential.rb +8 -4
- data/lib/chef/resource/cab_package.rb +1 -1
- data/lib/chef/resource/chef_client_cron.rb +12 -9
- data/lib/chef/resource/chef_client_scheduled_task.rb +9 -6
- data/lib/chef/resource/chef_client_systemd_timer.rb +10 -7
- data/lib/chef/resource/chef_gem.rb +6 -2
- data/lib/chef/resource/chef_handler.rb +1 -1
- data/lib/chef/resource/chef_sleep.rb +7 -4
- data/lib/chef/resource/chef_vault_secret.rb +3 -3
- data/lib/chef/resource/chocolatey_config.rb +5 -3
- data/lib/chef/resource/chocolatey_feature.rb +5 -3
- data/lib/chef/resource/chocolatey_package.rb +5 -3
- data/lib/chef/resource/chocolatey_source.rb +5 -3
- data/lib/chef/resource/cookbook_file.rb +3 -2
- data/lib/chef/resource/cron.rb +15 -15
- data/lib/chef/resource/cron_access.rb +7 -4
- data/lib/chef/resource/cron_d.rb +37 -23
- data/lib/chef/resource/csh.rb +1 -1
- data/lib/chef/resource/directory.rb +1 -1
- data/lib/chef/resource/dmg_package.rb +18 -15
- data/lib/chef/resource/dnf_package.rb +1 -1
- data/lib/chef/resource/dpkg_package.rb +1 -1
- data/lib/chef/resource/execute.rb +2 -2
- data/lib/chef/resource/file.rb +5 -4
- data/lib/chef/resource/freebsd_package.rb +1 -1
- data/lib/chef/resource/gem_package.rb +6 -6
- data/lib/chef/resource/group.rb +1 -1
- data/lib/chef/resource/homebrew_cask.rb +1 -1
- data/lib/chef/resource/homebrew_package.rb +1 -1
- data/lib/chef/resource/homebrew_tap.rb +1 -1
- data/lib/chef/resource/hostname.rb +4 -4
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/ifconfig.rb +7 -7
- data/lib/chef/resource/ips_package.rb +1 -1
- data/lib/chef/resource/kernel_module.rb +1 -1
- data/lib/chef/resource/ksh.rb +1 -1
- data/lib/chef/resource/launchd.rb +1 -1
- data/lib/chef/resource/link.rb +4 -4
- data/lib/chef/resource/locale.rb +1 -1
- data/lib/chef/resource/log.rb +1 -1
- data/lib/chef/resource/macos_userdefaults.rb +1 -1
- data/lib/chef/resource/macosx_service.rb +1 -1
- data/lib/chef/resource/macports_package.rb +1 -1
- data/lib/chef/resource/mdadm.rb +1 -1
- data/lib/chef/resource/mount.rb +1 -1
- data/lib/chef/resource/msu_package.rb +1 -1
- data/lib/chef/resource/ohai.rb +1 -1
- data/lib/chef/resource/ohai_hint.rb +1 -1
- data/lib/chef/resource/openbsd_package.rb +1 -1
- data/lib/chef/resource/openssl_dhparam.rb +1 -1
- data/lib/chef/resource/openssl_ec_private_key.rb +1 -1
- data/lib/chef/resource/openssl_ec_public_key.rb +1 -1
- data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
- data/lib/chef/resource/openssl_rsa_public_key.rb +1 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +1 -1
- data/lib/chef/resource/openssl_x509_crl.rb +1 -1
- data/lib/chef/resource/openssl_x509_request.rb +1 -1
- data/lib/chef/resource/osx_profile.rb +1 -1
- data/lib/chef/resource/package.rb +1 -1
- data/lib/chef/resource/pacman_package.rb +1 -1
- data/lib/chef/resource/paludis_package.rb +1 -1
- data/lib/chef/resource/perl.rb +1 -1
- data/lib/chef/resource/plist.rb +1 -1
- data/lib/chef/resource/portage_package.rb +1 -1
- data/lib/chef/resource/powershell_package.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +1 -1
- data/lib/chef/resource/powershell_script.rb +1 -1
- data/lib/chef/resource/python.rb +1 -1
- data/lib/chef/resource/reboot.rb +1 -1
- data/lib/chef/resource/registry_key.rb +1 -1
- data/lib/chef/resource/remote_directory.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -2
- data/lib/chef/resource/rhsm_errata.rb +1 -3
- data/lib/chef/resource/rhsm_errata_level.rb +1 -1
- data/lib/chef/resource/rhsm_register.rb +1 -2
- data/lib/chef/resource/rhsm_repo.rb +1 -2
- data/lib/chef/resource/rhsm_subscription.rb +1 -3
- data/lib/chef/resource/route.rb +1 -1
- data/lib/chef/resource/rpm_package.rb +5 -2
- data/lib/chef/resource/ruby.rb +1 -1
- data/lib/chef/resource/ruby_block.rb +1 -4
- data/lib/chef/resource/scm/_scm.rb +4 -3
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/scm/subversion.rb +2 -2
- data/lib/chef/resource/script.rb +1 -1
- data/lib/chef/resource/service.rb +1 -1
- data/lib/chef/resource/smartos_package.rb +1 -1
- data/lib/chef/resource/snap_package.rb +1 -1
- data/lib/chef/resource/solaris_package.rb +1 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
- data/lib/chef/resource/sudo.rb +4 -4
- data/lib/chef/resource/swap_file.rb +2 -2
- data/lib/chef/resource/sysctl.rb +61 -2
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/timezone.rb +1 -1
- data/lib/chef/resource/user.rb +2 -2
- data/lib/chef/resource/user_ulimit.rb +24 -22
- data/lib/chef/resource/windows_ad_join.rb +1 -1
- data/lib/chef/resource/windows_auto_run.rb +2 -2
- data/lib/chef/resource/windows_certificate.rb +1 -1
- data/lib/chef/resource/windows_dfs_folder.rb +1 -1
- data/lib/chef/resource/windows_dfs_namespace.rb +1 -1
- data/lib/chef/resource/windows_dfs_server.rb +1 -1
- data/lib/chef/resource/windows_env.rb +10 -1
- data/lib/chef/resource/windows_feature.rb +57 -2
- data/lib/chef/resource/windows_feature_dism.rb +15 -2
- data/lib/chef/resource/windows_feature_powershell.rb +29 -2
- data/lib/chef/resource/windows_firewall_rule.rb +9 -5
- data/lib/chef/resource/windows_font.rb +10 -1
- data/lib/chef/resource/windows_package.rb +63 -3
- data/lib/chef/resource/windows_pagefile.rb +30 -2
- data/lib/chef/resource/windows_path.rb +18 -1
- data/lib/chef/resource/windows_printer.rb +25 -5
- data/lib/chef/resource/windows_printer_port.rb +29 -1
- data/lib/chef/resource/windows_security_policy.rb +1 -1
- data/lib/chef/resource/windows_service.rb +1 -1
- data/lib/chef/resource/windows_share.rb +21 -1
- data/lib/chef/resource/windows_shortcut.rb +13 -2
- data/lib/chef/resource/windows_task.rb +122 -8
- data/lib/chef/resource/windows_uac.rb +20 -1
- data/lib/chef/resource/windows_workgroup.rb +19 -3
- data/lib/chef/resource/yum_package.rb +88 -6
- data/lib/chef/resource/yum_repository.rb +28 -11
- data/lib/chef/resource/zypper_package.rb +29 -3
- data/lib/chef/resource/zypper_repository.rb +17 -5
- data/lib/chef/resource_inspector.rb +1 -1
- data/lib/chef/scan_access_control.rb +1 -1
- data/lib/chef/version.rb +1 -1
- data/spec/functional/resource/link_spec.rb +3 -3
- data/spec/functional/resource/remote_file_spec.rb +1 -1
- data/spec/integration/knife/raw_spec.rb +4 -4
- data/spec/integration/knife/redirection_spec.rb +2 -2
- data/spec/support/platform_helpers.rb +0 -13
- data/spec/support/shared/functional/http.rb +2 -2
- data/spec/support/shared/unit/mock_shellout.rb +1 -1
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/mixin/shell_out_spec.rb +25 -31
- data/spec/unit/provider/apt_repository_spec.rb +27 -27
- data/spec/unit/provider/zypper_repository_spec.rb +17 -17
- data/spec/unit/provider_resolver_spec.rb +2 -2
- metadata +10 -10
@@ -22,8 +22,27 @@ class Chef
|
|
22
22
|
class WindowsUac < Chef::Resource
|
23
23
|
provides :windows_uac
|
24
24
|
|
25
|
-
description 'The windows_uac resource configures UAC on Windows hosts by setting registry keys at
|
25
|
+
description 'The *windows_uac* resource configures UAC on Windows hosts by setting registry keys at `HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System`'
|
26
26
|
introduced "15.0"
|
27
|
+
examples <<~DOC
|
28
|
+
**Disable UAC prompts for the admin**:
|
29
|
+
|
30
|
+
``` ruby
|
31
|
+
windows_uac 'Disable UAC prompts for the admin' do
|
32
|
+
enable_uac true
|
33
|
+
prompt_on_secure_desktop false
|
34
|
+
consent_behavior_admins :no_prompt
|
35
|
+
end
|
36
|
+
```
|
37
|
+
|
38
|
+
**Disable UAC entirely**:
|
39
|
+
|
40
|
+
``` ruby
|
41
|
+
windows_uac 'Disable UAC entirely' do
|
42
|
+
enable_uac false
|
43
|
+
end
|
44
|
+
```
|
45
|
+
DOC
|
27
46
|
|
28
47
|
# https://docs.microsoft.com/en-us/windows/security/identity-protection/user-account-control/user-account-control-group-policy-and-registry-key-settings#user-account-control-virtualize-file-and-registry-write-failures-to-per-user-locations
|
29
48
|
property :enable_uac, [TrueClass, FalseClass],
|
@@ -26,8 +26,24 @@ class Chef
|
|
26
26
|
|
27
27
|
include Chef::Mixin::PowershellOut
|
28
28
|
|
29
|
-
description "Use the windows_workgroup resource to join or change the workgroup of a Windows host."
|
29
|
+
description "Use the **windows_workgroup** resource to join or change the workgroup of a Windows host."
|
30
30
|
introduced "14.5"
|
31
|
+
examples <<~DOC
|
32
|
+
**Join a workgroup**:
|
33
|
+
|
34
|
+
``` ruby
|
35
|
+
windows_workgroup 'myworkgroup'
|
36
|
+
```
|
37
|
+
|
38
|
+
**Join a workgroup using a specific user**:
|
39
|
+
|
40
|
+
``` ruby
|
41
|
+
windows_workgroup 'myworkgroup' do
|
42
|
+
user 'Administrator'
|
43
|
+
password 'passw0rd'
|
44
|
+
end
|
45
|
+
```
|
46
|
+
DOC
|
31
47
|
|
32
48
|
property :workgroup_name, String,
|
33
49
|
description: "An optional property to set the workgroup name if it differs from the resource block's name.",
|
@@ -36,11 +52,11 @@ class Chef
|
|
36
52
|
name_property: true
|
37
53
|
|
38
54
|
property :user, String,
|
39
|
-
description: "The local administrator user to use to change the workgroup. Required if using the password property.",
|
55
|
+
description: "The local administrator user to use to change the workgroup. Required if using the `password` property.",
|
40
56
|
desired_state: false
|
41
57
|
|
42
58
|
property :password, String,
|
43
|
-
description: "The password for the local administrator user. Required if using the user property.",
|
59
|
+
description: "The password for the local administrator user. Required if using the `user` property.",
|
44
60
|
desired_state: false
|
45
61
|
|
46
62
|
property :reboot, Symbol,
|
@@ -27,11 +27,92 @@ class Chef
|
|
27
27
|
provides :yum_package
|
28
28
|
provides :package, platform_family: "fedora_derived"
|
29
29
|
|
30
|
-
description "Use the yum_package resource to install, upgrade, and remove packages with Yum"\
|
30
|
+
description "Use the **yum_package** resource to install, upgrade, and remove packages with Yum"\
|
31
31
|
" for the Red Hat and CentOS platforms. The yum_package resource is able to resolve"\
|
32
|
-
" provides data for packages much like Yum can do when it is run from the command line."\
|
32
|
+
" `provides` data for packages much like Yum can do when it is run from the command line."\
|
33
33
|
" This allows a variety of options for installing packages, like minimum versions,"\
|
34
34
|
" virtual provides, and library names."
|
35
|
+
examples <<~DOC
|
36
|
+
**Install an exact version**:
|
37
|
+
|
38
|
+
``` ruby
|
39
|
+
yum_package 'netpbm = 10.35.58-8.el8'
|
40
|
+
```
|
41
|
+
|
42
|
+
**Install a minimum version**:
|
43
|
+
|
44
|
+
``` ruby
|
45
|
+
yum_package 'netpbm >= 10.35.58-8.el8'
|
46
|
+
```
|
47
|
+
|
48
|
+
**Install a minimum version using the default action**:
|
49
|
+
|
50
|
+
``` ruby
|
51
|
+
yum_package 'netpbm'
|
52
|
+
```
|
53
|
+
|
54
|
+
**Install a version without worrying about the exact release**:
|
55
|
+
|
56
|
+
``` ruby
|
57
|
+
yum_package 'netpbm-10.35*'
|
58
|
+
```
|
59
|
+
|
60
|
+
|
61
|
+
**To install a package**:
|
62
|
+
|
63
|
+
``` ruby
|
64
|
+
yum_package 'netpbm' do
|
65
|
+
action :install
|
66
|
+
end
|
67
|
+
```
|
68
|
+
|
69
|
+
**To install a partial minimum version**:
|
70
|
+
|
71
|
+
``` ruby
|
72
|
+
yum_package 'netpbm >= 10'
|
73
|
+
```
|
74
|
+
|
75
|
+
**To install a specific architecture**:
|
76
|
+
|
77
|
+
``` ruby
|
78
|
+
yum_package 'netpbm' do
|
79
|
+
arch 'i386'
|
80
|
+
end
|
81
|
+
```
|
82
|
+
|
83
|
+
or:
|
84
|
+
|
85
|
+
``` ruby
|
86
|
+
yum_package 'netpbm.x86_64'
|
87
|
+
```
|
88
|
+
|
89
|
+
**To install a specific version-release**
|
90
|
+
|
91
|
+
``` ruby
|
92
|
+
yum_package 'netpbm' do
|
93
|
+
version '10.35.58-8.el8'
|
94
|
+
end
|
95
|
+
```
|
96
|
+
|
97
|
+
**Handle cookbook_file and yum_package resources in the same recipe**:
|
98
|
+
|
99
|
+
When a **cookbook_file** resource and a **yum_package** resource are
|
100
|
+
both called from within the same recipe, use the `flush_cache` attribute
|
101
|
+
to dump the in-memory Yum cache, and then use the repository immediately
|
102
|
+
to ensure that the correct package is installed:
|
103
|
+
|
104
|
+
``` ruby
|
105
|
+
cookbook_file '/etc/yum.repos.d/custom.repo' do
|
106
|
+
source 'custom'
|
107
|
+
mode '0755'
|
108
|
+
end
|
109
|
+
|
110
|
+
yum_package 'pkg-that-is-only-in-custom-repo' do
|
111
|
+
action :install
|
112
|
+
flush_cache [ :before ]
|
113
|
+
end
|
114
|
+
```
|
115
|
+
DOC
|
35
116
|
|
36
117
|
# XXX: the coercions here are due to the provider promiscuously updating the properties on the
|
37
118
|
# new_resource which causes immutable modification exceptions when passed an immutable node array.
|
@@ -46,7 +127,7 @@ class Chef
|
|
46
127
|
identity: true, coerce: proc { |x| x.is_a?(Array) ? x.to_a : x }
|
47
128
|
|
48
129
|
property :version, [ String, Array ],
|
49
|
-
description: "The version of a package to be installed or upgraded. This property is ignored when using the
|
130
|
+
description: "The version of a package to be installed or upgraded. This property is ignored when using the `:upgrade` action.",
|
50
131
|
coerce: proc { |x| x.is_a?(Array) ? x.to_a : x }
|
51
132
|
|
52
133
|
property :arch, [ String, Array ],
|
@@ -70,12 +151,13 @@ class Chef
|
|
70
151
|
end
|
71
152
|
}
|
72
153
|
|
73
|
-
property :allow_downgrade, [
|
74
|
-
description: "
|
154
|
+
property :allow_downgrade, [ TrueClass, FalseClass ],
|
155
|
+
description: "Allow downgrading a package to satisfy requested version requirements.",
|
75
156
|
default: true,
|
76
157
|
desired_state: false
|
77
158
|
|
78
|
-
property :yum_binary, String
|
159
|
+
property :yum_binary, String,
|
160
|
+
description: "The path to the yum binary."
|
79
161
|
end
|
80
162
|
end
|
81
163
|
end
|
@@ -25,21 +25,38 @@ class Chef
|
|
25
25
|
|
26
26
|
provides(:yum_repository) { true }
|
27
27
|
|
28
|
-
description "Use the yum_repository resource to manage a Yum repository configuration"
|
29
|
-
" file located at /etc/yum.repos.d/repositoryid.repo on the local machine."\
|
30
|
-
" This configuration file specifies which repositories to reference, how to"\
|
31
|
-
" handle cached data, etc."
|
28
|
+
description "Use the **yum_repository** resource to manage a Yum repository configuration file located at `/etc/yum.repos.d/repositoryid.repo` on the local machine. This configuration file specifies which repositories to reference, how to handle cached data, etc."
|
32
29
|
introduced "12.14"
|
30
|
+
examples <<~DOC
|
31
|
+
**Add an internal company repository**:
|
32
|
+
|
33
|
+
```ruby
|
34
|
+
yum_repository 'OurCo' do
|
35
|
+
description 'OurCo yum repository'
|
36
|
+
mirrorlist 'http://artifacts.ourco.org/mirrorlist?repo=ourco-8&arch=$basearch'
|
37
|
+
gpgkey 'http://artifacts.ourco.org/pub/yum/RPM-GPG-KEY-OURCO-8'
|
38
|
+
action :create
|
39
|
+
end
|
40
|
+
```ruby
|
41
|
+
|
42
|
+
**Delete a repository**:
|
43
|
+
|
44
|
+
```ruby
|
45
|
+
yum_repository 'CentOS-Media' do
|
46
|
+
action :delete
|
47
|
+
end
|
48
|
+
```
|
49
|
+
DOC
|
33
50
|
|
34
51
|
# http://linux.die.net/man/5/yum.conf as well as
|
35
52
|
# http://dnf.readthedocs.io/en/latest/conf_ref.html
|
36
53
|
property :baseurl, [String, Array],
|
37
|
-
description: "URL to the directory where the Yum repository's
|
54
|
+
description: "URL to the directory where the Yum repository's `repodata` directory lives. Can be an `http://`, `https://` or a `ftp://` URLs. You can specify multiple URLs in one `baseurl` statement."
|
38
55
|
|
39
56
|
property :clean_headers, [TrueClass, FalseClass],
|
40
57
|
description: "Specifies whether you want to purge the package data files that are downloaded from a Yum repository and held in a cache directory.",
|
41
58
|
deprecated: true,
|
42
|
-
default: false
|
59
|
+
default: false
|
43
60
|
|
44
61
|
property :clean_metadata, [TrueClass, FalseClass],
|
45
62
|
description: "Specifies whether you want to purge all of the packages downloaded from a Yum repository and held in a cache directory.",
|
@@ -64,7 +81,7 @@ class Chef
|
|
64
81
|
description: "List of packages to exclude from updates or installs. This should be a space separated list. Shell globs using wildcards (eg. * and ?) are allowed."
|
65
82
|
|
66
83
|
property :failovermethod, String,
|
67
|
-
description: "Method to determine how to switch to a new server if the current one fails, which can either be
|
84
|
+
description: "Method to determine how to switch to a new server if the current one fails, which can either be `roundrobin` or `priority`. `roundrobin` randomly selects a URL out of the list of URLs to start with and proceeds through each of them as it encounters a failure contacting the host. `priority` starts from the first `baseurl` listed and reads through them sequentially.",
|
68
85
|
equal_to: %w{priority roundrobin}
|
69
86
|
|
70
87
|
property :fastestmirror_enabled, [TrueClass, FalseClass],
|
@@ -81,23 +98,23 @@ class Chef
|
|
81
98
|
description: "Determines how upstream HTTP caches are instructed to handle any HTTP downloads that Yum does. This option can take the following values: all (all HTTP downloads should be cached), packages (only RPM package downloads should be cached, but not repository metadata downloads), or none (no HTTP downloads should be cached)"
|
82
99
|
|
83
100
|
property :include_config, String,
|
84
|
-
description: "An external configuration file using the format
|
101
|
+
description: "An external configuration file using the format `url://to/some/location`."
|
85
102
|
|
86
103
|
property :includepkgs, String,
|
87
104
|
description: "Inverse of exclude property. This is a list of packages you want to use from a repository. If this option lists only one package then that is all Yum will ever see from the repository."
|
88
105
|
|
89
106
|
property :keepalive, [TrueClass, FalseClass],
|
90
|
-
description: "Determines whether or not HTTP/1.1
|
107
|
+
description: "Determines whether or not HTTP/1.1 `keep-alive` should be used with this repository."
|
91
108
|
|
92
109
|
property :make_cache, [TrueClass, FalseClass],
|
93
110
|
description: "Determines whether package files downloaded by Yum stay in cache directories. By using cached data, you can carry out certain operations without a network connection.",
|
94
111
|
default: true
|
95
112
|
|
96
113
|
property :max_retries, [String, Integer],
|
97
|
-
description: "Number of times any attempt to retrieve a file should retry before returning an error. Setting this to
|
114
|
+
description: "Number of times any attempt to retrieve a file should retry before returning an error. Setting this to `0` makes Yum try forever."
|
98
115
|
|
99
116
|
property :metadata_expire, String, regex: [/^\d+$/, /^\d+[mhd]$/, /never/],
|
100
|
-
description: "Time (in seconds) after which the metadata will expire. If the current metadata downloaded is less than the value specified, then Yum will not update the metadata against the repository. If you find that Yum is not downloading information on updates as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a 'd', 'h' or 'm' respectively. The default is six hours to compliment yum-updates running once per hour. It is also possible to use the word
|
117
|
+
description: "Time (in seconds) after which the metadata will expire. If the current metadata downloaded is less than the value specified, then Yum will not update the metadata against the repository. If you find that Yum is not downloading information on updates as often as you would like lower the value of this option. You can also change from the default of using seconds to using days, hours or minutes by appending a 'd', 'h' or 'm' respectively. The default is six hours to compliment yum-updates running once per hour. It is also possible to use the word `never`, meaning that the metadata will never expire. Note: When using a metalink file, the metalink must always be newer than the metadata for the repository due to the validation, so this timeout also applies to the metalink file.",
|
101
118
|
validation_message: "The metadata_expire property must be a numeric value for time in seconds, the string 'never', or a numeric value appended with with 'd', 'h', or 'm'!"
|
102
119
|
|
103
120
|
property :metalink, String,
|
@@ -26,10 +26,36 @@ class Chef
|
|
26
26
|
provides :zypper_package
|
27
27
|
provides :package, platform_family: "suse"
|
28
28
|
|
29
|
-
description "Use the zypper_package resource to install, upgrade, and remove packages with Zypper for the SUSE Enterprise and
|
29
|
+
description "Use the **zypper_package** resource to install, upgrade, and remove packages with Zypper for the SUSE Enterprise and openSUSE platforms."
|
30
|
+
examples <<~DOC
|
31
|
+
**Install a package using package manager:**
|
32
|
+
|
33
|
+
``` ruby
|
34
|
+
zypper_package 'name of package' do
|
35
|
+
action :install
|
36
|
+
end
|
37
|
+
```
|
38
|
+
|
39
|
+
**Install a package using local file:**
|
40
|
+
|
41
|
+
``` ruby
|
42
|
+
zypper_package 'jwhois' do
|
43
|
+
action :install
|
44
|
+
source '/path/to/jwhois.rpm'
|
45
|
+
end
|
46
|
+
```
|
47
|
+
|
48
|
+
**Install without using recommend packages as a dependency:**
|
49
|
+
|
50
|
+
``` ruby
|
51
|
+
package 'apache2' do
|
52
|
+
options '--no-recommends'
|
53
|
+
end
|
54
|
+
```
|
55
|
+
DOC
|
30
56
|
|
31
57
|
property :gpg_check, [ TrueClass, FalseClass ],
|
32
|
-
description: "Verify the package's GPG signature. Can also be controlled site-wide using the
|
58
|
+
description: "Verify the package's GPG signature. Can also be controlled site-wide using the `zypper_check_gpg` config option.",
|
33
59
|
default: lazy { Chef::Config[:zypper_check_gpg] }, default_description: "true"
|
34
60
|
|
35
61
|
property :allow_downgrade, [ TrueClass, FalseClass ],
|
@@ -39,7 +65,7 @@ class Chef
|
|
39
65
|
introduced: "13.6"
|
40
66
|
|
41
67
|
property :global_options, [ String, Array ],
|
42
|
-
description: "One (or more) additional command options that are passed to the command. For example, common zypper directives, such as
|
68
|
+
description: "One (or more) additional command options that are passed to the command. For example, common zypper directives, such as `--no-recommends`. See the [zypper man page](https://en.opensuse.org/SDB:Zypper_manual_(plain)) for the full list.",
|
43
69
|
coerce: proc { |x| x.is_a?(String) ? x.shellsplit : x },
|
44
70
|
introduced: "14.6"
|
45
71
|
end
|
@@ -26,17 +26,29 @@ class Chef
|
|
26
26
|
provides(:zypper_repository) { true }
|
27
27
|
provides(:zypper_repo) { true }
|
28
28
|
|
29
|
-
description "Use the zypper_repository resource to create Zypper package repositories on SUSE Enterprise Linux and openSUSE systems. This resource maintains full compatibility with the zypper_repository resource in the existing zypper cookbook."
|
29
|
+
description "Use the **zypper_repository** resource to create Zypper package repositories on SUSE Enterprise Linux and openSUSE systems. This resource maintains full compatibility with the **zypper_repository** resource in the existing **zypper** cookbook."
|
30
30
|
introduced "13.3"
|
31
|
+
examples <<~DOC
|
32
|
+
**Add the Apache repo on openSUSE Leap 15**:
|
33
|
+
|
34
|
+
``` ruby
|
35
|
+
zypper_repository 'apache' do
|
36
|
+
baseurl 'http://download.opensuse.org/repositories/Apache'
|
37
|
+
path '/openSUSE_Leap_15.0'
|
38
|
+
type 'rpm-md'
|
39
|
+
priority '100'
|
40
|
+
end
|
41
|
+
```
|
42
|
+
DOC
|
31
43
|
|
32
44
|
property :repo_name, String,
|
33
45
|
regex: [%r{^[^/]+$}],
|
34
46
|
description: "An optional property to set the repository name if it differs from the resource block's name.",
|
35
|
-
validation_message: "repo_name property cannot contain a forward slash
|
47
|
+
validation_message: "repo_name property cannot contain a forward slash `/`",
|
36
48
|
name_property: true
|
37
49
|
|
38
50
|
property :description, String,
|
39
|
-
description: "The description of the repository that will be shown by the
|
51
|
+
description: "The description of the repository that will be shown by the `zypper repos` command."
|
40
52
|
|
41
53
|
property :type, String,
|
42
54
|
description: "Specifies the repository type.",
|
@@ -58,7 +70,7 @@ class Chef
|
|
58
70
|
description: "The location of the repository key to be imported."
|
59
71
|
|
60
72
|
property :baseurl, String,
|
61
|
-
description: "The base URL for the Zypper repository, such as
|
73
|
+
description: "The base URL for the Zypper repository, such as `http://download.opensuse.org`."
|
62
74
|
|
63
75
|
property :mirrorlist, String,
|
64
76
|
description: "The URL of the mirror list that will be used."
|
@@ -67,7 +79,7 @@ class Chef
|
|
67
79
|
description: "The relative path from the repository's base URL."
|
68
80
|
|
69
81
|
property :priority, Integer,
|
70
|
-
description: "Determines the priority of the Zypper repository.
|
82
|
+
description: "Determines the priority of the Zypper repository.",
|
71
83
|
default: 99
|
72
84
|
|
73
85
|
property :keeppackages, [TrueClass, FalseClass],
|
@@ -59,7 +59,7 @@ module ResourceInspector
|
|
59
59
|
required: opts[:required] || false,
|
60
60
|
default: opts[:default_description] || get_default(opts[:default]),
|
61
61
|
name_property: opts[:name_property] || false,
|
62
|
-
equal_to: opts[:equal_to]
|
62
|
+
equal_to: Array(opts[:equal_to]).sort.map(&:inspect) }
|
63
63
|
end
|
64
64
|
data
|
65
65
|
end
|
@@ -33,7 +33,7 @@ class Chef
|
|
33
33
|
# Not yet sure if this is the optimal way to solve the problem. But it's
|
34
34
|
# progress towards the end goal.
|
35
35
|
#
|
36
|
-
# TODO: figure out if all this works with
|
36
|
+
# TODO: figure out if all this works with macOS' negative uids
|
37
37
|
# TODO: windows
|
38
38
|
class ScanAccessControl
|
39
39
|
|
data/lib/chef/version.rb
CHANGED
@@ -656,10 +656,10 @@ describe Chef::Resource::Link do
|
|
656
656
|
end
|
657
657
|
context "and the link does not yet exist" do
|
658
658
|
it "links to the target file" do
|
659
|
-
skip("
|
659
|
+
skip("macOS/FreeBSD/AIX/Solaris symlink? and readlink working on hard links to symlinks") if os_x? || freebsd? || aix? || solaris?
|
660
660
|
resource.run_action(:create)
|
661
661
|
expect(File.exists?(target_file)).to be_truthy
|
662
|
-
#
|
662
|
+
# macOS gets angry about this sort of link. Bug in macOS, IMO.
|
663
663
|
expect(symlink?(target_file)).to be_truthy
|
664
664
|
expect(readlink(target_file)).to eq(canonicalize(@other_target))
|
665
665
|
end
|
@@ -675,7 +675,7 @@ describe Chef::Resource::Link do
|
|
675
675
|
end
|
676
676
|
context "and the link does not yet exist" do
|
677
677
|
it "links to the target file" do
|
678
|
-
skip("
|
678
|
+
skip("macOS/FreeBSD/AIX/Solaris fails to create hardlinks to broken symlinks") if os_x? || freebsd? || aix? || solaris?
|
679
679
|
resource.run_action(:create)
|
680
680
|
expect(File.exists?(target_file) || File.symlink?(target_file)).to be_truthy
|
681
681
|
expect(symlink?(target_file)).to be_truthy
|
@@ -214,8 +214,8 @@ describe "knife raw", :workstation do
|
|
214
214
|
end
|
215
215
|
|
216
216
|
context "When a server returns raw json" do
|
217
|
-
def start_tiny_server(server_opts
|
218
|
-
@server = TinyServer::Manager.new(server_opts)
|
217
|
+
def start_tiny_server(**server_opts)
|
218
|
+
@server = TinyServer::Manager.new(**server_opts)
|
219
219
|
@server.start
|
220
220
|
@api = TinyServer::API.instance
|
221
221
|
@api.clear
|
@@ -256,8 +256,8 @@ describe "knife raw", :workstation do
|
|
256
256
|
end
|
257
257
|
|
258
258
|
context "When a server returns text" do
|
259
|
-
def start_tiny_server(server_opts
|
260
|
-
@server = TinyServer::Manager.new(server_opts)
|
259
|
+
def start_tiny_server(**server_opts)
|
260
|
+
@server = TinyServer::Manager.new(**server_opts)
|
261
261
|
@server.start
|
262
262
|
@api = TinyServer::API.instance
|
263
263
|
@api.clear
|