chef 16.0.257 → 16.0.275

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +30 -16
  3. data/chef.gemspec +1 -1
  4. data/lib/chef/knife/environment_compare.rb +1 -1
  5. data/lib/chef/knife/list.rb +1 -1
  6. data/lib/chef/knife/supermarket_install.rb +1 -1
  7. data/lib/chef/knife/yaml_convert.rb +2 -2
  8. data/lib/chef/provider/execute.rb +1 -1
  9. data/lib/chef/provider/package/freebsd/base.rb +2 -1
  10. data/lib/chef/provider/package/homebrew.rb +1 -1
  11. data/lib/chef/provider/package/macports.rb +0 -2
  12. data/lib/chef/provider/package/windows.rb +26 -51
  13. data/lib/chef/provider/user/dscl.rb +1 -1
  14. data/lib/chef/resource/alternatives.rb +65 -4
  15. data/lib/chef/resource/apt_package.rb +31 -2
  16. data/lib/chef/resource/apt_preference.rb +34 -5
  17. data/lib/chef/resource/apt_repository.rb +22 -15
  18. data/lib/chef/resource/apt_update.rb +6 -4
  19. data/lib/chef/resource/archive_file.rb +5 -4
  20. data/lib/chef/resource/bash.rb +1 -1
  21. data/lib/chef/resource/batch.rb +1 -1
  22. data/lib/chef/resource/bff_package.rb +1 -1
  23. data/lib/chef/resource/breakpoint.rb +1 -1
  24. data/lib/chef/resource/build_essential.rb +8 -4
  25. data/lib/chef/resource/cab_package.rb +1 -1
  26. data/lib/chef/resource/chef_client_cron.rb +12 -9
  27. data/lib/chef/resource/chef_client_scheduled_task.rb +9 -6
  28. data/lib/chef/resource/chef_client_systemd_timer.rb +10 -7
  29. data/lib/chef/resource/chef_gem.rb +6 -2
  30. data/lib/chef/resource/chef_handler.rb +1 -1
  31. data/lib/chef/resource/chef_sleep.rb +7 -4
  32. data/lib/chef/resource/chef_vault_secret.rb +3 -3
  33. data/lib/chef/resource/chocolatey_config.rb +5 -3
  34. data/lib/chef/resource/chocolatey_feature.rb +5 -3
  35. data/lib/chef/resource/chocolatey_package.rb +5 -3
  36. data/lib/chef/resource/chocolatey_source.rb +5 -3
  37. data/lib/chef/resource/cookbook_file.rb +3 -2
  38. data/lib/chef/resource/cron.rb +15 -15
  39. data/lib/chef/resource/cron_access.rb +7 -4
  40. data/lib/chef/resource/cron_d.rb +37 -23
  41. data/lib/chef/resource/csh.rb +1 -1
  42. data/lib/chef/resource/directory.rb +1 -1
  43. data/lib/chef/resource/dmg_package.rb +18 -15
  44. data/lib/chef/resource/dnf_package.rb +1 -1
  45. data/lib/chef/resource/dpkg_package.rb +1 -1
  46. data/lib/chef/resource/execute.rb +2 -2
  47. data/lib/chef/resource/file.rb +5 -4
  48. data/lib/chef/resource/freebsd_package.rb +1 -1
  49. data/lib/chef/resource/gem_package.rb +6 -6
  50. data/lib/chef/resource/group.rb +1 -1
  51. data/lib/chef/resource/homebrew_cask.rb +1 -1
  52. data/lib/chef/resource/homebrew_package.rb +1 -1
  53. data/lib/chef/resource/homebrew_tap.rb +1 -1
  54. data/lib/chef/resource/hostname.rb +4 -4
  55. data/lib/chef/resource/http_request.rb +1 -1
  56. data/lib/chef/resource/ifconfig.rb +7 -7
  57. data/lib/chef/resource/ips_package.rb +1 -1
  58. data/lib/chef/resource/kernel_module.rb +1 -1
  59. data/lib/chef/resource/ksh.rb +1 -1
  60. data/lib/chef/resource/launchd.rb +1 -1
  61. data/lib/chef/resource/link.rb +4 -4
  62. data/lib/chef/resource/locale.rb +1 -1
  63. data/lib/chef/resource/log.rb +1 -1
  64. data/lib/chef/resource/macos_userdefaults.rb +1 -1
  65. data/lib/chef/resource/macosx_service.rb +1 -1
  66. data/lib/chef/resource/macports_package.rb +1 -1
  67. data/lib/chef/resource/mdadm.rb +1 -1
  68. data/lib/chef/resource/mount.rb +1 -1
  69. data/lib/chef/resource/msu_package.rb +1 -1
  70. data/lib/chef/resource/ohai.rb +1 -1
  71. data/lib/chef/resource/ohai_hint.rb +1 -1
  72. data/lib/chef/resource/openbsd_package.rb +1 -1
  73. data/lib/chef/resource/openssl_dhparam.rb +1 -1
  74. data/lib/chef/resource/openssl_ec_private_key.rb +1 -1
  75. data/lib/chef/resource/openssl_ec_public_key.rb +1 -1
  76. data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
  77. data/lib/chef/resource/openssl_rsa_public_key.rb +1 -1
  78. data/lib/chef/resource/openssl_x509_certificate.rb +1 -1
  79. data/lib/chef/resource/openssl_x509_crl.rb +1 -1
  80. data/lib/chef/resource/openssl_x509_request.rb +1 -1
  81. data/lib/chef/resource/osx_profile.rb +1 -1
  82. data/lib/chef/resource/package.rb +1 -1
  83. data/lib/chef/resource/pacman_package.rb +1 -1
  84. data/lib/chef/resource/paludis_package.rb +1 -1
  85. data/lib/chef/resource/perl.rb +1 -1
  86. data/lib/chef/resource/plist.rb +1 -1
  87. data/lib/chef/resource/portage_package.rb +1 -1
  88. data/lib/chef/resource/powershell_package.rb +1 -1
  89. data/lib/chef/resource/powershell_package_source.rb +1 -1
  90. data/lib/chef/resource/powershell_script.rb +1 -1
  91. data/lib/chef/resource/python.rb +1 -1
  92. data/lib/chef/resource/reboot.rb +1 -1
  93. data/lib/chef/resource/registry_key.rb +1 -1
  94. data/lib/chef/resource/remote_directory.rb +1 -1
  95. data/lib/chef/resource/remote_file.rb +1 -2
  96. data/lib/chef/resource/rhsm_errata.rb +1 -3
  97. data/lib/chef/resource/rhsm_errata_level.rb +1 -1
  98. data/lib/chef/resource/rhsm_register.rb +1 -2
  99. data/lib/chef/resource/rhsm_repo.rb +1 -2
  100. data/lib/chef/resource/rhsm_subscription.rb +1 -3
  101. data/lib/chef/resource/route.rb +1 -1
  102. data/lib/chef/resource/rpm_package.rb +5 -2
  103. data/lib/chef/resource/ruby.rb +1 -1
  104. data/lib/chef/resource/ruby_block.rb +1 -4
  105. data/lib/chef/resource/scm/_scm.rb +4 -3
  106. data/lib/chef/resource/scm/git.rb +1 -1
  107. data/lib/chef/resource/scm/subversion.rb +2 -2
  108. data/lib/chef/resource/script.rb +1 -1
  109. data/lib/chef/resource/service.rb +1 -1
  110. data/lib/chef/resource/smartos_package.rb +1 -1
  111. data/lib/chef/resource/snap_package.rb +1 -1
  112. data/lib/chef/resource/solaris_package.rb +1 -1
  113. data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
  114. data/lib/chef/resource/sudo.rb +4 -4
  115. data/lib/chef/resource/swap_file.rb +2 -2
  116. data/lib/chef/resource/sysctl.rb +61 -2
  117. data/lib/chef/resource/systemd_unit.rb +2 -2
  118. data/lib/chef/resource/timezone.rb +1 -1
  119. data/lib/chef/resource/user.rb +2 -2
  120. data/lib/chef/resource/user_ulimit.rb +24 -22
  121. data/lib/chef/resource/windows_ad_join.rb +1 -1
  122. data/lib/chef/resource/windows_auto_run.rb +2 -2
  123. data/lib/chef/resource/windows_certificate.rb +1 -1
  124. data/lib/chef/resource/windows_dfs_folder.rb +1 -1
  125. data/lib/chef/resource/windows_dfs_namespace.rb +1 -1
  126. data/lib/chef/resource/windows_dfs_server.rb +1 -1
  127. data/lib/chef/resource/windows_env.rb +10 -1
  128. data/lib/chef/resource/windows_feature.rb +57 -2
  129. data/lib/chef/resource/windows_feature_dism.rb +15 -2
  130. data/lib/chef/resource/windows_feature_powershell.rb +29 -2
  131. data/lib/chef/resource/windows_firewall_rule.rb +9 -5
  132. data/lib/chef/resource/windows_font.rb +10 -1
  133. data/lib/chef/resource/windows_package.rb +63 -3
  134. data/lib/chef/resource/windows_pagefile.rb +30 -2
  135. data/lib/chef/resource/windows_path.rb +18 -1
  136. data/lib/chef/resource/windows_printer.rb +25 -5
  137. data/lib/chef/resource/windows_printer_port.rb +29 -1
  138. data/lib/chef/resource/windows_security_policy.rb +1 -1
  139. data/lib/chef/resource/windows_service.rb +1 -1
  140. data/lib/chef/resource/windows_share.rb +21 -1
  141. data/lib/chef/resource/windows_shortcut.rb +13 -2
  142. data/lib/chef/resource/windows_task.rb +122 -8
  143. data/lib/chef/resource/windows_uac.rb +20 -1
  144. data/lib/chef/resource/windows_workgroup.rb +19 -3
  145. data/lib/chef/resource/yum_package.rb +88 -6
  146. data/lib/chef/resource/yum_repository.rb +28 -11
  147. data/lib/chef/resource/zypper_package.rb +29 -3
  148. data/lib/chef/resource/zypper_repository.rb +17 -5
  149. data/lib/chef/resource_inspector.rb +1 -1
  150. data/lib/chef/scan_access_control.rb +1 -1
  151. data/lib/chef/version.rb +1 -1
  152. data/spec/functional/resource/link_spec.rb +3 -3
  153. data/spec/functional/resource/remote_file_spec.rb +1 -1
  154. data/spec/integration/knife/raw_spec.rb +4 -4
  155. data/spec/integration/knife/redirection_spec.rb +2 -2
  156. data/spec/support/platform_helpers.rb +0 -13
  157. data/spec/support/shared/functional/http.rb +2 -2
  158. data/spec/support/shared/unit/mock_shellout.rb +1 -1
  159. data/spec/unit/file_access_control_spec.rb +1 -1
  160. data/spec/unit/mixin/shell_out_spec.rb +25 -31
  161. data/spec/unit/provider/apt_repository_spec.rb +27 -27
  162. data/spec/unit/provider/zypper_repository_spec.rb +17 -17
  163. data/spec/unit/provider_resolver_spec.rb +2 -2
  164. 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 \'HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System\''
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 ':upgrade' action.",
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, [ true, false ],
74
- description: "Downgrade a package to satisfy requested version requirements.",
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 'repodata' directory lives. Can be an http://, https:// or a ftp:// URL. You can specify multiple URLs in one baseurl statement."
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 # deprecated
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 ``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.",
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 'url://to/some/location'."
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 ``keep-alive`` should be used with this repository."
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 '0' makes Yum try forever."
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 ``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.",
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 OpenSUSE platforms."
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 ``zypper_check_gpg`` config option.",
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 '--no-recommends'. See the zypper man page at https://en.opensuse.org/SDB:Zypper_manual_(plain) for the full list.",
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 'zypper repos' command."
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 'http://download.opensuse.org'."
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 OS X's negative uids
36
+ # TODO: figure out if all this works with macOS' negative uids
37
37
  # TODO: windows
38
38
  class ScanAccessControl
39
39
 
@@ -23,7 +23,7 @@ require_relative "version_string"
23
23
 
24
24
  class Chef
25
25
  CHEF_ROOT = File.expand_path("../..", __FILE__)
26
- VERSION = Chef::VersionString.new("16.0.257")
26
+ VERSION = Chef::VersionString.new("16.0.275")
27
27
  end
28
28
 
29
29
  #
@@ -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("OS X/FreeBSD/AIX/Solaris symlink? and readlink working on hard links to symlinks") if os_x? || freebsd? || aix? || solaris?
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
- # OS X gets angry about this sort of link. Bug in OS X, IMO.
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("OS X/FreeBSD/AIX/Solaris fails to create hardlinks to broken symlinks") if os_x? || freebsd? || aix? || solaris?
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
@@ -112,7 +112,7 @@ describe Chef::Resource::RemoteFile do
112
112
  SSLPrivateKey: key,
113
113
  RequestTimeout: 1 }
114
114
 
115
- start_tiny_server(server_opts)
115
+ start_tiny_server(**server_opts)
116
116
  end
117
117
 
118
118
  after(:all) do
@@ -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