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.
- checksums.yaml +4 -4
- data/Gemfile +11 -6
- data/chef-universal-mingw-ucrt.gemspec +1 -1
- data/chef.gemspec +19 -15
- data/lib/chef/application/client.rb +0 -12
- data/lib/chef/client.rb +1 -10
- data/lib/chef/compliance/default_attributes.rb +2 -2
- data/lib/chef/compliance/runner.rb +6 -11
- data/lib/chef/cookbook/metadata.rb +1 -1
- data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
- data/lib/chef/cookbook/synchronizer.rb +0 -5
- data/lib/chef/event_dispatch/dispatcher.rb +0 -1
- data/lib/chef/exceptions.rb +1 -1
- data/lib/chef/file_access_control/unix.rb +9 -9
- data/lib/chef/file_content_management/deploy.rb +1 -4
- data/lib/chef/mixin/file_class.rb +1 -3
- data/lib/chef/mixin/get_source_from_package.rb +1 -1
- data/lib/chef/mixin/{homebrew_user.rb → homebrew.rb} +13 -16
- data/lib/chef/mixin/openssl_helper.rb +1 -12
- data/lib/chef/provider/cookbook_file.rb +1 -1
- data/lib/chef/provider/cron.rb +1 -1
- data/lib/chef/provider/directory.rb +15 -15
- data/lib/chef/provider/file.rb +29 -42
- data/lib/chef/provider/git.rb +8 -8
- data/lib/chef/provider/group/aix.rb +1 -1
- data/lib/chef/provider/group/dscl.rb +1 -1
- data/lib/chef/provider/group/gpasswd.rb +2 -2
- data/lib/chef/provider/group/groupadd.rb +1 -1
- data/lib/chef/provider/group/groupmod.rb +2 -2
- data/lib/chef/provider/group/pw.rb +2 -2
- data/lib/chef/provider/group/solaris.rb +2 -2
- data/lib/chef/provider/group/usermod.rb +2 -2
- data/lib/chef/provider/group.rb +1 -1
- data/lib/chef/provider/http_request.rb +3 -2
- data/lib/chef/provider/ifconfig/aix.rb +1 -1
- data/lib/chef/provider/ifconfig/debian.rb +3 -3
- data/lib/chef/provider/ifconfig/redhat.rb +1 -1
- data/lib/chef/provider/ifconfig.rb +1 -1
- data/lib/chef/provider/link.rb +10 -10
- data/lib/chef/provider/mount/aix.rb +4 -4
- data/lib/chef/provider/mount/linux.rb +4 -4
- data/lib/chef/provider/mount/mount.rb +11 -11
- data/lib/chef/provider/package/apt.rb +11 -2
- data/lib/chef/provider/package/bff.rb +3 -3
- data/lib/chef/provider/package/chocolatey.rb +2 -2
- data/lib/chef/provider/package/dnf/dnf_helper.py +7 -0
- data/lib/chef/provider/package/dpkg.rb +3 -3
- data/lib/chef/provider/package/freebsd/base.rb +1 -1
- data/lib/chef/provider/package/habitat.rb +3 -5
- data/lib/chef/provider/package/homebrew.rb +6 -9
- data/lib/chef/provider/package/ips.rb +2 -2
- data/lib/chef/provider/package/openbsd.rb +2 -3
- data/lib/chef/provider/package/pacman.rb +4 -4
- data/lib/chef/provider/package/paludis.rb +2 -2
- data/lib/chef/provider/package/portage.rb +1 -1
- data/lib/chef/provider/package/rpm.rb +2 -2
- data/lib/chef/provider/package/rubygems.rb +4 -0
- data/lib/chef/provider/package/smartos.rb +2 -2
- data/lib/chef/provider/package/snap.rb +2 -2
- data/lib/chef/provider/package/solaris.rb +4 -4
- data/lib/chef/provider/package/zypper.rb +4 -4
- data/lib/chef/provider/package.rb +1 -1
- data/lib/chef/provider/registry_key.rb +6 -0
- data/lib/chef/provider/remote_directory.rb +5 -5
- data/lib/chef/provider/remote_file/http.rb +3 -2
- data/lib/chef/provider/remote_file.rb +1 -1
- data/lib/chef/provider/route.rb +9 -9
- data/lib/chef/provider/service/aix.rb +1 -1
- data/lib/chef/provider/service/aixinit.rb +4 -4
- data/lib/chef/provider/service/arch.rb +6 -6
- data/lib/chef/provider/service/debian.rb +5 -5
- data/lib/chef/provider/service/freebsd.rb +7 -7
- data/lib/chef/provider/service/gentoo.rb +5 -5
- data/lib/chef/provider/service/init.rb +2 -2
- data/lib/chef/provider/service/insserv.rb +2 -2
- data/lib/chef/provider/service/invokercd.rb +1 -1
- data/lib/chef/provider/service/openbsd.rb +7 -7
- data/lib/chef/provider/service/redhat.rb +3 -3
- data/lib/chef/provider/service/solaris.rb +2 -2
- data/lib/chef/provider/service/systemd.rb +2 -2
- data/lib/chef/provider/service/upstart.rb +2 -2
- data/lib/chef/provider/subversion.rb +8 -8
- data/lib/chef/provider/systemd_unit.rb +3 -3
- data/lib/chef/provider/template.rb +1 -1
- data/lib/chef/provider/user/aix.rb +3 -3
- data/lib/chef/provider/user/linux.rb +2 -7
- data/lib/chef/provider/user/pw.rb +3 -3
- data/lib/chef/provider/user/solaris.rb +7 -7
- data/lib/chef/provider/user/windows.rb +5 -0
- data/lib/chef/provider/user.rb +8 -7
- data/lib/chef/provider/yum_repository.rb +3 -1
- data/lib/chef/provider/zypper_repository.rb +1 -1
- data/lib/chef/providers.rb +0 -1
- data/lib/chef/resource/alternatives.rb +2 -2
- data/lib/chef/resource/apt_preference.rb +1 -1
- data/lib/chef/resource/apt_repository.rb +90 -15
- data/lib/chef/resource/apt_update.rb +3 -3
- data/lib/chef/resource/bff_package.rb +1 -1
- data/lib/chef/resource/chef_client_config.rb +3 -2
- data/lib/chef/resource/chef_sleep.rb +1 -1
- data/lib/chef/resource/cookbook_file.rb +1 -1
- data/lib/chef/resource/cron/cron.rb +1 -1
- data/lib/chef/resource/cron/cron_d.rb +1 -1
- data/lib/chef/resource/cron_access.rb +1 -1
- data/lib/chef/resource/directory.rb +1 -1
- data/lib/chef/resource/dpkg_package.rb +1 -1
- data/lib/chef/resource/file/verification/json.rb +1 -1
- data/lib/chef/resource/file/verification/systemd_unit.rb +1 -1
- data/lib/chef/resource/file/verification/yaml.rb +1 -1
- data/lib/chef/resource/file.rb +1 -1
- data/lib/chef/resource/freebsd_package.rb +2 -2
- data/lib/chef/resource/group.rb +1 -1
- data/lib/chef/resource/habitat/habitat_package.rb +1 -1
- data/lib/chef/resource/habitat/habitat_sup.rb +9 -9
- data/lib/chef/resource/habitat/habitat_sup_systemd.rb +2 -2
- data/lib/chef/resource/habitat_install.rb +3 -3
- data/lib/chef/resource/homebrew_cask.rb +19 -30
- data/lib/chef/resource/homebrew_tap.rb +32 -17
- data/lib/chef/resource/homebrew_update.rb +4 -4
- data/lib/chef/resource/hostname.rb +10 -11
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/ifconfig.rb +1 -1
- data/lib/chef/resource/inspec_input.rb +1 -3
- data/lib/chef/resource/inspec_waiver.rb +1 -1
- data/lib/chef/resource/inspec_waiver_file_entry.rb +1 -1
- data/lib/chef/resource/ips_package.rb +2 -2
- data/lib/chef/resource/kernel_module.rb +2 -2
- data/lib/chef/resource/link.rb +1 -1
- data/lib/chef/resource/locale.rb +2 -2
- data/lib/chef/resource/mount.rb +1 -1
- data/lib/chef/resource/notify_group.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 +2 -2
- 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/portage_package.rb +1 -1
- data/lib/chef/resource/reboot.rb +1 -1
- data/lib/chef/resource/registry_key.rb +18 -0
- data/lib/chef/resource/remote_directory.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -1
- data/lib/chef/resource/rhsm_errata.rb +1 -1
- data/lib/chef/resource/rhsm_errata_level.rb +1 -1
- data/lib/chef/resource/rhsm_register.rb +1 -1
- data/lib/chef/resource/rhsm_repo.rb +4 -3
- data/lib/chef/resource/rhsm_subscription.rb +9 -8
- data/lib/chef/resource/route.rb +1 -1
- data/lib/chef/resource/rpm_package.rb +1 -1
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/scm/subversion.rb +1 -1
- data/lib/chef/resource/selinux/common_helpers.rb +1 -1
- data/lib/chef/resource/selinux_boolean.rb +1 -1
- data/lib/chef/resource/selinux_fcontext.rb +3 -3
- data/lib/chef/resource/selinux_install.rb +1 -1
- data/lib/chef/resource/selinux_login.rb +1 -1
- data/lib/chef/resource/selinux_module.rb +5 -5
- data/lib/chef/resource/selinux_permissive.rb +2 -2
- data/lib/chef/resource/selinux_port.rb +2 -2
- data/lib/chef/resource/selinux_state.rb +2 -2
- data/lib/chef/resource/selinux_user.rb +1 -1
- data/lib/chef/resource/smartos_package.rb +2 -2
- 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 +5 -5
- data/lib/chef/resource/support/client.erb +3 -2
- data/lib/chef/resource/swap_file.rb +6 -6
- data/lib/chef/resource/sysctl.rb +5 -5
- data/lib/chef/resource/systemd_unit.rb +1 -1
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/timezone.rb +5 -5
- data/lib/chef/resource/user/aix_user.rb +2 -2
- data/lib/chef/resource/user/linux_user.rb +2 -2
- data/lib/chef/resource/user/pw_user.rb +2 -2
- data/lib/chef/resource/user/solaris_user.rb +2 -2
- data/lib/chef/resource/user_ulimit.rb +1 -1
- data/lib/chef/resource/yum_repository.rb +1 -1
- data/lib/chef/resource/zypper_package.rb +2 -2
- data/lib/chef/resource/zypper_repository.rb +2 -2
- data/lib/chef/resource.rb +1 -0
- data/lib/chef/resource_inspector.rb +25 -7
- data/lib/chef/resource_reporter.rb +1 -0
- data/lib/chef/run_lock.rb +0 -3
- data/lib/chef/scan_access_control.rb +6 -6
- data/lib/chef/util/backup.rb +1 -1
- data/lib/chef/util/diff.rb +1 -14
- data/lib/chef/util/file_edit.rb +4 -4
- data/lib/chef/util/powershell/ps_credential.rb +10 -0
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/registry.rb +5 -1
- data/lib/chef/win32/security.rb +9 -0
- data/lib/chef.rb +0 -2
- data/spec/functional/assets/yumrepo-empty/repodata/repomd.xml +6 -6
- data/spec/functional/resource/cookbook_file_spec.rb +1 -1
- data/spec/functional/resource/registry_spec.rb +276 -609
- data/spec/integration/client/open_ssl_spec.rb +1 -1
- data/spec/spec_helper.rb +1 -0
- data/spec/support/chef_helpers.rb +2 -2
- data/spec/support/platform_helpers.rb +8 -0
- data/spec/support/shared/functional/file_resource.rb +3 -3
- data/spec/tiny_server.rb +5 -2
- data/spec/unit/mixin/homebrew_spec.rb +118 -0
- data/spec/unit/provider/apt_repository_spec.rb +14 -9
- data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
- data/spec/unit/provider/package/homebrew_spec.rb +4 -1
- data/spec/unit/provider/registry_key_spec.rb +18 -17
- data/spec/unit/provider/route_spec.rb +4 -6
- data/spec/unit/provider/user/windows_spec.rb +1 -0
- data/spec/unit/resource/rhsm_repo_spec.rb +0 -1
- data/spec/unit/resource/rhsm_subscription_spec.rb +0 -2
- data/spec/unit/resource_inspector_spec.rb +36 -0
- data/spec/unit/util/powershell/ps_credential_spec.rb +6 -0
- metadata +36 -44
- data/lib/chef/file_content_management/deploy/target_io.rb +0 -29
- data/lib/chef/provider/.gitkeep +0 -0
- data/lib/chef/provider/package/snap_tm.rb +0 -79
- data/lib/chef/resource/.gitkeep +0 -0
- data/lib/chef/target_io/dir.rb +0 -12
- data/lib/chef/target_io/etc.rb +0 -16
- data/lib/chef/target_io/file.rb +0 -12
- data/lib/chef/target_io/fileutils.rb +0 -12
- data/lib/chef/target_io/http.rb +0 -22
- data/lib/chef/target_io/io.rb +0 -12
- data/lib/chef/target_io/shadow.rb +0 -44
- data/lib/chef/target_io/train/dir.rb +0 -69
- data/lib/chef/target_io/train/etc.rb +0 -112
- data/lib/chef/target_io/train/file.rb +0 -219
- data/lib/chef/target_io/train/fileutils.rb +0 -220
- data/lib/chef/target_io/train/http.rb +0 -117
- data/lib/chef/target_io/train/io.rb +0 -13
- data/lib/chef/target_io/train/shadow.rb +0 -52
- data/lib/chef/target_io/train_compat.rb +0 -7
- data/lib/chef/target_io.rb +0 -9
- data/spec/unit/mixin/homebrew_user_spec.rb +0 -119
- /data/spec/functional/assets/yumrepo-empty/repodata/{01a3b489a465bcac22a43492163df43451dc6ce47d27f66de289756b91635523-filelists.sqlite.bz2 → 01a3b-filelists.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo-empty/repodata/{401dc19bda88c82c403423fb835844d64345f7e95f5b9835888189c03834cc93-filelists.xml.gz → 401dc-filelists.xml.gz} +0 -0
- /data/spec/functional/assets/yumrepo-empty/repodata/{5dc1e6e73c84803f059bb3065e684e56adfc289a7e398946574d79dac6643945-primary.sqlite.bz2 → 5dc1e-primary.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo-empty/repodata/{6bf9672d0862e8ef8b8ff05a2fd0208a922b1f5978e6589d87944c88259cb670-other.xml.gz → 6bf96-other.xml.gz} +0 -0
- /data/spec/functional/assets/yumrepo-empty/repodata/{7c36572015e075add2b38b900837bcdbb8a504130ddff49b2351a7fc0affa3d4-other.sqlite.bz2 → 7c365-other.sqlite.bz2} +0 -0
- /data/spec/functional/assets/yumrepo-empty/repodata/{dabe2ce5481d23de1f4f52bdcfee0f9af98316c9e0de2ce8123adeefa0dd08b9-primary.xml.gz → dabe2-primary.xml.gz} +0 -0
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("/",
|
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
|
-
|
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
|
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.
|
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(:
|
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(:
|
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(:
|
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(:
|
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")
|