chef 18.5.0 → 18.7.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (241) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +11 -6
  3. data/chef-universal-mingw-ucrt.gemspec +1 -1
  4. data/chef.gemspec +19 -15
  5. data/lib/chef/application/client.rb +0 -12
  6. data/lib/chef/client.rb +1 -10
  7. data/lib/chef/compliance/default_attributes.rb +2 -2
  8. data/lib/chef/compliance/runner.rb +6 -11
  9. data/lib/chef/cookbook/metadata.rb +1 -1
  10. data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
  11. data/lib/chef/cookbook/synchronizer.rb +0 -5
  12. data/lib/chef/event_dispatch/dispatcher.rb +0 -1
  13. data/lib/chef/exceptions.rb +1 -1
  14. data/lib/chef/file_access_control/unix.rb +9 -9
  15. data/lib/chef/file_content_management/deploy.rb +1 -4
  16. data/lib/chef/mixin/file_class.rb +1 -3
  17. data/lib/chef/mixin/get_source_from_package.rb +1 -1
  18. data/lib/chef/mixin/{homebrew_user.rb → homebrew.rb} +13 -16
  19. data/lib/chef/mixin/openssl_helper.rb +1 -12
  20. data/lib/chef/provider/cookbook_file.rb +1 -1
  21. data/lib/chef/provider/cron.rb +1 -1
  22. data/lib/chef/provider/directory.rb +15 -15
  23. data/lib/chef/provider/file.rb +29 -42
  24. data/lib/chef/provider/git.rb +8 -8
  25. data/lib/chef/provider/group/aix.rb +1 -1
  26. data/lib/chef/provider/group/dscl.rb +1 -1
  27. data/lib/chef/provider/group/gpasswd.rb +2 -2
  28. data/lib/chef/provider/group/groupadd.rb +1 -1
  29. data/lib/chef/provider/group/groupmod.rb +2 -2
  30. data/lib/chef/provider/group/pw.rb +2 -2
  31. data/lib/chef/provider/group/solaris.rb +2 -2
  32. data/lib/chef/provider/group/usermod.rb +2 -2
  33. data/lib/chef/provider/group.rb +1 -1
  34. data/lib/chef/provider/http_request.rb +3 -2
  35. data/lib/chef/provider/ifconfig/aix.rb +1 -1
  36. data/lib/chef/provider/ifconfig/debian.rb +3 -3
  37. data/lib/chef/provider/ifconfig/redhat.rb +1 -1
  38. data/lib/chef/provider/ifconfig.rb +1 -1
  39. data/lib/chef/provider/link.rb +10 -10
  40. data/lib/chef/provider/mount/aix.rb +4 -4
  41. data/lib/chef/provider/mount/linux.rb +4 -4
  42. data/lib/chef/provider/mount/mount.rb +11 -11
  43. data/lib/chef/provider/package/apt.rb +11 -2
  44. data/lib/chef/provider/package/bff.rb +3 -3
  45. data/lib/chef/provider/package/chocolatey.rb +2 -2
  46. data/lib/chef/provider/package/dnf/dnf_helper.py +7 -0
  47. data/lib/chef/provider/package/dpkg.rb +3 -3
  48. data/lib/chef/provider/package/freebsd/base.rb +1 -1
  49. data/lib/chef/provider/package/habitat.rb +3 -5
  50. data/lib/chef/provider/package/homebrew.rb +6 -9
  51. data/lib/chef/provider/package/ips.rb +2 -2
  52. data/lib/chef/provider/package/openbsd.rb +2 -3
  53. data/lib/chef/provider/package/pacman.rb +4 -4
  54. data/lib/chef/provider/package/paludis.rb +2 -2
  55. data/lib/chef/provider/package/portage.rb +1 -1
  56. data/lib/chef/provider/package/rpm.rb +2 -2
  57. data/lib/chef/provider/package/rubygems.rb +4 -0
  58. data/lib/chef/provider/package/smartos.rb +2 -2
  59. data/lib/chef/provider/package/snap.rb +2 -2
  60. data/lib/chef/provider/package/solaris.rb +4 -4
  61. data/lib/chef/provider/package/zypper.rb +4 -4
  62. data/lib/chef/provider/package.rb +1 -1
  63. data/lib/chef/provider/registry_key.rb +6 -0
  64. data/lib/chef/provider/remote_directory.rb +5 -5
  65. data/lib/chef/provider/remote_file/http.rb +3 -2
  66. data/lib/chef/provider/remote_file.rb +1 -1
  67. data/lib/chef/provider/route.rb +9 -9
  68. data/lib/chef/provider/service/aix.rb +1 -1
  69. data/lib/chef/provider/service/aixinit.rb +4 -4
  70. data/lib/chef/provider/service/arch.rb +6 -6
  71. data/lib/chef/provider/service/debian.rb +5 -5
  72. data/lib/chef/provider/service/freebsd.rb +7 -7
  73. data/lib/chef/provider/service/gentoo.rb +5 -5
  74. data/lib/chef/provider/service/init.rb +2 -2
  75. data/lib/chef/provider/service/insserv.rb +2 -2
  76. data/lib/chef/provider/service/invokercd.rb +1 -1
  77. data/lib/chef/provider/service/openbsd.rb +7 -7
  78. data/lib/chef/provider/service/redhat.rb +3 -3
  79. data/lib/chef/provider/service/solaris.rb +2 -2
  80. data/lib/chef/provider/service/systemd.rb +2 -2
  81. data/lib/chef/provider/service/upstart.rb +2 -2
  82. data/lib/chef/provider/subversion.rb +8 -8
  83. data/lib/chef/provider/systemd_unit.rb +3 -3
  84. data/lib/chef/provider/template.rb +1 -1
  85. data/lib/chef/provider/user/aix.rb +3 -3
  86. data/lib/chef/provider/user/linux.rb +2 -7
  87. data/lib/chef/provider/user/pw.rb +3 -3
  88. data/lib/chef/provider/user/solaris.rb +7 -7
  89. data/lib/chef/provider/user/windows.rb +5 -0
  90. data/lib/chef/provider/user.rb +8 -7
  91. data/lib/chef/provider/yum_repository.rb +3 -1
  92. data/lib/chef/provider/zypper_repository.rb +1 -1
  93. data/lib/chef/providers.rb +0 -1
  94. data/lib/chef/resource/alternatives.rb +2 -2
  95. data/lib/chef/resource/apt_preference.rb +1 -1
  96. data/lib/chef/resource/apt_repository.rb +90 -15
  97. data/lib/chef/resource/apt_update.rb +3 -3
  98. data/lib/chef/resource/bff_package.rb +1 -1
  99. data/lib/chef/resource/chef_client_config.rb +3 -2
  100. data/lib/chef/resource/chef_sleep.rb +1 -1
  101. data/lib/chef/resource/cookbook_file.rb +1 -1
  102. data/lib/chef/resource/cron/cron.rb +1 -1
  103. data/lib/chef/resource/cron/cron_d.rb +1 -1
  104. data/lib/chef/resource/cron_access.rb +1 -1
  105. data/lib/chef/resource/directory.rb +1 -1
  106. data/lib/chef/resource/dpkg_package.rb +1 -1
  107. data/lib/chef/resource/file/verification/json.rb +1 -1
  108. data/lib/chef/resource/file/verification/systemd_unit.rb +1 -1
  109. data/lib/chef/resource/file/verification/yaml.rb +1 -1
  110. data/lib/chef/resource/file.rb +1 -1
  111. data/lib/chef/resource/freebsd_package.rb +2 -2
  112. data/lib/chef/resource/group.rb +1 -1
  113. data/lib/chef/resource/habitat/habitat_package.rb +1 -1
  114. data/lib/chef/resource/habitat/habitat_sup.rb +9 -9
  115. data/lib/chef/resource/habitat/habitat_sup_systemd.rb +2 -2
  116. data/lib/chef/resource/habitat_install.rb +3 -3
  117. data/lib/chef/resource/homebrew_cask.rb +19 -30
  118. data/lib/chef/resource/homebrew_tap.rb +32 -17
  119. data/lib/chef/resource/homebrew_update.rb +4 -4
  120. data/lib/chef/resource/hostname.rb +10 -11
  121. data/lib/chef/resource/http_request.rb +1 -1
  122. data/lib/chef/resource/ifconfig.rb +1 -1
  123. data/lib/chef/resource/inspec_input.rb +1 -3
  124. data/lib/chef/resource/inspec_waiver.rb +1 -1
  125. data/lib/chef/resource/inspec_waiver_file_entry.rb +1 -1
  126. data/lib/chef/resource/ips_package.rb +2 -2
  127. data/lib/chef/resource/kernel_module.rb +2 -2
  128. data/lib/chef/resource/link.rb +1 -1
  129. data/lib/chef/resource/locale.rb +2 -2
  130. data/lib/chef/resource/mount.rb +1 -1
  131. data/lib/chef/resource/notify_group.rb +1 -1
  132. data/lib/chef/resource/ohai.rb +1 -1
  133. data/lib/chef/resource/ohai_hint.rb +1 -1
  134. data/lib/chef/resource/openbsd_package.rb +2 -2
  135. data/lib/chef/resource/package.rb +1 -1
  136. data/lib/chef/resource/pacman_package.rb +1 -1
  137. data/lib/chef/resource/paludis_package.rb +1 -1
  138. data/lib/chef/resource/portage_package.rb +1 -1
  139. data/lib/chef/resource/reboot.rb +1 -1
  140. data/lib/chef/resource/registry_key.rb +18 -0
  141. data/lib/chef/resource/remote_directory.rb +1 -1
  142. data/lib/chef/resource/remote_file.rb +1 -1
  143. data/lib/chef/resource/rhsm_errata.rb +1 -1
  144. data/lib/chef/resource/rhsm_errata_level.rb +1 -1
  145. data/lib/chef/resource/rhsm_register.rb +1 -1
  146. data/lib/chef/resource/rhsm_repo.rb +4 -3
  147. data/lib/chef/resource/rhsm_subscription.rb +9 -8
  148. data/lib/chef/resource/route.rb +1 -1
  149. data/lib/chef/resource/rpm_package.rb +1 -1
  150. data/lib/chef/resource/scm/git.rb +1 -1
  151. data/lib/chef/resource/scm/subversion.rb +1 -1
  152. data/lib/chef/resource/selinux/common_helpers.rb +1 -1
  153. data/lib/chef/resource/selinux_boolean.rb +1 -1
  154. data/lib/chef/resource/selinux_fcontext.rb +3 -3
  155. data/lib/chef/resource/selinux_install.rb +1 -1
  156. data/lib/chef/resource/selinux_login.rb +1 -1
  157. data/lib/chef/resource/selinux_module.rb +5 -5
  158. data/lib/chef/resource/selinux_permissive.rb +2 -2
  159. data/lib/chef/resource/selinux_port.rb +2 -2
  160. data/lib/chef/resource/selinux_state.rb +2 -2
  161. data/lib/chef/resource/selinux_user.rb +1 -1
  162. data/lib/chef/resource/smartos_package.rb +2 -2
  163. data/lib/chef/resource/snap_package.rb +1 -1
  164. data/lib/chef/resource/solaris_package.rb +1 -1
  165. data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
  166. data/lib/chef/resource/sudo.rb +5 -5
  167. data/lib/chef/resource/support/client.erb +3 -2
  168. data/lib/chef/resource/swap_file.rb +6 -6
  169. data/lib/chef/resource/sysctl.rb +5 -5
  170. data/lib/chef/resource/systemd_unit.rb +1 -1
  171. data/lib/chef/resource/template.rb +1 -1
  172. data/lib/chef/resource/timezone.rb +5 -5
  173. data/lib/chef/resource/user/aix_user.rb +2 -2
  174. data/lib/chef/resource/user/linux_user.rb +2 -2
  175. data/lib/chef/resource/user/pw_user.rb +2 -2
  176. data/lib/chef/resource/user/solaris_user.rb +2 -2
  177. data/lib/chef/resource/user_ulimit.rb +1 -1
  178. data/lib/chef/resource/yum_repository.rb +1 -1
  179. data/lib/chef/resource/zypper_package.rb +2 -2
  180. data/lib/chef/resource/zypper_repository.rb +2 -2
  181. data/lib/chef/resource.rb +1 -0
  182. data/lib/chef/resource_inspector.rb +25 -7
  183. data/lib/chef/resource_reporter.rb +1 -0
  184. data/lib/chef/run_lock.rb +0 -3
  185. data/lib/chef/scan_access_control.rb +6 -6
  186. data/lib/chef/util/backup.rb +1 -1
  187. data/lib/chef/util/diff.rb +1 -14
  188. data/lib/chef/util/file_edit.rb +4 -4
  189. data/lib/chef/util/powershell/ps_credential.rb +10 -0
  190. data/lib/chef/version.rb +1 -1
  191. data/lib/chef/win32/registry.rb +5 -1
  192. data/lib/chef/win32/security.rb +9 -0
  193. data/lib/chef.rb +0 -2
  194. data/spec/functional/assets/yumrepo-empty/repodata/repomd.xml +6 -6
  195. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  196. data/spec/functional/resource/registry_spec.rb +276 -609
  197. data/spec/integration/client/open_ssl_spec.rb +1 -1
  198. data/spec/spec_helper.rb +1 -0
  199. data/spec/support/chef_helpers.rb +2 -2
  200. data/spec/support/platform_helpers.rb +8 -0
  201. data/spec/support/shared/functional/file_resource.rb +3 -3
  202. data/spec/tiny_server.rb +5 -2
  203. data/spec/unit/mixin/homebrew_spec.rb +118 -0
  204. data/spec/unit/provider/apt_repository_spec.rb +14 -9
  205. data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
  206. data/spec/unit/provider/package/homebrew_spec.rb +4 -1
  207. data/spec/unit/provider/registry_key_spec.rb +18 -17
  208. data/spec/unit/provider/route_spec.rb +4 -6
  209. data/spec/unit/provider/user/windows_spec.rb +1 -0
  210. data/spec/unit/resource/rhsm_repo_spec.rb +0 -1
  211. data/spec/unit/resource/rhsm_subscription_spec.rb +0 -2
  212. data/spec/unit/resource_inspector_spec.rb +36 -0
  213. data/spec/unit/util/powershell/ps_credential_spec.rb +6 -0
  214. metadata +36 -44
  215. data/lib/chef/file_content_management/deploy/target_io.rb +0 -29
  216. data/lib/chef/provider/.gitkeep +0 -0
  217. data/lib/chef/provider/package/snap_tm.rb +0 -79
  218. data/lib/chef/resource/.gitkeep +0 -0
  219. data/lib/chef/target_io/dir.rb +0 -12
  220. data/lib/chef/target_io/etc.rb +0 -16
  221. data/lib/chef/target_io/file.rb +0 -12
  222. data/lib/chef/target_io/fileutils.rb +0 -12
  223. data/lib/chef/target_io/http.rb +0 -22
  224. data/lib/chef/target_io/io.rb +0 -12
  225. data/lib/chef/target_io/shadow.rb +0 -44
  226. data/lib/chef/target_io/train/dir.rb +0 -69
  227. data/lib/chef/target_io/train/etc.rb +0 -112
  228. data/lib/chef/target_io/train/file.rb +0 -219
  229. data/lib/chef/target_io/train/fileutils.rb +0 -220
  230. data/lib/chef/target_io/train/http.rb +0 -117
  231. data/lib/chef/target_io/train/io.rb +0 -13
  232. data/lib/chef/target_io/train/shadow.rb +0 -52
  233. data/lib/chef/target_io/train_compat.rb +0 -7
  234. data/lib/chef/target_io.rb +0 -9
  235. data/spec/unit/mixin/homebrew_user_spec.rb +0 -119
  236. /data/spec/functional/assets/yumrepo-empty/repodata/{01a3b489a465bcac22a43492163df43451dc6ce47d27f66de289756b91635523-filelists.sqlite.bz2 → 01a3b-filelists.sqlite.bz2} +0 -0
  237. /data/spec/functional/assets/yumrepo-empty/repodata/{401dc19bda88c82c403423fb835844d64345f7e95f5b9835888189c03834cc93-filelists.xml.gz → 401dc-filelists.xml.gz} +0 -0
  238. /data/spec/functional/assets/yumrepo-empty/repodata/{5dc1e6e73c84803f059bb3065e684e56adfc289a7e398946574d79dac6643945-primary.sqlite.bz2 → 5dc1e-primary.sqlite.bz2} +0 -0
  239. /data/spec/functional/assets/yumrepo-empty/repodata/{6bf9672d0862e8ef8b8ff05a2fd0208a922b1f5978e6589d87944c88259cb670-other.xml.gz → 6bf96-other.xml.gz} +0 -0
  240. /data/spec/functional/assets/yumrepo-empty/repodata/{7c36572015e075add2b38b900837bcdbb8a504130ddff49b2351a7fc0affa3d4-other.sqlite.bz2 → 7c365-other.sqlite.bz2} +0 -0
  241. /data/spec/functional/assets/yumrepo-empty/repodata/{dabe2ce5481d23de1f4f52bdcfee0f9af98316c9e0de2ce8123adeefa0dd08b9-primary.xml.gz → dabe2-primary.xml.gz} +0 -0
