chef 16.2.73-universal-mingw32 → 16.3.38-universal-mingw32
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 +4 -4
- data/Rakefile +1 -1
- data/chef-universal-mingw32.gemspec +2 -2
- data/chef.gemspec +2 -1
- data/lib/chef/application.rb +12 -0
- data/lib/chef/{whitelist.rb → attribute_allowlist.rb} +11 -11
- data/lib/chef/{blacklist.rb → attribute_blocklist.rb} +9 -9
- data/lib/chef/chef_fs/data_handler/organization_data_handler.rb +1 -2
- data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +1 -5
- data/lib/chef/chef_fs/file_system/repository/base_file.rb +1 -0
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +1 -1
- data/lib/chef/client.rb +3 -3
- data/lib/chef/cookbook/remote_file_vendor.rb +1 -3
- data/lib/chef/cookbook/syntax_check.rb +1 -2
- data/lib/chef/cookbook_loader.rb +15 -29
- data/lib/chef/data_bag.rb +1 -2
- data/lib/chef/deprecated.rb +8 -0
- data/lib/chef/dsl/platform_introspection.rb +2 -0
- data/lib/chef/environment.rb +1 -2
- data/lib/chef/exceptions.rb +3 -0
- data/lib/chef/http/authenticator.rb +1 -1
- data/lib/chef/knife.rb +4 -4
- data/lib/chef/knife/bootstrap.rb +4 -10
- data/lib/chef/knife/bootstrap/train_connector.rb +1 -0
- data/lib/chef/knife/config_get.rb +1 -0
- data/lib/chef/knife/config_list_profiles.rb +4 -1
- data/lib/chef/knife/configure.rb +1 -1
- data/lib/chef/knife/cookbook_upload.rb +5 -10
- data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +1 -0
- data/lib/chef/knife/core/subcommand_loader.rb +20 -1
- data/lib/chef/knife/core/ui.rb +8 -2
- data/lib/chef/knife/core/windows_bootstrap_context.rb +1 -2
- data/lib/chef/knife/rehash.rb +3 -21
- data/lib/chef/knife/ssh.rb +5 -1
- data/lib/chef/log.rb +7 -2
- data/lib/chef/mixin/chef_utils_wiring.rb +40 -0
- data/{spec/unit/log_spec.rb → lib/chef/mixin/default_paths.rb} +13 -5
- data/lib/chef/mixin/openssl_helper.rb +27 -5
- data/lib/chef/mixin/path_sanity.rb +5 -4
- data/lib/chef/mixin/shell_out.rb +4 -188
- data/lib/chef/mixin/template.rb +1 -0
- data/lib/chef/mixin/which.rb +6 -3
- data/lib/chef/mixins.rb +1 -0
- data/lib/chef/node.rb +36 -12
- data/lib/chef/node_map.rb +21 -18
- data/lib/chef/platform/service_helpers.rb +31 -28
- data/lib/chef/provider/git.rb +12 -4
- data/lib/chef/provider/mount/solaris.rb +0 -1
- data/lib/chef/provider/package/snap.rb +2 -3
- data/lib/chef/provider/package/windows.rb +9 -4
- data/lib/chef/provider/package/zypper.rb +0 -1
- data/lib/chef/provider/service.rb +2 -2
- data/lib/chef/provider/yum_repository.rb +1 -1
- data/lib/chef/provider/zypper_repository.rb +1 -1
- data/lib/chef/resource.rb +2 -0
- data/lib/chef/resource/build_essential.rb +2 -2
- data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
- data/lib/chef/resource/chocolatey_feature.rb +1 -2
- data/lib/chef/resource/cron/cron_d.rb +1 -1
- data/lib/chef/resource/cron_access.rb +2 -2
- data/lib/chef/resource/execute.rb +2 -2
- data/lib/chef/resource/lwrp_base.rb +1 -0
- data/lib/chef/resource/macos_userdefaults.rb +176 -61
- data/lib/chef/resource/openssl_x509_certificate.rb +11 -14
- data/lib/chef/resource/openssl_x509_crl.rb +1 -2
- data/lib/chef/resource/service.rb +2 -2
- data/lib/chef/resource/ssh_known_hosts_entry.rb +1 -1
- data/lib/chef/resource/sudo.rb +1 -1
- data/lib/chef/resource/user_ulimit.rb +1 -1
- data/lib/chef/resource/windows_dns_record.rb +17 -0
- data/lib/chef/resource/windows_firewall_profile.rb +197 -0
- data/lib/chef/resource/windows_security_policy.rb +49 -20
- data/lib/chef/resource_inspector.rb +7 -1
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/role.rb +1 -2
- data/lib/chef/shell/shell_session.rb +2 -0
- data/lib/chef/util/diff.rb +0 -1
- data/lib/chef/version.rb +2 -2
- data/lib/chef/win32/registry.rb +1 -2
- data/spec/functional/knife/ssh_spec.rb +5 -16
- data/spec/functional/resource/aix_service_spec.rb +0 -2
- data/spec/functional/resource/aixinit_service_spec.rb +0 -1
- data/spec/functional/resource/apt_package_spec.rb +0 -1
- data/spec/functional/resource/cron_spec.rb +0 -1
- data/spec/functional/resource/git_spec.rb +23 -1
- data/spec/functional/resource/group_spec.rb +6 -2
- data/spec/functional/resource/insserv_spec.rb +0 -1
- data/spec/functional/resource/remote_file_spec.rb +1 -7
- data/spec/functional/resource/windows_user_privilege_spec.rb +1 -1
- data/spec/functional/run_lock_spec.rb +2 -1
- data/spec/functional/shell_spec.rb +5 -5
- data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/integration/knife/config_list_profiles_spec.rb +30 -2
- data/spec/integration/knife/cookbook_upload_spec.rb +27 -0
- data/spec/integration/recipes/accumulator_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_spec.rb +1 -1
- data/spec/integration/recipes/notifies_spec.rb +1 -1
- data/spec/integration/recipes/notifying_block_spec.rb +1 -1
- data/spec/integration/recipes/recipe_dsl_spec.rb +1 -1
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +2 -0
- data/spec/integration/recipes/resource_load_spec.rb +2 -0
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +1 -1
- data/spec/scripts/ssl-serve.rb +1 -1
- data/spec/spec_helper.rb +10 -4
- data/spec/support/chef_helpers.rb +1 -20
- data/spec/support/platform_helpers.rb +0 -2
- data/spec/support/shared/functional/file_resource.rb +0 -1
- data/spec/support/shared/integration/knife_support.rb +2 -9
- data/spec/support/shared/unit/application_dot_d.rb +0 -1
- data/spec/unit/application_spec.rb +4 -2
- data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +2 -4
- data/spec/unit/chef_fs/{parallelizer.rb → parallelizer_spec.rb} +1 -1
- data/spec/unit/cookbook/gem_installer_spec.rb +2 -1
- data/spec/unit/data_collector_spec.rb +1 -1
- data/spec/unit/dsl/platform_introspection_spec.rb +1 -0
- data/spec/unit/event_dispatch/dispatcher_spec.rb +3 -0
- data/spec/unit/json_compat_spec.rb +1 -1
- data/spec/unit/knife/bootstrap_spec.rb +2 -6
- data/spec/unit/knife/cookbook_upload_spec.rb +7 -10
- data/spec/unit/log/syslog_spec.rb +6 -10
- data/spec/unit/log/winevt_spec.rb +21 -13
- data/spec/unit/lwrp_spec.rb +4 -4
- data/spec/unit/mixin/{path_sanity_spec.rb → default_paths_spec.rb} +14 -14
- data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
- data/spec/unit/mixin/securable_spec.rb +0 -1
- data/spec/unit/mixin/shell_out_spec.rb +25 -26
- data/spec/unit/mixin/which.rb +8 -0
- data/spec/unit/node_spec.rb +98 -11
- data/spec/unit/property_spec.rb +5 -5
- data/spec/unit/provider/execute_spec.rb +0 -7
- data/spec/unit/provider/ifconfig_spec.rb +0 -1
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
- data/spec/unit/provider/package/rubygems_spec.rb +5 -10
- data/spec/unit/provider/package/smartos_spec.rb +1 -1
- data/spec/unit/provider/package/windows_spec.rb +30 -53
- data/spec/unit/provider/service/redhat_spec.rb +1 -1
- data/spec/unit/provider/service/windows_spec.rb +2 -6
- data/spec/unit/provider/systemd_unit_spec.rb +28 -24
- data/spec/unit/provider_spec.rb +1 -0
- data/spec/unit/resource/execute_spec.rb +10 -0
- data/spec/unit/resource/macos_user_defaults_spec.rb +103 -2
- data/spec/unit/resource/windows_firewall_profile_spec.rb +77 -0
- data/spec/unit/resource/windows_package_spec.rb +1 -0
- data/spec/unit/resource_reporter_spec.rb +1 -1
- data/spec/unit/run_context/cookbook_compiler_spec.rb +1 -1
- data/spec/unit/run_lock_spec.rb +1 -1
- data/spec/unit/scan_access_control_spec.rb +1 -1
- data/spec/unit/util/diff_spec.rb +1 -15
- data/spec/unit/win32/security_spec.rb +4 -3
- metadata +38 -15
@@ -23,7 +23,7 @@ describe "notifying_block" do
|
|
23
23
|
include IntegrationSupport
|
24
24
|
include Chef::Mixin::ShellOut
|
25
25
|
|
26
|
-
let(:chef_dir) { File.expand_path("
|
26
|
+
let(:chef_dir) { File.expand_path("../../../bin", __dir__) }
|
27
27
|
let(:chef_client) { "bundle exec chef-client --minimal-ohai" }
|
28
28
|
|
29
29
|
when_the_repository "notifying_block test one" do
|
@@ -1221,7 +1221,7 @@ describe "Recipe DSL methods" do
|
|
1221
1221
|
|
1222
1222
|
it "utf-8 dsl names work" do
|
1223
1223
|
recipe = converge do
|
1224
|
-
Straße("blah") {}
|
1224
|
+
Straße("blah") {} # rubocop: disable Naming/AsciiIdentifiers
|
1225
1225
|
end
|
1226
1226
|
expect(recipe.logged_warnings).to eq ""
|
1227
1227
|
expect(BaseThingy.created_resource).to eq(UTF8Thingy)
|
@@ -6,6 +6,7 @@ describe "Resource::ActionClass#converge_if_changed" do
|
|
6
6
|
module Namer
|
7
7
|
extend self
|
8
8
|
attr_accessor :current_index
|
9
|
+
|
9
10
|
def incrementing_value
|
10
11
|
@incrementing_value += 1
|
11
12
|
@incrementing_value
|
@@ -30,6 +31,7 @@ describe "Resource::ActionClass#converge_if_changed" do
|
|
30
31
|
property :state2, default: "default_state2"
|
31
32
|
property :sensitive1, default: "default_dontprintme", sensitive: true
|
32
33
|
attr_accessor :converged
|
34
|
+
|
33
35
|
def initialize(*args)
|
34
36
|
super
|
35
37
|
@converged = 0
|
@@ -6,6 +6,7 @@ describe "Resource.load_current_value" do
|
|
6
6
|
module Namer
|
7
7
|
extend self
|
8
8
|
attr_accessor :current_index
|
9
|
+
|
9
10
|
def incrementing_value
|
10
11
|
@incrementing_value += 1
|
11
12
|
@incrementing_value
|
@@ -194,6 +195,7 @@ describe "simple load_current_value tests" do
|
|
194
195
|
let(:resource_class) do
|
195
196
|
Class.new(Chef::Resource) do
|
196
197
|
attr_writer :index # this is our hacky global state
|
198
|
+
|
197
199
|
def index; @index ||= 1; end
|
198
200
|
|
199
201
|
property :myindex, Integer
|
@@ -6,7 +6,7 @@ describe "Unified Mode" do
|
|
6
6
|
include IntegrationSupport
|
7
7
|
include Chef::Mixin::ShellOut
|
8
8
|
|
9
|
-
let(:chef_dir) { File.expand_path("
|
9
|
+
let(:chef_dir) { File.expand_path("../../../bin", __dir__) }
|
10
10
|
|
11
11
|
let(:chef_client) { "bundle exec chef-client --minimal-ohai" }
|
12
12
|
|
@@ -22,7 +22,7 @@ describe "notifying_block" do
|
|
22
22
|
include IntegrationSupport
|
23
23
|
include Chef::Mixin::ShellOut
|
24
24
|
|
25
|
-
let(:chef_dir) { File.expand_path("
|
25
|
+
let(:chef_dir) { File.expand_path("../../../bin", __dir__) }
|
26
26
|
let(:chef_client) { "bundle exec chef-client --minimal-ohai" }
|
27
27
|
|
28
28
|
when_the_repository "has a cookbook with partial resources" do
|
data/spec/scripts/ssl-serve.rb
CHANGED
@@ -12,7 +12,7 @@ require "webrick/https"
|
|
12
12
|
|
13
13
|
$ssl = true
|
14
14
|
|
15
|
-
CHEF_SPEC_DATA = File.expand_path("
|
15
|
+
CHEF_SPEC_DATA = File.expand_path("../data", __dir__)
|
16
16
|
cert_text = File.read(File.expand_path("ssl/chef-rspec.cert", CHEF_SPEC_DATA))
|
17
17
|
cert = OpenSSL::X509::Certificate.new(cert_text)
|
18
18
|
key_text = File.read(File.expand_path("ssl/chef-rspec.key", CHEF_SPEC_DATA))
|
data/spec/spec_helper.rb
CHANGED
@@ -24,10 +24,10 @@ module Shell
|
|
24
24
|
IRB = nil unless defined? IRB
|
25
25
|
end
|
26
26
|
|
27
|
-
$LOAD_PATH.unshift File.expand_path("
|
27
|
+
$LOAD_PATH.unshift File.expand_path("..", __dir__)
|
28
28
|
|
29
|
-
$LOAD_PATH.unshift File.expand_path("
|
30
|
-
$LOAD_PATH.unshift File.expand_path("
|
29
|
+
$LOAD_PATH.unshift File.expand_path("../chef-config/lib", __dir__)
|
30
|
+
$LOAD_PATH.unshift File.expand_path("../chef-utils/lib", __dir__)
|
31
31
|
|
32
32
|
require "rubygems"
|
33
33
|
require "rspec/mocks"
|
@@ -116,6 +116,7 @@ RSpec.configure do |config|
|
|
116
116
|
config.include(MockShellout::RSpec)
|
117
117
|
config.filter_run focus: true
|
118
118
|
config.filter_run_excluding external: true
|
119
|
+
config.raise_on_warning = true
|
119
120
|
|
120
121
|
# Explicitly disable :should syntax
|
121
122
|
# And set max_formatted_output_length to nil to prevent RSpec from doing truncation.
|
@@ -125,6 +126,7 @@ RSpec.configure do |config|
|
|
125
126
|
end
|
126
127
|
config.mock_with :rspec do |c|
|
127
128
|
c.syntax = :expect
|
129
|
+
c.allow_message_expectations_on_nil = false
|
128
130
|
end
|
129
131
|
|
130
132
|
# Only run these tests on platforms that are also chef workstations
|
@@ -173,7 +175,6 @@ RSpec.configure do |config|
|
|
173
175
|
config.filter_run_excluding requires_root: true unless root?
|
174
176
|
config.filter_run_excluding requires_root_or_running_windows: true unless root? || windows?
|
175
177
|
config.filter_run_excluding requires_unprivileged_user: true if root?
|
176
|
-
config.filter_run_excluding uses_diff: true unless has_diff?
|
177
178
|
config.filter_run_excluding openssl_gte_101: true unless openssl_gte_101?
|
178
179
|
config.filter_run_excluding openssl_lt_101: true unless openssl_lt_101?
|
179
180
|
config.filter_run_excluding aes_256_gcm_only: true unless aes_256_gcm?
|
@@ -239,6 +240,11 @@ RSpec.configure do |config|
|
|
239
240
|
|
240
241
|
Chef::Config.reset
|
241
242
|
|
243
|
+
Chef::Log.setup!
|
244
|
+
|
245
|
+
Chef::Config[:log_level] = :fatal
|
246
|
+
Chef::Log.level(Chef::Config[:log_level])
|
247
|
+
|
242
248
|
# By default, treat deprecation warnings as errors in tests.
|
243
249
|
Chef::Config.treat_deprecation_warnings_as_errors(true)
|
244
250
|
|
@@ -18,14 +18,6 @@ CHEF_SPEC_DATA = File.expand_path(File.dirname(__FILE__) + "/../data/")
|
|
18
18
|
CHEF_SPEC_ASSETS = File.expand_path(File.dirname(__FILE__) + "/../functional/assets/")
|
19
19
|
CHEF_SPEC_BACKUP_PATH = File.join(Dir.tmpdir, "test-backup-path")
|
20
20
|
|
21
|
-
Chef::Config[:log_level] = :fatal
|
22
|
-
Chef::Config[:persistent_queue] = false
|
23
|
-
Chef::Config[:file_backup_path] = CHEF_SPEC_BACKUP_PATH
|
24
|
-
|
25
|
-
Chef::Log.init(StringIO.new)
|
26
|
-
Chef::Log.level(Chef::Config.log_level)
|
27
|
-
Chef::Config.solo(false)
|
28
|
-
|
29
21
|
def sha256_checksum(path)
|
30
22
|
OpenSSL::Digest.hexdigest("SHA256", File.read(path))
|
31
23
|
end
|
@@ -48,22 +40,11 @@ def make_tmpname(prefix_suffix, n = nil)
|
|
48
40
|
path << suffix
|
49
41
|
end
|
50
42
|
|
51
|
-
# NOTE:
|
52
|
-
# This is a temporary fix to get tests passing on systems that have no `diff`
|
53
|
-
# until we can replace shelling out to `diff` with ruby diff-lcs
|
54
|
-
def has_diff?
|
55
|
-
diff_cmd = Mixlib::ShellOut.new("diff -v")
|
56
|
-
diff_cmd.run_command
|
57
|
-
true
|
58
|
-
rescue Errno::ENOENT
|
59
|
-
false
|
60
|
-
end
|
61
|
-
|
62
43
|
# This is a helper to determine if the ruby in the PATH contains
|
63
44
|
# win32/service gem. windows_service_manager tests create a windows
|
64
45
|
# service that starts with the system ruby and requires this gem.
|
65
46
|
def system_windows_service_gem?
|
66
|
-
windows_service_gem_check_command = %{ruby -r "win32/daemon" -e ":noop" > #{
|
47
|
+
windows_service_gem_check_command = %{ruby -r "win32/daemon" -e ":noop" > #{File::NULL} 2>&1}
|
67
48
|
if defined?(Bundler)
|
68
49
|
Bundler.with_unbundled_env do
|
69
50
|
# This returns true if the gem can be loaded
|
@@ -193,8 +193,6 @@ def supports_cloexec?
|
|
193
193
|
Fcntl.const_defined?("F_SETFD") && Fcntl.const_defined?("FD_CLOEXEC")
|
194
194
|
end
|
195
195
|
|
196
|
-
DEV_NULL = windows? ? "NUL" : "/dev/null"
|
197
|
-
|
198
196
|
def selinux_enabled?
|
199
197
|
# This code is currently copied from lib/chef/util/selinux to make
|
200
198
|
# specs independent of product.
|
@@ -39,10 +39,7 @@ module KnifeSupport
|
|
39
39
|
|
40
40
|
# Work on machines where we can't access /var
|
41
41
|
Dir.mktmpdir("checksums") do |checksums_cache_dir|
|
42
|
-
Chef::Config[:
|
43
|
-
path: checksums_cache_dir,
|
44
|
-
skip_expires: true,
|
45
|
-
}
|
42
|
+
Chef::Config[:syntax_check_cache_path] = checksums_cache_dir
|
46
43
|
|
47
44
|
# This is Chef::Knife.run without load_commands--we'll load stuff
|
48
45
|
# ourselves, thank you very much
|
@@ -55,8 +52,6 @@ module KnifeSupport
|
|
55
52
|
STDIN
|
56
53
|
end
|
57
54
|
|
58
|
-
old_loggers = Chef::Log.loggers
|
59
|
-
old_log_level = Chef::Log.level
|
60
55
|
begin
|
61
56
|
puts "knife: #{args.join(" ")}" if DEBUG
|
62
57
|
subcommand_class = Chef::Knife.subcommand_class_from(args)
|
@@ -115,9 +110,7 @@ module KnifeSupport
|
|
115
110
|
rescue SystemExit => e
|
116
111
|
exit_code = e.status
|
117
112
|
ensure
|
118
|
-
Chef::
|
119
|
-
Chef::Log.level = old_log_level
|
120
|
-
Chef::Config.delete(:cache_options)
|
113
|
+
Chef::Config.delete(:syntax_check_cache_path)
|
121
114
|
Chef::Config.delete(:concurrency)
|
122
115
|
end
|
123
116
|
|
@@ -41,7 +41,6 @@ shared_examples_for "an application that loads a dot d" do
|
|
41
41
|
expect(IO).to receive(:read).with(Pathname.new("#{client_d_dir}/00-foo.rb").cleanpath.to_s).and_return("foo 0")
|
42
42
|
expect(IO).to receive(:read).with(Pathname.new("#{client_d_dir}/01-bar.rb").cleanpath.to_s).and_return("bar 0")
|
43
43
|
expect(IO).to receive(:read).with(Pathname.new("#{client_d_dir}/02-strings.rb").cleanpath.to_s).and_return("strings 0")
|
44
|
-
allow(app).to receive(:apply_config).with(anything, Chef::Config.platform_specific_path("/etc/chef/client.rb")).and_call_original.ordered
|
45
44
|
expect(app).to receive(:apply_config).with("foo 0", Pathname.new("#{client_d_dir}/00-foo.rb").cleanpath.to_s).and_call_original.ordered
|
46
45
|
expect(app).to receive(:apply_config).with("bar 0", Pathname.new("#{client_d_dir}/01-bar.rb").cleanpath.to_s).and_call_original.ordered
|
47
46
|
expect(app).to receive(:apply_config).with("strings 0", Pathname.new("#{client_d_dir}/02-strings.rb").cleanpath.to_s).and_call_original.ordered
|
@@ -22,12 +22,10 @@ describe Chef::Application do
|
|
22
22
|
before do
|
23
23
|
@original_argv = ARGV.dup
|
24
24
|
ARGV.clear
|
25
|
-
Chef::Log.logger = Logger.new(StringIO.new)
|
26
25
|
@app = Chef::Application.new
|
27
26
|
allow(@app).to receive(:trap)
|
28
27
|
allow(Dir).to receive(:chdir).and_return(0)
|
29
28
|
allow(@app).to receive(:reconfigure)
|
30
|
-
Chef::Log.init(STDERR)
|
31
29
|
end
|
32
30
|
|
33
31
|
after do
|
@@ -254,6 +252,10 @@ describe Chef::Application do
|
|
254
252
|
end
|
255
253
|
|
256
254
|
context "when log_level is not set" do
|
255
|
+
before do
|
256
|
+
Chef::Config.delete(:log_level)
|
257
|
+
end
|
258
|
+
|
257
259
|
it_behaves_like "log_level_is_auto"
|
258
260
|
end
|
259
261
|
|
@@ -25,11 +25,9 @@ describe Chef::ChefFS::FileSystem::OperationFailedError do
|
|
25
25
|
|
26
26
|
context "has a cause attribute and HTTP result code is 400" do
|
27
27
|
it "include error cause" do
|
28
|
-
allow_message_expectations_on_nil
|
29
28
|
response_body = '{"error":["Invalid key test in request body"]}'
|
30
|
-
|
31
|
-
|
32
|
-
exception = Net::HTTPClientException.new("(exception) unauthorized", @response)
|
29
|
+
response = double(:response, code: "400", body: response_body)
|
30
|
+
exception = Net::HTTPClientException.new("(exception) unauthorized", response)
|
33
31
|
expect do
|
34
32
|
raise Chef::ChefFS::FileSystem::OperationFailedError.new(:write, self, exception), error_message
|
35
33
|
end.to raise_error(Chef::ChefFS::FileSystem::OperationFailedError, "#{error_message} cause: #{response_body}")
|
@@ -95,7 +95,8 @@ describe Chef::Cookbook::GemInstaller do
|
|
95
95
|
|
96
96
|
it "skip metadata installation when Chef::Config[:skip_gem_metadata_installation] is set to true" do
|
97
97
|
Chef::Config[:skip_gem_metadata_installation] = true
|
98
|
-
expect(gem_installer
|
98
|
+
expect(gem_installer).to_not receive(:shell_out!)
|
99
|
+
expect(gem_installer.install).to be_nil
|
99
100
|
end
|
100
101
|
|
101
102
|
it "install metadata when Chef::Config[:skip_gem_metadata_installation] is not true" do
|
@@ -61,6 +61,7 @@ describe Chef::EventDispatch::Dispatcher do
|
|
61
61
|
let(:event_sink) do
|
62
62
|
Class.new(Chef::EventDispatch::Base) do
|
63
63
|
attr_reader :synchronized_cookbook_args
|
64
|
+
|
64
65
|
def synchronized_cookbook(cookbook_name)
|
65
66
|
@synchronized_cookbook_args = [cookbook_name]
|
66
67
|
end
|
@@ -79,6 +80,7 @@ describe Chef::EventDispatch::Dispatcher do
|
|
79
80
|
let(:event_sink_1) do
|
80
81
|
Class.new(Chef::EventDispatch::Base) do
|
81
82
|
attr_reader :synchronized_cookbook_args
|
83
|
+
|
82
84
|
def synchronized_cookbook(cookbook_name)
|
83
85
|
@synchronized_cookbook_args = [cookbook_name]
|
84
86
|
end
|
@@ -87,6 +89,7 @@ describe Chef::EventDispatch::Dispatcher do
|
|
87
89
|
let(:event_sink_2) do
|
88
90
|
Class.new(Chef::EventDispatch::Base) do
|
89
91
|
attr_reader :synchronized_cookbook_args
|
92
|
+
|
90
93
|
def synchronized_cookbook(cookbook_name, cookbook)
|
91
94
|
@synchronized_cookbook_args = [cookbook_name, cookbook]
|
92
95
|
end
|
@@ -1861,12 +1861,10 @@ describe Chef::Knife::Bootstrap do
|
|
1861
1861
|
let(:connection_protocol) { "ssh" }
|
1862
1862
|
|
1863
1863
|
it "warns, prompts for password, then reconnects with a password-enabled configuration using the new password" do
|
1864
|
-
question_mock = double("question")
|
1865
1864
|
expect(knife).to receive(:do_connect).and_raise(expected_error_password_prompt)
|
1866
1865
|
expect(knife.ui).to receive(:warn).with(/Failed to auth.*/)
|
1867
|
-
expect(knife.ui).to receive(:ask).
|
1866
|
+
expect(knife.ui).to receive(:ask).and_return("newpassword")
|
1868
1867
|
# Ensure that we set echo off to prevent showing password on the screen
|
1869
|
-
expect(question_mock).to receive(:echo=).with false
|
1870
1868
|
expect(knife).to receive(:do_connect) do |opts|
|
1871
1869
|
expect(opts[:password]).to eq "newpassword"
|
1872
1870
|
end
|
@@ -1878,12 +1876,10 @@ describe Chef::Knife::Bootstrap do
|
|
1878
1876
|
let(:connection_protocol) { "winrm" }
|
1879
1877
|
|
1880
1878
|
it "warns, prompts for password, then reconnects with a password-enabled configuration using the new password for" do
|
1881
|
-
question_mock = double("question")
|
1882
1879
|
expect(knife).to receive(:do_connect).and_raise(expected_error_password_prompt_winrm)
|
1883
1880
|
expect(knife.ui).to receive(:warn).with(/Failed to auth.*/)
|
1884
|
-
expect(knife.ui).to receive(:ask).
|
1881
|
+
expect(knife.ui).to receive(:ask).and_return("newpassword")
|
1885
1882
|
# Ensure that we set echo off to prevent showing password on the screen
|
1886
|
-
expect(question_mock).to receive(:echo=).with false
|
1887
1883
|
expect(knife).to receive(:do_connect) do |opts|
|
1888
1884
|
expect(opts[:password]).to eq "newpassword"
|
1889
1885
|
end
|
@@ -17,7 +17,7 @@
|
|
17
17
|
# limitations under the License.
|
18
18
|
#
|
19
19
|
|
20
|
-
require
|
20
|
+
require "spec_helper"
|
21
21
|
|
22
22
|
require "chef/cookbook_uploader"
|
23
23
|
require "timeout"
|
@@ -40,7 +40,6 @@ describe Chef::Knife::CookbookUpload do
|
|
40
40
|
allow(cookbook_loader).to receive(:load_cookbooks).and_return(cookbook_loader)
|
41
41
|
allow(cookbook_loader).to receive(:compile_metadata).and_return(nil)
|
42
42
|
allow(cookbook_loader).to receive(:freeze_versions).and_return(nil)
|
43
|
-
allow(cookbook_loader).to receive(:unlink!).and_return(nil)
|
44
43
|
cookbook_loader
|
45
44
|
end
|
46
45
|
|
@@ -60,7 +59,7 @@ describe Chef::Knife::CookbookUpload do
|
|
60
59
|
|
61
60
|
before(:each) do
|
62
61
|
allow(Chef::CookbookLoader).to receive(:new).and_return(cookbook_loader)
|
63
|
-
allow(Chef::CookbookLoader).to receive(:copy_to_tmp_dir_from_array).
|
62
|
+
allow(Chef::CookbookLoader).to receive(:copy_to_tmp_dir_from_array).and_yield(cookbook_loader)
|
64
63
|
end
|
65
64
|
|
66
65
|
describe "with --concurrency" do
|
@@ -70,7 +69,6 @@ describe Chef::Knife::CookbookUpload do
|
|
70
69
|
test_cookbook = Chef::CookbookVersion.new("test_cookbook", "/tmp/blah")
|
71
70
|
allow(cookbook_loader).to receive(:each).and_yield("test_cookbook", test_cookbook)
|
72
71
|
allow(cookbook_loader).to receive(:cookbook_names).and_return(["test_cookbook"])
|
73
|
-
allow(cookbook_loader).to receive(:tmp_working_dir_path).and_return("/tmp/blah")
|
74
72
|
expect(Chef::CookbookUploader).to receive(:new)
|
75
73
|
.with( kind_of(Array), { force: nil, concurrency: 3 })
|
76
74
|
.and_return(double("Chef::CookbookUploader", upload_cookbooks: true))
|
@@ -323,19 +321,18 @@ describe Chef::Knife::CookbookUpload do
|
|
323
321
|
|
324
322
|
context "when cookbook path is an array" do
|
325
323
|
it "should warn users that no cookbooks exist" do
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
)
|
324
|
+
cookbook_path = windows? ? "C:/chef-repo/cookbooks" : "/chef-repo/cookbooks"
|
325
|
+
knife.config[:cookbook_path] = [cookbook_path, "/home/user/cookbooks"]
|
326
|
+
expect(knife.ui).to receive(:warn).with("Could not find any cookbooks in your cookbook path: '#{knife.config[:cookbook_path].join(", ")}'. Use --cookbook-path to specify the desired path.")
|
330
327
|
knife.run
|
331
328
|
end
|
332
329
|
end
|
333
330
|
|
334
331
|
context "when cookbook path is a string" do
|
335
332
|
it "should warn users that no cookbooks exist" do
|
336
|
-
knife.config[:cookbook_path] = "/chef-repo/cookbooks"
|
333
|
+
knife.config[:cookbook_path] = windows? ? "C:/chef-repo/cookbooks" : "/chef-repo/cookbooks"
|
337
334
|
expect(knife.ui).to receive(:warn).with(
|
338
|
-
|
335
|
+
"Could not find any cookbooks in your cookbook path: '#{knife.config[:cookbook_path]}'. Use --cookbook-path to specify the desired path."
|
339
336
|
)
|
340
337
|
knife.run
|
341
338
|
end
|
@@ -23,25 +23,21 @@ describe "Chef::Log::Syslog", unix_only: true do
|
|
23
23
|
|
24
24
|
before do
|
25
25
|
Chef::Log.init(MonoLogger.new(syslog))
|
26
|
-
@old_log_level = Chef::Log.level
|
27
26
|
Chef::Log.level = :info
|
28
|
-
@old_loggers = Chef::Log.loggers
|
29
|
-
Chef::Log.use_log_devices([syslog])
|
30
|
-
end
|
31
|
-
|
32
|
-
after do
|
33
|
-
Chef::Log.level = @old_log_level
|
34
|
-
Chef::Log.use_log_devices(@old_loggers)
|
35
27
|
end
|
36
28
|
|
37
29
|
it "should send message with severity info to syslog." do
|
38
30
|
expect(syslog).to receive(:add).with(1, "*** Chef 12.4.0.dev.0 ***", nil)
|
39
|
-
|
31
|
+
expect {
|
32
|
+
Chef::Log.info("*** Chef 12.4.0.dev.0 ***")
|
33
|
+
}.not_to output.to_stderr
|
40
34
|
end
|
41
35
|
|
42
36
|
it "should send message with severity warning to syslog." do
|
43
37
|
expect(syslog).to receive(:add).with(2, "No config file found or specified on command line. Using command line options instead.", nil)
|
44
|
-
|
38
|
+
expect {
|
39
|
+
Chef::Log.warn("No config file found or specified on command line. Using command line options instead.")
|
40
|
+
}.not_to output.to_stderr
|
45
41
|
end
|
46
42
|
|
47
43
|
it "should fallback into send message with severity info to syslog when wrong format." do
|