@@ -3,7 +3,7 @@ require "spec_helper"
3
3
  describe "openssl checks" do
4
4
  let(:openssl_version_default) do
5
5
  if windows?
6
- "1.0.2zi"
6
+ "3.0.9"
7
7
  elsif macos?
8
8
  "1.1.1m"
9
9
  else
data/spec/spec_helper.rb CHANGED
@@ -145,6 +145,7 @@ RSpec.configure do |config|
145
145
 
146
146
  config.filter_run_excluding windows_only: true unless windows?
147
147
  config.filter_run_excluding not_supported_on_windows: true if windows?
148
+ config.filter_run_excluding not_supported_on_windows_11: true if windows_11?
148
149
  config.filter_run_excluding not_supported_on_macos: true if macos?
149
150
  config.filter_run_excluding macos_only: true unless macos?
150
151
  config.filter_run_excluding not_macos_gte_11: true if macos_gte_11?
@@ -69,8 +69,8 @@ def make_canonical_temp_directory
69
69
  end
70
70
 
71
71
  # Check if a cmd exists on the PATH
72
- def which(cmd)
73
- paths = ENV["PATH"].split(File::PATH_SEPARATOR) + [ "/bin", "/usr/bin", "/sbin", "/usr/sbin" ]
72
+ def which(cmd, prepend_path: nil, extra_path: nil)
73
+ paths = Array(prepend_path) + ENV["PATH"].split(File::PATH_SEPARATOR) + [ "/bin", "/usr/bin", "/sbin", "/usr/sbin" ] + Array(extra_path)
74
74
  paths.each do |path|
75
75
  filename = File.join(path, cmd)
76
76
  return filename if File.executable?(filename)
@@ -65,6 +65,12 @@ def windows_gte_10?
65
65
  Gem::Requirement.new(">= 10").satisfied_by?(Gem::Version.new(win32_os_version))
66
66
  end
67
67
 
68
+ def windows_11?
69
+ return false unless windows?
70
+
71
+ Gem::Requirement.new(">= 10.0.22621").satisfied_by?(Gem::Version.new(win32_os_version))
72
+ end
73
+
68
74
  def win32_os_version
69
75
  @win32_os_version ||= begin
70
76
  wmi = WmiLite::Wmi.new
@@ -228,6 +234,8 @@ def aes_256_gcm?
228
234
  end
229
235
 
230
236
  def fips_mode_build?
237
+ return false if ENV.fetch("BUILDKITE_PIPELINE_SLUG", "") =~ /verify$/
238
+
231
239
  if ENV.include?("BUILDKITE_LABEL") # try keying directly off Buildkite environments
232
240
  # regex version of chef/chef-foundation:.expeditor/release.omnibus.yml:fips-platforms
233
241
  [/el-.*-x86_64/, /el-.*-ppc64/, /el-.*aarch/, /ubuntu-/, /windows-/, /amazon-2/].any? do |os_arch|
@@ -245,14 +245,14 @@ shared_examples_for "a file resource" do
245
245
 
246
246
  include_context "deploying with move"
247
247
 
248
- describe "when deploying via tmpdir" do
248
+ describe "when deploying via tmpdir", :not_supported_on_windows_11 do
249
249
 
250
250
  include_context "deploying via tmpdir"
251
251
 
252
252
  it_behaves_like "a configured file resource"
253
253
  end
254
254
 
255
- describe "when deploying via destdir" do
255
+ describe "when deploying via destdir", :not_supported_on_windows_11 do
256
256
 
257
257
  include_context "deploying via destdir"
258
258
 
@@ -912,7 +912,7 @@ shared_examples_for "a configured file resource" do
912
912
  dummy_desc
913
913
  end
914
914
 
915
- it_behaves_like "a securable resource without existing target"
915
+ it_behaves_like "a securable resource without existing target", :not_supported_on_windows_11
916
916
 
917
917
  context "when the target file has the wrong content" do
918
918
  before(:each) do
data/spec/tiny_server.rb CHANGED
@@ -19,6 +19,7 @@
19
19
  require "webrick"
20
20
  require "webrick/https"
21
21
  require "rack"
22
+ require "rackup"
22
23
  require "singleton"
23
24
  require "open-uri"
24
25
  require "chef/config"
@@ -91,7 +92,7 @@ module TinyServer
91
92
 
92
93
  def create_server(**extra_options)
93
94
  server = WEBrick::HTTPServer.new(**options, **extra_options)
94
- server.mount("/", Rack::Handler::WEBrick, API.instance)
95
+ server.mount("/", Rackup::Handler::WEBrick, API.instance)
95
96
  server
96
97
  end
97
98
  end
@@ -172,7 +173,9 @@ module TinyServer
172
173
 
173
174
  def initialize(response_code = 200, data = nil, headers = nil, &block)
174
175
  @response_code, @data = response_code, data
175
- @response_headers = headers ? HEADERS.merge(headers) : HEADERS
176
+ # .merge creates a new hash, headers is sometimes passed as nil, @response_headers gets mutated somewhere
177
+ # in processing
178
+ @response_headers = HEADERS.merge(headers || {})
176
179
  @block = block_given? ? block : nil
177
180
  end
178
181
 
@@ -0,0 +1,118 @@
1
+ #
2
+ # Author:: Joshua Timberman (<joshua@chef.io>)
3
+ #
4
+ # Copyright:: Copyright (c) Chef Software Inc.
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+
18
+ require "spec_helper"
19
+
20
+ describe Chef::Mixin::Homebrew do
21
+ let(:homebrew) { Class.new { include Chef::Mixin::Homebrew }.new }
22
+ let(:uid) { 1001 }
23
+ let(:username) { "foobar" }
24
+ let(:alt_brew_path) { "/foo" }
25
+
26
+ describe "#find_homebrew_uid" do
27
+ it "returns the provided UID when an integer is given" do
28
+ expect(File).to receive(:exist?).exactly(0).times
29
+ expect(homebrew.find_homebrew_uid(uid)).to eq(uid)
30
+ end
31
+
32
+ it "returns the provided UID when username is given" do
33
+ expect(File).to receive(:exist?).exactly(0).times
34
+ allow(Etc).to receive(:getpwnam).with(username).and_return(OpenStruct.new(uid: uid))
35
+ expect(homebrew.find_homebrew_uid(username)).to eq(uid)
36
+ end
37
+
38
+ it "raises an error when the brew executable is not found" do
39
+ allow(homebrew).to receive(:homebrew_bin_path).and_raise(Chef::Exceptions::CannotDetermineHomebrewPath)
40
+ expect { homebrew.find_homebrew_uid }.to raise_error(Chef::Exceptions::CannotDetermineHomebrewPath)
41
+ end
42
+
43
+ it "returns the UID of the owner based on the brew executable" do
44
+ allow(homebrew).to receive(:homebrew_bin_path).and_return(alt_brew_path)
45
+ allow(File).to receive(:stat).with(alt_brew_path).and_return(OpenStruct.new(uid: uid))
46
+ allow(Etc).to receive(:getpwuid).with(uid).and_return(OpenStruct.new(name: username))
47
+ expect(homebrew.find_homebrew_uid).to eq(uid)
48
+ end
49
+ end
50
+
51
+ describe "#find_homebrew_username" do
52
+ it "returns the username for the provided UID" do
53
+ allow(homebrew).to receive(:find_homebrew_uid).and_return(uid)
54
+ allow(Etc).to receive(:getpwuid).with(uid).and_return(OpenStruct.new(name: username))
55
+ expect(homebrew.find_homebrew_username(uid)).to eq(username)
56
+ end
57
+ end
58
+
59
+ describe "#homebrew_bin_path" do
60
+ it "returns the correct path when a valid path is provided" do
61
+ allow(File).to receive(:exist?).with(alt_brew_path).and_return(true)
62
+ expect(homebrew.homebrew_bin_path(alt_brew_path)).to eq(alt_brew_path)
63
+ end
64
+
65
+ it "raises an error when the brew executable is not found" do
66
+ allow(homebrew).to receive(:which).and_return(false)
67
+ expect { homebrew.homebrew_bin_path }.to raise_error(Chef::Exceptions::CannotDetermineHomebrewPath)
68
+ end
69
+ end
70
+
71
+ shared_examples "successfully find executable" do
72
+ let(:default_brew_path) { "/usr/local/bin/brew" }
73
+ let(:default_brew_path_arm) { "/opt/homebrew/bin/brew" }
74
+ let(:default_brew_path_linux) { "/home/linuxbrew/.linuxbrew/bin/brew" }
75
+
76
+ context "debug statement prints owner name" do
77
+
78
+ before do
79
+ expect(Etc).to receive(:getpwuid).with(uid).and_return(OpenStruct.new(name: username))
80
+ end
81
+
82
+ it "returns the owner of the brew executable when it is at a default location for x86_64 machines" do
83
+ allow(homebrew).to receive(:homebrew_bin_path).and_return(default_brew_path)
84
+ allow(File).to receive(:stat).with(default_brew_path).and_return(OpenStruct.new(uid: uid))
85
+ expect(homebrew.find_homebrew_uid).to eq(uid)
86
+ end
87
+
88
+ it "returns the owner of the brew executable when it is at a default location for arm machines" do
89
+ allow(homebrew).to receive(:homebrew_bin_path).and_return(default_brew_path_arm)
90
+ allow(File).to receive(:stat).with(default_brew_path_arm).and_return(OpenStruct.new(uid: uid))
91
+ expect(homebrew.find_homebrew_uid).to eq(uid)
92
+ end
93
+
94
+ it "returns the owner of the brew executable when it is at a default location for linux machines" do
95
+ allow(homebrew).to receive(:homebrew_bin_path).and_return(default_brew_path_linux)
96
+ allow(File).to receive(:stat).with(default_brew_path_linux).and_return(OpenStruct.new(uid: uid))
97
+ expect(homebrew.find_homebrew_uid).to eq(uid)
98
+ end
99
+
100
+ it "returns the owner of the brew executable when it is not at a default location" do
101
+ allow(homebrew).to receive(:homebrew_bin_path).and_return(alt_brew_path)
102
+ allow(File).to receive(:stat).with(alt_brew_path).and_return(OpenStruct.new(uid: uid))
103
+ expect(homebrew.find_homebrew_uid).to eq(uid)
104
+ end
105
+ end
106
+ end
107
+
108
+ describe "#When the homebrew user is not provided" do
109
+
110
+ include_examples "successfully find executable"
111
+
112
+ context "the executable is owned by root" do
113
+ include_examples "successfully find executable" do
114
+ let(:uid) { 0 }
115
+ end
116
+ end
117
+ end
118
+ end
@@ -230,7 +230,7 @@ C5986B4F1257FFA86632CBA746181433FBB75451
230
230
  it "gets a key" do
231
231
  simples = double("HTTP")
232
232
  allow(simples).to receive(:get).and_return("\"#{key}\"")
233
- expect(Chef::HTTP::Simple).to receive(:new).with(url, {}).and_return(simples)
233
+ expect(Chef::HTTP::Simple).to receive(:new).with(url).and_return(simples)
234
234
  expect(provider).to receive(:install_key_from_keyserver).with(key, "keyserver.ubuntu.com")
235
235
  provider.install_ppa_key("chef", "main")
236
236
  end
@@ -246,43 +246,48 @@ C5986B4F1257FFA86632CBA746181433FBB75451
246
246
  describe "#build_repo" do
247
247
  it "creates a repository string" do
248
248
  target = "deb http://test/uri unstable main\n"
249
- expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, [])).to eql(target)
249
+ expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, nil, [])).to eql(target)
250
250
  end
251
251
 
252
252
  it "creates a repository string with spaces" do
253
253
  target = "deb http://test/uri%20with%20spaces unstable main\n"
254
- expect(provider.build_repo("http://test/uri with spaces", "unstable", "main", false, nil, [])).to eql(target)
254
+ expect(provider.build_repo("http://test/uri with spaces", "unstable", "main", false, nil, nil, [])).to eql(target)
255
255
  end
256
256
 
257
257
  it "creates a repository string with no distribution" do
258
258
  target = "deb http://test/uri main\n"
259
- expect(provider.build_repo("http://test/uri", nil, "main", false, nil, [])).to eql(target)
259
+ expect(provider.build_repo("http://test/uri", nil, "main", false, nil, nil, [])).to eql(target)
260
260
  end
261
261
 
262
262
  it "creates a repository string with source" do
263
263
  target = "deb http://test/uri unstable main\ndeb-src http://test/uri unstable main\n"
264
- expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, [], true)).to eql(target)
264
+ expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, nil, [], true)).to eql(target)
265
265
  end
266
266
 
267
267
  it "creates a repository string with trusted" do
268
268
  target = "deb [trusted=yes] http://test/uri unstable main\n"
269
- expect(provider.build_repo("http://test/uri", "unstable", "main", true, nil, [])).to eql(target)
269
+ expect(provider.build_repo("http://test/uri", "unstable", "main", true, nil, nil, [])).to eql(target)
270
+ end
271
+
272
+ it "creates a repository string with signed-by" do
273
+ target = "deb [signed-by=/etc/apt/keyrings/test.gpg] http://test/uri unstable main\n"
274
+ expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, "/etc/apt/keyrings/test.gpg", [])).to eql(target)
270
275
  end
271
276
 
272
277
  it "creates a repository string with custom options" do
273
278
  target = "deb [by-hash=no] http://test/uri unstable main\n"
274
- expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, ["by-hash=no"])).to eql(target)
279
+ expect(provider.build_repo("http://test/uri", "unstable", "main", false, nil, nil, ["by-hash=no"])).to eql(target)
275
280
  end
276
281
 
277
282
  it "creates a repository string with trusted, arch, and custom options" do
278
283
  target = "deb [arch=amd64 trusted=yes by-hash=no] http://test/uri unstable main\n"
279
- expect(provider.build_repo("http://test/uri", "unstable", "main", true, "amd64", ["by-hash=no"])).to eql(target)
284
+ expect(provider.build_repo("http://test/uri", "unstable", "main", true, "amd64", nil, ["by-hash=no"])).to eql(target)
280
285
  end
281
286
 
282
287
  it "handles a ppa repo" do
283
288
  target = "deb http://ppa.launchpad.net/chef/main/ubuntu unstable main\n"
284
289
  expect(provider).to receive(:make_ppa_url).with("ppa:chef/main").and_return("http://ppa.launchpad.net/chef/main/ubuntu")
285
- expect(provider.build_repo("ppa:chef/main", "unstable", "main", false, nil, [])).to eql(target)
290
+ expect(provider.build_repo("ppa:chef/main", "unstable", "main", false, nil, nil, [])).to eql(target)
286
291
  end
287
292
  end
288
293
  end
@@ -92,7 +92,7 @@ describe Chef::Provider::Package::Chocolatey, :windows_only do
92
92
 
93
93
  describe "choco searches change with the version" do
94
94
  it "Choco V1 uses List" do
95
- allow(provider).to receive(:powershell_exec!).with("Get-ItemProperty #{choco_exe} | select-object -expandproperty versioninfo | select-object -expandproperty productversion").and_return(double(result: "1.4.0"))
95
+ allow(provider).to receive(:powershell_exec!).with("Get-ItemProperty #{choco_exe} | select-object -expandproperty versioninfo | select-object -expandproperty productversion").and_return(double(result: "1.3.0"))
96
96
  expect(provider.query_command).to eql("list")
97
97
  end
98
98
 
@@ -19,6 +19,7 @@
19
19
  require "spec_helper"
20
20
 
21
21
  describe Chef::Provider::Package::Homebrew do
22
+ let(:default_brew_path) { "/usr/local/bin/brew" }
22
23
  let(:node) { Chef::Node.new }
23
24
  let(:new_resource) { Chef::Resource::HomebrewPackage.new(%w{emacs vim}) }
24
25
  let(:current_resource) { Chef::Resource::HomebrewPackage.new("emacs, vim") }
@@ -30,7 +31,6 @@ describe Chef::Provider::Package::Homebrew do
30
31
  end
31
32
 
32
33
  let(:homebrew_uid) { 1001 }
33
-
34
34
  let(:brew_cmd_output_data) { '[{"name":"emacs","full_name":"emacs","oldname":null,"aliases":[],"versioned_formulae":[],"desc":"GNU Emacs text editor","homepage":"https://www.gnu.org/software/emacs/","versions":{"stable":"26.3","devel":null,"head":"HEAD","bottle":true},"urls":{"stable":{"url":"https://ftp.gnu.org/gnu/emacs/emacs-26.3.tar.xz","tag":null,"revision":null}},"revision":0,"version_scheme":0,"bottle":{"stable":{"rebuild":0,"cellar":"/usr/local/Cellar","prefix":"/usr/local","root_url":"https://homebrew.bintray.com/bottles","files":{"catalina":{"url":"https://homebrew.bintray.com/bottles/emacs-26.3.catalina.bottle.tar.gz","sha256":"9ab33f4386ca5f7326a8c28da1324556ec990f682a7ca88641203da0b42dbdae"},"mojave":{"url":"https://homebrew.bintray.com/bottles/emacs-26.3.mojave.bottle.tar.gz","sha256":"8162a26246de7db44c53ea0d0ef0a806140318d19c69e8e5e33aa88ce7e823a8"},"high_sierra":{"url":"https://homebrew.bintray.com/bottles/emacs-26.3.high_sierra.bottle.tar.gz","sha256":"6a2629b6deddf99f81abb1990ecd6c87f0242a0eecbb6b6c2e4c3540e421d4c4"},"sierra":{"url":"https://homebrew.bintray.com/bottles/emacs-26.3.sierra.bottle.tar.gz","sha256":"2a47477e71766d7dd6b16c29ad5ba71817ed80d06212e3261ef3c776e7e9f5a2"}}}},"keg_only":false,"bottle_disabled":false,"options":[],"build_dependencies":["pkg-config"],"dependencies":["gnutls"],"recommended_dependencies":[],"optional_dependencies":[],"uses_from_macos":["libxml2","ncurses"],"requirements":[],"conflicts_with":[],"caveats":null,"installed":[],"linked_keg":null,"pinned":false,"outdated":false},{"name":"vim","full_name":"vim","oldname":null,"aliases":[],"versioned_formulae":[],"desc":"Vi \'workalike\' with many additional features","homepage":"https://www.vim.org/","versions":{"stable":"8.2.0550","devel":null,"head":"HEAD","bottle":true},"urls":{"stable":{"url":"https://github.com/vim/vim/archive/v8.2.0550.tar.gz","tag":null,"revision":null}},"revision":0,"version_scheme":0,"bottle":{"stable":{"rebuild":0,"cellar":"/usr/local/Cellar","prefix":"/usr/local","root_url":"https://homebrew.bintray.com/bottles","files":{"catalina":{"url":"https://homebrew.bintray.com/bottles/vim-8.2.0550.catalina.bottle.tar.gz","sha256":"8f9252500775aa85d8f826af30ca9e1118a56145fc2f961c37abed48bf78cf6b"},"mojave":{"url":"https://homebrew.bintray.com/bottles/vim-8.2.0550.mojave.bottle.tar.gz","sha256":"7566c83b770f3e8c4d4b462a39e5eb26609b37a8f8db6690a2560a3e22ded6b6"},"high_sierra":{"url":"https://homebrew.bintray.com/bottles/vim-8.2.0550.high_sierra.bottle.tar.gz","sha256":"a76e517fc69bf67b6903cb82295bc085c5eb4b46b4659f034c694dd97d2ee2d9"}}}},"keg_only":false,"bottle_disabled":false,"options":[],"build_dependencies":[],"dependencies":["gettext","lua","perl","python","ruby"],"recommended_dependencies":[],"optional_dependencies":[],"uses_from_macos":["ncurses"],"requirements":[],"conflicts_with":["ex-vi","macvim"],"caveats":null,"installed":[{"version":"8.2.0550","used_options":[],"built_as_bottle":true,"poured_from_bottle":true,"runtime_dependencies":[{"full_name":"gettext","version":"0.20.1"},{"full_name":"lua","version":"5.3.5"},{"full_name":"perl","version":"5.30.2"},{"full_name":"gdbm","version":"1.18.1"},{"full_name":"openssl@1.1","version":"1.1.1f"},{"full_name":"readline","version":"8.0.4"},{"full_name":"sqlite","version":"3.31.1"},{"full_name":"xz","version":"5.2.5"},{"full_name":"python","version":"3.7.7"},{"full_name":"libyaml","version":"0.2.2"},{"full_name":"ruby","version":"2.7.1"}],"installed_as_dependency":false,"installed_on_request":true}],"linked_keg":"8.2.0550","pinned":false,"outdated":false}]' }
35
35
 
36
36
  let(:brew_info_data) do
@@ -297,11 +297,13 @@ describe Chef::Provider::Package::Homebrew do
297
297
 
298
298
  it "passes a single pkg to the brew command and return stdout" do
299
299
  allow(provider).to receive(:shell_out!).and_return(OpenStruct.new(stdout: "zombo"))
300
+ allow(provider).to receive(:homebrew_bin_path).and_return(default_brew_path)
300
301
  expect(provider.brew_cmd_output).to eql("zombo")
301
302
  end
302
303
 
303
304
  it "takes multiple arguments as an array" do
304
305
  allow(provider).to receive(:shell_out!).and_return(OpenStruct.new(stdout: "homestarrunner"))
306
+ allow(provider).to receive(:homebrew_bin_path).and_return(default_brew_path)
305
307
  expect(provider.brew_cmd_output("info", "opts", "bananas")).to eql("homestarrunner")
306
308
  end
307
309
 
@@ -310,6 +312,7 @@ describe Chef::Provider::Package::Homebrew do
310
312
 
311
313
  it "does not try to read homebrew_user from Package, which does not have it" do
312
314
  allow(provider).to receive(:shell_out!).and_return(OpenStruct.new(stdout: "zombo"))
315
+ allow(provider).to receive(:homebrew_bin_path).and_return(default_brew_path)
313
316
  expect(provider.brew_cmd_output).to eql("zombo")
314
317
  end
315
318
  end
@@ -26,7 +26,8 @@ shared_examples_for "a registry key" do
26
26
  describe "when the key exists" do
27
27
  before(:each) do
28
28
  expect(@double_registry).to receive(:key_exists?).with(keyname).and_return(true)
29
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval2 )
29
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval2] )
30
+ @new_resource.only_record_changes false
30
31
  @provider.load_current_resource
31
32
  end
32
33
 
@@ -66,7 +67,7 @@ shared_examples_for "a registry key" do
66
67
  end
67
68
  it "should do nothing if the if a case insensitive key and the value both exist" do
68
69
  @provider.new_resource.key(keyname.downcase)
69
- expect(@double_registry).to receive(:get_values).with(keyname.downcase).and_return( testval1 )
70
+ expect(@double_registry).to receive(:get_values).with(keyname.downcase).and_return( [testval1 ])
70
71
  expect(@double_registry).not_to receive(:set_value)
71
72
  @provider.load_current_resource
72
73
  @provider.action_create
@@ -77,25 +78,25 @@ shared_examples_for "a registry key" do
77
78
  expect(@double_registry).to receive(:key_exists?).twice.with(keyname).and_return(true)
78
79
  end
79
80
  it "should do nothing if the key and the value both exist" do
80
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1 )
81
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1] )
81
82
  expect(@double_registry).not_to receive(:set_value)
82
83
  @provider.load_current_resource
83
84
  @provider.action_create
84
85
  end
85
86
  it "should create the value if the key exists but the value does not" do
86
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval2 )
87
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval2] )
87
88
  expect(@double_registry).to receive(:set_value).with(keyname, testval1)
88
89
  @provider.load_current_resource
89
90
  @provider.action_create
90
91
  end
91
92
  it "should set the value if the key exists but the data does not match" do
92
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_data )
93
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_data] )
93
94
  expect(@double_registry).to receive(:set_value).with(keyname, testval1)
94
95
  @provider.load_current_resource
95
96
  @provider.action_create
96
97
  end
97
98
  it "should set the value if the key exists but the type does not match" do
98
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_type )
99
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_type] )
99
100
  expect(@double_registry).to receive(:set_value).with(keyname, testval1)
100
101
  @provider.load_current_resource
101
102
  @provider.action_create
@@ -105,7 +106,7 @@ shared_examples_for "a registry key" do
105
106
  it "when a value is in the key, it should do nothing" do
106
107
  @provider.new_resource.values([])
107
108
  expect(@double_registry).to receive(:key_exists?).twice.with(keyname).and_return(true)
108
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1 )
109
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1] )
109
110
  expect(@double_registry).not_to receive(:create_key)
110
111
  expect(@double_registry).not_to receive(:set_value)
111
112
  @provider.load_current_resource
@@ -150,25 +151,25 @@ shared_examples_for "a registry key" do
150
151
  expect(@double_registry).to receive(:key_exists?).twice.with(keyname).and_return(true)
151
152
  end
152
153
  it "should do nothing if the key and the value both exist" do
153
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1 )
154
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1] )
154
155
  expect(@double_registry).not_to receive(:set_value)
155
156
  @provider.load_current_resource
156
157
  @provider.action_create_if_missing
157
158
  end
158
159
  it "should create the value if the key exists but the value does not" do
159
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval2 )
160
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval2] )
160
161
  expect(@double_registry).to receive(:set_value).with(keyname, testval1)
161
162
  @provider.load_current_resource
162
163
  @provider.action_create_if_missing
163
164
  end
164
165
  it "should not set the value if the key exists but the data does not match" do
165
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_data )
166
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_data] )
166
167
  expect(@double_registry).not_to receive(:set_value)
167
168
  @provider.load_current_resource
168
169
  @provider.action_create_if_missing
169
170
  end
170
171
  it "should not set the value if the key exists but the type does not match" do
171
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_type )
172
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_type] )
172
173
  expect(@double_registry).not_to receive(:set_value)
173
174
  @provider.load_current_resource
174
175
  @provider.action_create_if_missing
@@ -193,25 +194,25 @@ shared_examples_for "a registry key" do
193
194
  expect(@double_registry).to receive(:key_exists?).twice.with(keyname).and_return(true)
194
195
  end
195
196
  it "deletes the value when the value exists" do
196
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1 )
197
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1] )
197
198
  expect(@double_registry).to receive(:delete_value).with(keyname, testval1)
198
199
  @provider.load_current_resource
199
200
  @provider.action_delete
200
201
  end
201
202
  it "deletes the value when the value exists, but the type is wrong" do
202
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_type )
203
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_type] )
203
204
  expect(@double_registry).to receive(:delete_value).with(keyname, testval1)
204
205
  @provider.load_current_resource
205
206
  @provider.action_delete
206
207
  end
207
208
  it "deletes the value when the value exists, but the data is wrong" do
208
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1_wrong_data )
209
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1_wrong_data] )
209
210
  expect(@double_registry).to receive(:delete_value).with(keyname, testval1)
210
211
  @provider.load_current_resource
211
212
  @provider.action_delete
212
213
  end
213
214
  it "does not delete the value when the value does not exist" do
214
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval2 )
215
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval2] )
215
216
  expect(@double_registry).not_to receive(:delete_value)
216
217
  @provider.load_current_resource
217
218
  @provider.action_delete
@@ -235,7 +236,7 @@ shared_examples_for "a registry key" do
235
236
  expect(@double_registry).to receive(:key_exists?).twice.with(keyname).and_return(true)
236
237
  end
237
238
  it "deletes the key" do
238
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( testval1 )
239
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [testval1] )
239
240
  expect(@double_registry).to receive(:delete_key).with(keyname, false)
240
241
  @provider.load_current_resource
241
242
  @provider.action_delete_key
@@ -303,7 +304,7 @@ describe Chef::Provider::RegistryKey do
303
304
  end
304
305
 
305
306
  it "does not make a change for datatype of data value differing" do
306
- expect(@double_registry).to receive(:get_values).with(keyname).and_return( dword_passed_as_integer )
307
+ expect(@double_registry).to receive(:get_values).with(keyname).and_return( [dword_passed_as_integer] )
307
308
  expect(@double_registry).not_to receive(:set_value)
308
309
  @provider.load_current_resource
309
310
  @provider.action_create
@@ -117,7 +117,7 @@ describe Chef::Provider::Route do
117
117
  @node.automatic_attrs[:platform_family] = "rhel"
118
118
 
119
119
  route_file = StringIO.new
120
- expect(File).to receive(:open).and_yield(route_file)
120
+ expect(File).to receive(:new).and_return(route_file)
121
121
  @resource_add = Chef::Resource::Route.new("192.168.1.0/24 via 192.168.0.1")
122
122
  @run_context.resource_collection << @resource_add
123
123
  allow(@provider).to receive(:shell_out!).and_return(true)
@@ -225,7 +225,7 @@ describe Chef::Provider::Route do
225
225
  @node.automatic_attrs[:platform_family] = platform_family
226
226
 
227
227
  route_file = StringIO.new
228
- expect(File).to receive(:open).with("/etc/sysconfig/network-scripts/route-eth0", "w").and_return(route_file)
228
+ expect(File).to receive(:new).with("/etc/sysconfig/network-scripts/route-eth0", "w").and_return(route_file)
229
229
  @run_context.resource_collection << @new_resource
230
230
  @provider.generate_config
231
231
  end
@@ -234,10 +234,8 @@ describe Chef::Provider::Route do
234
234
  @node.automatic_attrs[:platform_family] = platform_family
235
235
 
236
236
  route_file = StringIO.new
237
- allow(File).to receive(:exist?).and_call_original
238
- allow(File).to receive(:open).and_call_original
239
237
  allow(File).to receive(:exist?).with("/etc/sysconfig/network").and_return(false)
240
- expect(File).to receive(:open).with("/etc/sysconfig/network", "w").and_yield(route_file)
238
+ expect(File).to receive(:new).with("/etc/sysconfig/network", "w").and_return(route_file)
241
239
  @run_context.resource_collection << @default_resource
242
240
  @default_provider.generate_config
243
241
  expect(route_file.string).to match(/GATEWAY=10\.0\.0\.9/)
@@ -248,7 +246,7 @@ describe Chef::Provider::Route do
248
246
  @node.automatic_attrs[:platform_family] = "rhel"
249
247
 
250
248
  route_file = StringIO.new
251
- expect(File).to receive(:open).and_yield(route_file)
249
+ expect(File).to receive(:new).and_return(route_file)
252
250
  @run_context.resource_collection << Chef::Resource::Route.new("192.168.1.0/24 via 192.168.0.1")
253
251
  @run_context.resource_collection << Chef::Resource::Route.new("192.168.2.0/24 via 192.168.0.1")
254
252
  @run_context.resource_collection << Chef::Resource::Route.new("192.168.3.0/24 via 192.168.0.1")
@@ -158,6 +158,7 @@ describe Chef::Provider::User::Windows do
158
158
 
159
159
  describe "when removing the user" do
160
160
  it "should call @net_user.delete" do
161
+ allow(Chef::ReservedNames::Win32::Security).to receive(:clear_account_rights)
161
162
  expect(@net_user).to receive(:delete)
162
163
  @provider.remove_user
163
164
  end
@@ -46,7 +46,6 @@ describe Chef::Resource::RhsmRepo do
46
46
  before do
47
47
  allow(Mixlib::ShellOut).to receive(:new).and_return(cmd)
48
48
  allow(cmd).to receive(:run_command)
49
- allow(cmd).to receive(:live_stream).and_return(output)
50
49
  allow(cmd).to receive(:stdout).and_return(output)
51
50
  end
52
51
 
@@ -92,7 +92,6 @@ describe Chef::Resource::RhsmSubscription do
92
92
  before do
93
93
  allow(Mixlib::ShellOut).to receive(:new).and_return(cmd)
94
94
  allow(cmd).to receive(:run_command)
95
- allow(cmd).to receive(:live_stream).and_return(output)
96
95
  allow(cmd).to receive(:stdout).and_return(output)
97
96
  end
98
97
 
@@ -128,7 +127,6 @@ describe Chef::Resource::RhsmSubscription do
128
127
  it "parses the output correctly" do
129
128
  allow(Mixlib::ShellOut).to receive(:new).and_return(cmd)
130
129
  allow(cmd).to receive(:run_command)
131
- allow(cmd).to receive(:live_stream).and_return(output)
132
130
  allow(cmd).to receive(:stdout).and_return(output)
133
131
 
134
132
  expect(provider.serials_by_pool["pool1"]).to eq("serial1")
@@ -17,6 +17,20 @@
17
17
  require "spec_helper"
18
18
  require "chef/resource_inspector"
19
19
 
20
+ COMBINED_RESOURCE_TEXT = <<~EOF.freeze
21
+ class Dummy1 < Chef::Resource::LWRPBase
22
+ resource_name :dummy1
23
+ description "A dummy resource"
24
+ property :first, String, description: "My First Property", introduced: "14.0"
25
+ end
26
+
27
+ class Dummy2 < Chef::Resource::LWRPBase
28
+ resource_name :dummy2
29
+ description "Another dummy resource"
30
+ property :second, String, description: "My Second Property", introduced: "14.0"
31
+ end
32
+ EOF
33
+
20
34
  class DummyResource < Chef::Resource
21
35
  resource_name :dummy
22
36
  description "A dummy resource"
@@ -62,4 +76,26 @@ describe Chef::ResourceInspector do
62
76
  end
63
77
  end
64
78
  end
79
+
80
+ describe "inspecting a multi-resource file" do
81
+ # Call the inspector with a fake file containing two resources, and ensure that we get
82
+ # both of them back!
83
+ subject {
84
+ Chef::ResourceInspector.load_from_resources([
85
+ { "full_path" => "/cookbooks/fake_cookbook/resources/big_resource.rb" },
86
+ ], false)
87
+ }
88
+ it "has elephants" do
89
+ allow(File).to receive(:file?).with("/cookbooks/fake_cookbook/resources/big_resource.rb").and_return(true)
90
+ allow(File).to receive(:readable?).with("/cookbooks/fake_cookbook/resources/big_resource.rb").and_return(true)
91
+ allow(IO).to receive(:read).with("/cookbooks/fake_cookbook/resources/big_resource.rb").and_return(COMBINED_RESOURCE_TEXT)
92
+ expect(subject.keys.count).to be 2
93
+ expect(subject.keys.sort).to eq(%i{dummy1 dummy2})
94
+ # This is correct - because they're not fully realised resources at this point, sensitive and friends are not added yet.
95
+ expect(subject[:dummy1][:properties].count).to be 1
96
+ expect(subject[:dummy2][:properties].count).to be 1
97
+ expect(subject[:dummy1][:properties][0][:description]).to eq "My First Property"
98
+ expect(subject[:dummy2][:properties][0][:description]).to eq "My Second Property"
99
+ end
100
+ end
65
101
  end
@@ -35,6 +35,12 @@ describe Chef::Util::Powershell::PSCredential do
35
35
  end
36
36
  end
37
37
 
38
+ context "when inspect is called" do
39
+ it "should not contain the password" do
40
+ expect(ps_credential.inspect).not_to match(/#{password}/)
41
+ end
42
+ end
43
+
38
44
  context "when to_text is called" do
39
45
  it "should not contain the password" do
40
46
  allow(ps_credential).to receive(:encrypt).with(password).and_return("encrypted")