chef 16.3.45-universal-mingw32 → 16.5.77-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 +1 -1
- data/Rakefile +2 -2
- data/bin/knife +1 -1
- data/chef-universal-mingw32.gemspec +0 -1
- data/chef.gemspec +2 -1
- data/distro/templates/powershell/chef/chef.psm1.erb +18 -18
- data/ext/win32-eventlog/Rakefile +2 -2
- data/ext/win32-eventlog/chef-log.man.erb +4 -4
- data/lib/chef/action_collection.rb +4 -0
- data/lib/chef/api_client/registration.rb +2 -2
- data/lib/chef/application.rb +20 -18
- data/lib/chef/application/apply.rb +17 -12
- data/lib/chef/application/base.rb +26 -23
- data/lib/chef/application/client.rb +10 -4
- data/lib/chef/application/exit_code.rb +13 -4
- data/lib/chef/application/knife.rb +22 -11
- data/lib/chef/application/solo.rb +2 -1
- data/lib/chef/application/windows_service.rb +39 -39
- data/lib/chef/application/windows_service_manager.rb +6 -6
- data/lib/chef/chef_class.rb +0 -1
- data/lib/chef/chef_fs/chef_fs_data_store.rb +55 -55
- data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
- data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
- data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +2 -2
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
- data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
- data/lib/chef/chef_fs/knife.rb +2 -2
- data/lib/chef/chef_fs/parallelizer.rb +0 -1
- data/lib/chef/client.rb +21 -22
- data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
- data/lib/chef/cookbook/gem_installer.rb +1 -1
- data/lib/chef/cookbook/synchronizer.rb +2 -2
- data/lib/chef/cookbook_site_streaming_uploader.rb +13 -11
- data/lib/chef/cookbook_uploader.rb +1 -1
- data/lib/chef/data_collector.rb +6 -5
- data/lib/chef/data_collector/config_validation.rb +22 -13
- data/lib/chef/data_collector/run_end_message.rb +13 -3
- data/lib/chef/data_collector/run_start_message.rb +1 -1
- data/lib/chef/deprecated.rb +1 -1
- data/lib/chef/deprecation/warnings.rb +2 -2
- data/lib/chef/digester.rb +2 -2
- data/lib/chef/dsl/chef_vault.rb +1 -1
- data/lib/chef/dsl/data_query.rb +2 -2
- data/lib/chef/dsl/platform_introspection.rb +9 -9
- data/lib/chef/encrypted_data_bag_item.rb +3 -4
- data/lib/chef/encrypted_data_bag_item/decryptor.rb +3 -3
- data/lib/chef/encrypted_data_bag_item/encryptor.rb +3 -3
- data/lib/chef/environment.rb +4 -4
- data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
- data/lib/chef/exceptions.rb +5 -5
- data/lib/chef/file_access_control/windows.rb +5 -1
- data/lib/chef/file_content_management/tempfile.rb +10 -10
- data/lib/chef/formatters/doc.rb +7 -6
- data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +6 -5
- data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +3 -3
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +9 -9
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +2 -2
- data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +3 -3
- data/lib/chef/formatters/indentable_output_stream.rb +2 -2
- data/lib/chef/formatters/minimal.rb +5 -4
- data/lib/chef/http.rb +6 -3
- data/lib/chef/http/auth_credentials.rb +5 -1
- data/lib/chef/http/authenticator.rb +1 -1
- data/lib/chef/http/basic_client.rb +4 -2
- data/lib/chef/http/decompressor.rb +1 -1
- data/lib/chef/http/http_request.rb +7 -5
- data/lib/chef/http/socketless_chef_zero_client.rb +5 -2
- data/lib/chef/http/ssl_policies.rb +1 -1
- data/lib/chef/json_compat.rb +2 -2
- data/lib/chef/knife.rb +4 -4
- data/lib/chef/knife/bootstrap.rb +18 -16
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +3 -3
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +7 -7
- data/lib/chef/knife/client_create.rb +3 -3
- data/lib/chef/knife/config_get.rb +8 -97
- data/lib/chef/knife/config_get_profile.rb +9 -9
- data/lib/chef/knife/config_list.rb +139 -0
- data/lib/chef/knife/config_list_profiles.rb +8 -98
- data/lib/chef/knife/config_show.rb +127 -0
- data/lib/chef/knife/config_use.rb +61 -0
- data/lib/chef/knife/config_use_profile.rb +9 -24
- data/lib/chef/knife/configure.rb +4 -2
- data/lib/chef/knife/cookbook_download.rb +1 -1
- data/lib/chef/knife/cookbook_metadata.rb +1 -1
- data/lib/chef/knife/cookbook_upload.rb +23 -23
- data/lib/chef/knife/core/bootstrap_context.rb +2 -2
- data/lib/chef/knife/core/generic_presenter.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +2 -2
- data/lib/chef/knife/core/object_loader.rb +1 -1
- data/lib/chef/knife/core/ui.rb +1 -1
- data/lib/chef/knife/core/windows_bootstrap_context.rb +42 -34
- data/lib/chef/knife/delete.rb +15 -15
- data/lib/chef/knife/exec.rb +4 -4
- data/lib/chef/knife/node_policy_set.rb +2 -2
- data/lib/chef/knife/node_run_list_add.rb +1 -1
- data/lib/chef/knife/node_run_list_remove.rb +1 -1
- data/lib/chef/knife/node_run_list_set.rb +1 -1
- data/lib/chef/knife/node_show.rb +2 -2
- data/lib/chef/knife/role_env_run_list_add.rb +1 -1
- data/lib/chef/knife/role_env_run_list_set.rb +1 -1
- data/lib/chef/knife/role_run_list_add.rb +1 -1
- data/lib/chef/knife/role_run_list_set.rb +1 -1
- data/lib/chef/knife/search.rb +0 -1
- data/lib/chef/knife/serve.rb +3 -3
- data/lib/chef/knife/ssh.rb +24 -9
- data/lib/chef/knife/ssl_check.rb +3 -3
- data/lib/chef/knife/status.rb +2 -2
- data/lib/chef/knife/tag_create.rb +1 -1
- data/lib/chef/knife/tag_delete.rb +1 -1
- data/lib/chef/knife/user_create.rb +2 -2
- data/lib/chef/knife/xargs.rb +19 -19
- data/lib/chef/knife/yaml_convert.rb +1 -1
- data/lib/chef/local_mode.rb +2 -2
- data/lib/chef/log/syslog.rb +2 -2
- data/lib/chef/log/winevt.rb +2 -2
- data/lib/chef/mixin/checksum.rb +0 -1
- data/lib/chef/mixin/deep_merge.rb +35 -18
- data/lib/chef/mixin/openssl_helper.rb +4 -5
- data/lib/chef/mixin/shell_out.rb +1 -1
- data/lib/chef/mixin/template.rb +3 -3
- data/lib/chef/mixin/uris.rb +4 -2
- data/lib/chef/mixin/versioned_api.rb +1 -2
- data/lib/chef/mixin/which.rb +1 -1
- data/lib/chef/monkey_patches/net_http.rb +4 -4
- data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
- data/lib/chef/node/attribute.rb +2 -4
- data/lib/chef/node_map.rb +4 -4
- data/lib/chef/platform/service_helpers.rb +1 -1
- data/lib/chef/policy_builder/dynamic.rb +2 -0
- data/lib/chef/policy_builder/policyfile.rb +2 -2
- data/lib/chef/property.rb +1 -1
- data/lib/chef/provider.rb +1 -5
- data/lib/chef/provider/cron/unix.rb +0 -2
- data/lib/chef/provider/file.rb +2 -2
- data/lib/chef/provider/git.rb +5 -5
- data/lib/chef/provider/group.rb +0 -2
- data/lib/chef/provider/group/suse.rb +5 -5
- data/lib/chef/provider/ifconfig.rb +1 -4
- data/lib/chef/provider/launchd.rb +2 -2
- data/lib/chef/provider/link.rb +0 -9
- data/lib/chef/provider/mount.rb +0 -2
- data/lib/chef/provider/mount/linux.rb +63 -0
- data/lib/chef/provider/package.rb +0 -2
- data/lib/chef/provider/package/dpkg.rb +3 -12
- data/lib/chef/provider/package/homebrew.rb +1 -1
- data/lib/chef/provider/package/rubygems.rb +22 -19
- data/lib/chef/provider/package/snap.rb +1 -2
- data/lib/chef/provider/package/windows.rb +2 -2
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +12 -10
- data/lib/chef/provider/package/zypper.rb +1 -1
- data/lib/chef/provider/powershell_script.rb +21 -5
- data/lib/chef/provider/remote_file/content.rb +3 -0
- data/lib/chef/provider/remote_file/ftp.rb +6 -4
- data/lib/chef/provider/remote_file/sftp.rb +6 -4
- data/lib/chef/provider/route.rb +2 -6
- data/lib/chef/provider/service/arch.rb +1 -1
- data/lib/chef/provider/service/debian.rb +1 -1
- data/lib/chef/provider/service/gentoo.rb +2 -2
- data/lib/chef/provider/service/macosx.rb +4 -4
- data/lib/chef/provider/service/openbsd.rb +1 -4
- data/lib/chef/provider/service/redhat.rb +3 -3
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +10 -10
- data/lib/chef/provider/systemd_unit.rb +0 -2
- data/lib/chef/provider/template/content.rb +1 -0
- data/lib/chef/provider/template_finder.rb +2 -10
- data/lib/chef/provider/user/dscl.rb +7 -7
- data/lib/chef/provider/user/mac.rb +12 -12
- data/lib/chef/provider/windows_task.rb +1 -5
- data/lib/chef/provider/zypper_repository.rb +2 -3
- data/lib/chef/provider_resolver.rb +1 -1
- data/lib/chef/providers.rb +1 -1
- data/lib/chef/recipe.rb +2 -2
- data/lib/chef/resource.rb +8 -12
- data/lib/chef/resource/apt_repository.rb +5 -12
- data/lib/chef/resource/bff_package.rb +22 -0
- data/lib/chef/resource/breakpoint.rb +57 -2
- data/lib/chef/resource/build_essential.rb +1 -1
- data/lib/chef/resource/cab_package.rb +29 -0
- data/lib/chef/resource/chef_client_cron.rb +32 -25
- data/lib/chef/resource/chef_client_launchd.rb +194 -0
- data/lib/chef/resource/chef_client_scheduled_task.rb +21 -18
- data/lib/chef/resource/chef_client_systemd_timer.rb +26 -19
- data/lib/chef/resource/chef_client_trusted_certificate.rb +101 -0
- data/lib/chef/resource/chef_gem.rb +10 -10
- data/lib/chef/resource/chef_handler.rb +149 -4
- data/lib/chef/resource/chef_sleep.rb +2 -2
- data/lib/chef/resource/chef_vault_secret.rb +14 -14
- data/lib/chef/resource/cookbook_file.rb +2 -2
- data/lib/chef/resource/cron/_cron_shared.rb +1 -0
- data/lib/chef/resource/cron/cron_d.rb +0 -1
- data/lib/chef/resource/dnf_package.rb +2 -2
- data/lib/chef/resource/dsc_resource.rb +0 -1
- data/lib/chef/resource/dsc_script.rb +2 -2
- data/lib/chef/resource/execute.rb +8 -9
- data/lib/chef/resource/file.rb +4 -4
- data/lib/chef/resource/gem_package.rb +5 -5
- data/lib/chef/resource/homebrew_package.rb +3 -3
- data/lib/chef/resource/homebrew_update.rb +7 -7
- data/lib/chef/resource/hostname.rb +2 -2
- data/lib/chef/resource/launchd.rb +2 -1
- data/lib/chef/resource/locale.rb +2 -2
- data/lib/chef/resource/macos_userdefaults.rb +3 -3
- data/lib/chef/resource/notify_group.rb +0 -1
- data/lib/chef/resource/ohai.rb +46 -3
- data/lib/chef/resource/ohai_hint.rb +33 -0
- data/lib/chef/resource/openssl_dhparam.rb +29 -5
- data/lib/chef/resource/openssl_ec_private_key.rb +8 -3
- data/lib/chef/resource/openssl_ec_public_key.rb +4 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +8 -3
- data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
- data/lib/chef/resource/openssl_x509_certificate.rb +38 -35
- data/lib/chef/resource/openssl_x509_crl.rb +21 -10
- data/lib/chef/resource/openssl_x509_request.rb +37 -36
- data/lib/chef/resource/osx_profile.rb +292 -6
- data/lib/chef/resource/plist.rb +1 -1
- data/lib/chef/resource/powershell_package_source.rb +6 -6
- data/lib/chef/resource/powershell_script.rb +24 -30
- data/lib/chef/resource/reboot.rb +2 -2
- data/lib/chef/resource/remote_file.rb +3 -3
- data/lib/chef/resource/rhsm_register.rb +22 -10
- data/lib/chef/resource/ruby_block.rb +2 -2
- data/lib/chef/resource/scm/subversion.rb +2 -2
- data/lib/chef/resource/service.rb +3 -3
- data/lib/chef/resource/ssh_known_hosts_entry.rb +2 -2
- data/lib/chef/resource/sudo.rb +1 -1
- data/lib/chef/resource/support/cron.d.erb +1 -1
- data/lib/chef/resource/support/cron_access.erb +1 -1
- data/lib/chef/resource/support/sudoer.erb +1 -1
- data/lib/chef/resource/support/ulimit.erb +1 -1
- data/lib/chef/resource/sysctl.rb +6 -10
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/template.rb +2 -2
- data/lib/chef/resource/timezone.rb +112 -73
- data/lib/chef/resource/windows_ad_join.rb +12 -3
- data/lib/chef/resource/windows_audit_policy.rb +3 -0
- data/lib/chef/resource/windows_auto_run.rb +2 -0
- data/lib/chef/resource/windows_certificate.rb +8 -4
- data/lib/chef/resource/windows_dfs_folder.rb +2 -0
- data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
- data/lib/chef/resource/windows_dfs_server.rb +2 -0
- data/lib/chef/resource/windows_dns_record.rb +10 -7
- data/lib/chef/resource/windows_dns_zone.rb +12 -7
- data/lib/chef/resource/windows_feature.rb +2 -0
- data/lib/chef/resource/windows_feature_dism.rb +10 -0
- data/lib/chef/resource/windows_feature_powershell.rb +14 -2
- data/lib/chef/resource/windows_firewall_profile.rb +24 -20
- data/lib/chef/resource/windows_firewall_rule.rb +5 -3
- data/lib/chef/resource/windows_font.rb +3 -1
- data/lib/chef/resource/windows_package.rb +28 -5
- data/lib/chef/resource/windows_pagefile.rb +4 -0
- data/lib/chef/resource/windows_printer.rb +22 -21
- data/lib/chef/resource/windows_printer_port.rb +20 -17
- data/lib/chef/resource/windows_security_policy.rb +2 -0
- data/lib/chef/resource/windows_share.rb +5 -3
- data/lib/chef/resource/windows_shortcut.rb +2 -0
- data/lib/chef/resource/windows_uac.rb +2 -0
- data/lib/chef/resource/windows_user_privilege.rb +54 -53
- data/lib/chef/resource/windows_workgroup.rb +5 -6
- data/lib/chef/resource/yum_package.rb +2 -2
- data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
- data/lib/chef/resource_reporter.rb +0 -2
- data/lib/chef/resources.rb +3 -1
- data/lib/chef/role.rb +2 -2
- data/lib/chef/run_context.rb +2 -2
- data/lib/chef/run_context/cookbook_compiler.rb +21 -21
- data/lib/chef/run_lock.rb +2 -2
- data/lib/chef/run_status.rb +2 -6
- data/lib/chef/search/query.rb +6 -5
- data/lib/chef/shell.rb +32 -27
- data/lib/chef/shell/ext.rb +11 -11
- data/lib/chef/shell/shell_session.rb +2 -2
- data/lib/chef/train_transport.rb +5 -104
- data/lib/chef/util/backup.rb +2 -2
- data/lib/chef/util/diff.rb +14 -14
- data/lib/chef/util/powershell/cmdlet.rb +4 -2
- data/lib/chef/util/powershell/ps_credential.rb +18 -14
- data/lib/chef/util/threaded_job_queue.rb +0 -2
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/crypto.rb +1 -1
- data/lib/chef/win32/file.rb +3 -3
- data/lib/chef/win32/file/version_info.rb +5 -5
- data/lib/chef/win32/registry.rb +1 -2
- data/lib/chef/win32/unicode.rb +1 -1
- data/spec/data/shef-config.rb +1 -1
- data/spec/data/ssl/chef-rspec.cert +15 -15
- data/spec/functional/event_loggers/windows_eventlog_spec.rb +6 -5
- data/spec/functional/resource/aix_service_spec.rb +2 -2
- data/spec/functional/resource/aixinit_service_spec.rb +8 -8
- data/spec/functional/resource/bff_spec.rb +2 -2
- data/spec/functional/resource/cookbook_file_spec.rb +1 -1
- data/spec/functional/resource/dsc_resource_spec.rb +1 -1
- data/spec/functional/resource/dsc_script_spec.rb +0 -1
- data/spec/functional/resource/group_spec.rb +6 -6
- data/spec/functional/resource/insserv_spec.rb +5 -5
- data/spec/functional/resource/link_spec.rb +20 -20
- data/spec/functional/resource/powershell_script_spec.rb +4 -4
- data/spec/functional/resource/rpm_spec.rb +2 -2
- data/spec/functional/resource/user/dscl_spec.rb +1 -1
- data/spec/functional/resource/user/mac_user_spec.rb +1 -1
- data/spec/functional/resource/windows_certificate_spec.rb +3 -3
- data/spec/functional/resource/windows_font_spec.rb +49 -0
- data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
- data/spec/functional/resource/windows_task_spec.rb +13 -13
- data/spec/functional/run_lock_spec.rb +24 -24
- data/spec/functional/version_spec.rb +3 -3
- data/spec/functional/win32/registry_spec.rb +8 -8
- data/spec/functional/win32/service_manager_spec.rb +1 -1
- data/spec/integration/client/client_spec.rb +4 -4
- data/spec/integration/client/exit_code_spec.rb +3 -2
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/knife/common_options_spec.rb +12 -12
- data/spec/integration/knife/config_list_spec.rb +220 -0
- data/spec/integration/knife/config_show_spec.rb +192 -0
- data/spec/integration/knife/config_use_spec.rb +198 -0
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
- data/spec/integration/knife/diff_spec.rb +3 -1
- data/spec/integration/knife/download_spec.rb +3 -1
- data/spec/integration/knife/serve_spec.rb +5 -5
- data/spec/integration/knife/upload_spec.rb +3 -1
- data/spec/integration/ohai/ohai_spec.rb +61 -0
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/recipes/remote_directory.rb +1 -1
- data/spec/integration/solo/solo_spec.rb +5 -5
- data/spec/spec_helper.rb +12 -11
- data/spec/stress/win32/file_spec.rb +1 -1
- data/spec/support/chef_helpers.rb +2 -2
- data/spec/support/matchers/leak.rb +2 -2
- data/spec/support/platform_helpers.rb +17 -35
- data/spec/support/platforms/win32/spec_service.rb +1 -1
- data/spec/support/shared/functional/directory_resource.rb +1 -1
- data/spec/support/shared/functional/execute_resource.rb +1 -1
- data/spec/support/shared/functional/file_resource.rb +20 -20
- data/spec/support/shared/functional/securable_resource.rb +108 -27
- data/spec/support/shared/functional/win32_service.rb +2 -2
- data/spec/support/shared/functional/windows_script.rb +3 -3
- data/spec/support/shared/integration/integration_helper.rb +22 -52
- data/spec/support/shared/unit/application_dot_d.rb +5 -3
- data/spec/support/shared/unit/script_resource.rb +6 -20
- data/spec/support/shared/unit/windows_script_resource.rb +15 -28
- data/spec/tiny_server.rb +0 -1
- data/spec/unit/application/client_spec.rb +2 -2
- data/spec/unit/application/exit_code_spec.rb +10 -0
- data/spec/unit/application_spec.rb +4 -6
- data/spec/unit/chef_fs/config_spec.rb +1 -1
- data/spec/unit/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
- data/spec/unit/chef_fs/parallelizer_spec.rb +5 -1
- data/spec/unit/chef_fs/path_util_spec.rb +1 -1
- data/spec/unit/cookbook/synchronizer_spec.rb +2 -2
- data/spec/unit/cookbook_spec.rb +2 -2
- data/spec/unit/data_collector/config_validation_spec.rb +208 -0
- data/spec/unit/data_collector_spec.rb +28 -117
- data/spec/unit/dsl/declare_resource_spec.rb +1 -1
- data/spec/unit/environment_spec.rb +7 -7
- data/spec/unit/file_access_control_spec.rb +1 -1
- data/spec/unit/knife/bootstrap_spec.rb +20 -20
- data/spec/unit/knife/cookbook_download_spec.rb +4 -4
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
- data/spec/unit/knife/core/ui_spec.rb +1 -0
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
- data/spec/unit/knife/ssh_spec.rb +2 -2
- data/spec/unit/knife/supermarket_share_spec.rb +1 -1
- data/spec/unit/lwrp_spec.rb +3 -3
- data/spec/unit/mixin/deep_merge_spec.rb +15 -0
- data/spec/unit/mixin/openssl_helper_spec.rb +1 -1
- data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
- data/spec/unit/mixin/securable_spec.rb +2 -2
- data/spec/unit/mixin/template_spec.rb +30 -30
- data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
- data/spec/unit/node/immutable_collections_spec.rb +8 -4
- data/spec/unit/node_spec.rb +5 -5
- data/spec/unit/provider/mount/linux_spec.rb +97 -0
- data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
- data/spec/unit/provider/package/powershell_spec.rb +1 -1
- data/spec/unit/provider/package/rubygems_spec.rb +4 -1
- data/spec/unit/provider/powershell_script_spec.rb +11 -4
- data/spec/unit/provider/remote_directory_spec.rb +9 -9
- data/spec/unit/provider/route_spec.rb +0 -2
- data/spec/unit/provider/service/arch_service_spec.rb +3 -2
- data/spec/unit/provider/service/debian_service_spec.rb +1 -1
- data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
- data/spec/unit/provider/service/macosx_spec.rb +3 -3
- data/spec/unit/provider/service/redhat_spec.rb +2 -2
- data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
- data/spec/unit/provider_resolver_spec.rb +6 -6
- data/spec/unit/recipe_spec.rb +1 -1
- data/spec/unit/resource/batch_spec.rb +6 -6
- data/spec/unit/resource/chef_client_cron_spec.rb +35 -14
- data/spec/unit/resource/chef_client_launchd_spec.rb +127 -0
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +36 -1
- data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +54 -0
- data/spec/unit/resource/execute_spec.rb +113 -118
- data/spec/unit/resource/launchd_spec.rb +8 -0
- data/spec/unit/resource/osx_profile_spec.rb +299 -0
- data/spec/unit/resource/powershell_script_spec.rb +11 -29
- data/spec/unit/resource/rhsm_register_spec.rb +56 -18
- data/spec/unit/resource/script_spec.rb +6 -1
- data/spec/unit/resource/timezone_spec.rb +63 -0
- data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
- data/spec/unit/resource/windows_uac_spec.rb +1 -1
- data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
- data/spec/unit/role_spec.rb +11 -11
- data/spec/unit/run_lock_spec.rb +5 -1
- data/spec/unit/runner_spec.rb +1 -2
- data/spec/unit/shell/shell_ext_spec.rb +46 -3
- data/spec/unit/shell/shell_session_spec.rb +35 -64
- data/spec/unit/shell_spec.rb +16 -19
- data/spec/unit/train_transport_spec.rb +14 -13
- data/spec/unit/util/selinux_spec.rb +2 -0
- data/tasks/rspec.rb +1 -3
- metadata +42 -33
- data/lib/chef/dist.rb +0 -68
- data/lib/chef/provider/osx_profile.rb +0 -255
- data/spec/integration/knife/config_get_profile_spec.rb +0 -113
- data/spec/integration/knife/config_get_spec.rb +0 -191
- data/spec/integration/knife/config_list_profiles_spec.rb +0 -218
- data/spec/integration/knife/config_use_profile_spec.rb +0 -154
- data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -16,6 +16,7 @@
|
|
16
16
|
#
|
17
17
|
|
18
18
|
require "uri" unless defined?(URI)
|
19
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
19
20
|
|
20
21
|
class Chef
|
21
22
|
class DataCollector
|
@@ -46,14 +47,14 @@ class Chef
|
|
46
47
|
return unless output_locations
|
47
48
|
|
48
49
|
# but deliberately setting an empty output_location we consider to be an error (XXX: but should we?)
|
49
|
-
|
50
|
+
unless valid_hash_with_keys?(output_locations, :urls, :files)
|
50
51
|
raise Chef::Exceptions::ConfigurationError,
|
51
52
|
"Chef::Config[:data_collector][:output_locations] is empty. Please supply an hash of valid URLs and / or local file paths."
|
52
53
|
end
|
53
54
|
|
54
55
|
# loop through all the types and locations and validate each one-by-one
|
55
56
|
output_locations.each do |type, locations|
|
56
|
-
locations.each do |location|
|
57
|
+
Array(locations).each do |location|
|
57
58
|
validate_url!(location) if type == :urls
|
58
59
|
validate_file!(location) if type == :files
|
59
60
|
end
|
@@ -86,15 +87,20 @@ class Chef
|
|
86
87
|
false
|
87
88
|
when running_mode == :client && Chef::Config[:data_collector][:token]
|
88
89
|
Chef::Log.warn("Data collector token authentication is not recommended for client-server mode. " \
|
89
|
-
"Please upgrade #{
|
90
|
+
"Please upgrade #{ChefUtils::Dist::Server::PRODUCT} to 12.11 or later and remove the token from your config file " \
|
90
91
|
"to use key based authentication instead")
|
91
92
|
true
|
92
|
-
when Chef::Config[:data_collector][:output_locations] && Chef::Config[:data_collector][:output_locations]
|
93
|
+
when Chef::Config[:data_collector][:output_locations] && !valid_hash_with_keys?(Chef::Config[:data_collector][:output_locations], :urls)
|
93
94
|
# we can run fine to a file without a token, even in solo mode.
|
95
|
+
unless valid_hash_with_keys?(Chef::Config[:data_collector][:output_locations], :files)
|
96
|
+
raise Chef::Exceptions::ConfigurationError,
|
97
|
+
"Chef::Config[:data_collector][:output_locations] is empty. Please supply an hash of valid URLs and / or local file paths."
|
98
|
+
end
|
99
|
+
|
94
100
|
true
|
95
101
|
when running_mode == :solo && !Chef::Config[:data_collector][:token]
|
96
102
|
# we are in solo mode and are not logging to a file, so must have a token
|
97
|
-
Chef::Log.trace("Data collector token must be configured to use #{
|
103
|
+
Chef::Log.trace("Data collector token must be configured to use #{ChefUtils::Dist::Automate::PRODUCT} data collector with #{ChefUtils::Dist::Solo::PRODUCT}")
|
98
104
|
false
|
99
105
|
else
|
100
106
|
true
|
@@ -105,16 +111,10 @@ class Chef
|
|
105
111
|
|
106
112
|
# validate an output_location file
|
107
113
|
def validate_file!(file)
|
108
|
-
|
109
|
-
|
114
|
+
return true if Chef::Config.path_accessible?(File.expand_path(file))
|
115
|
+
|
110
116
|
raise Chef::Exceptions::ConfigurationError,
|
111
117
|
"Chef::Config[:data_collector][:output_locations][:files] contains the location #{file}, which is a non existent file path."
|
112
|
-
rescue Errno::EACCES
|
113
|
-
raise Chef::Exceptions::ConfigurationError,
|
114
|
-
"Chef::Config[:data_collector][:output_locations][:files] contains the location #{file}, which cannot be written to by Chef."
|
115
|
-
rescue Exception => e
|
116
|
-
raise Chef::Exceptions::ConfigurationError,
|
117
|
-
"Chef::Config[:data_collector][:output_locations][:files] contains the location #{file}, which is invalid: #{e.message}."
|
118
118
|
end
|
119
119
|
|
120
120
|
# validate an output_location url
|
@@ -125,6 +125,15 @@ class Chef
|
|
125
125
|
"Chef::Config[:data_collector][:output_locations][:urls] contains the url #{url} which is not valid."
|
126
126
|
end
|
127
127
|
|
128
|
+
# Validate the hash contains at least one of the given keys.
|
129
|
+
#
|
130
|
+
# @param hash [Hash] the hash to be validated.
|
131
|
+
# @param keys [Array] an array of keys to check existence of in the hash.
|
132
|
+
# @return [Boolean] true if the hash contains any of the given keys.
|
133
|
+
#
|
134
|
+
def valid_hash_with_keys?(hash, *keys)
|
135
|
+
hash.is_a?(Hash) && keys.any? { |k| hash.key?(k) }
|
136
|
+
end
|
128
137
|
end
|
129
138
|
end
|
130
139
|
end
|
@@ -60,8 +60,8 @@ class Chef
|
|
60
60
|
"cookbooks" => ( node && node["cookbooks"] ) || {},
|
61
61
|
"policy_name" => node&.policy_name,
|
62
62
|
"policy_group" => node&.policy_group,
|
63
|
-
"start_time" => run_status
|
64
|
-
"end_time" => run_status
|
63
|
+
"start_time" => run_status&.start_time&.utc&.iso8601,
|
64
|
+
"end_time" => run_status&.end_time&.utc&.iso8601,
|
65
65
|
"source" => solo_run? ? "chef_solo" : "chef_client",
|
66
66
|
"status" => status,
|
67
67
|
"total_resource_count" => all_action_records(action_collection).count,
|
@@ -133,7 +133,17 @@ class Chef
|
|
133
133
|
end
|
134
134
|
|
135
135
|
hash["conditional"] = action_record.conditional.to_text if action_record.status == :skipped
|
136
|
-
|
136
|
+
|
137
|
+
unless action_record.exception.nil?
|
138
|
+
hash["error_message"] = action_record.exception.message
|
139
|
+
|
140
|
+
hash["error"] = {
|
141
|
+
"class" => action_record.exception.class,
|
142
|
+
"message" => action_record.exception.message,
|
143
|
+
"backtrace" => action_record.exception.backtrace,
|
144
|
+
"description" => action_record.error_description,
|
145
|
+
}
|
146
|
+
end
|
137
147
|
|
138
148
|
hash
|
139
149
|
end
|
@@ -51,7 +51,7 @@ class Chef
|
|
51
51
|
"organization_name" => organization,
|
52
52
|
"run_id" => run_status&.run_id,
|
53
53
|
"source" => solo_run? ? "chef_solo" : "chef_client",
|
54
|
-
"start_time" => run_status
|
54
|
+
"start_time" => run_status&.start_time&.utc&.iso8601,
|
55
55
|
}
|
56
56
|
end
|
57
57
|
end
|
data/lib/chef/deprecated.rb
CHANGED
@@ -21,12 +21,12 @@ class Chef
|
|
21
21
|
module Warnings
|
22
22
|
|
23
23
|
require_relative "../version"
|
24
|
-
|
24
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
25
25
|
|
26
26
|
def add_deprecation_warnings_for(method_names)
|
27
27
|
method_names.each do |name|
|
28
28
|
define_method(name) do |*args|
|
29
|
-
message = "Method '#{name}' of '#{self.class}' is deprecated. It will be removed in #{
|
29
|
+
message = "Method '#{name}' of '#{self.class}' is deprecated. It will be removed in #{ChefUtils::Dist::Infra::PRODUCT} #{Chef::VERSION.to_i.next}."
|
30
30
|
message << " Please update your cookbooks accordingly."
|
31
31
|
Chef.deprecated(:internal_api, message)
|
32
32
|
super(*args)
|
data/lib/chef/digester.rb
CHANGED
@@ -18,8 +18,8 @@
|
|
18
18
|
# limitations under the License.
|
19
19
|
#
|
20
20
|
|
21
|
-
|
22
|
-
|
21
|
+
autoload :OpenSSL, "openssl"
|
22
|
+
autoload :Digest, "digest"
|
23
23
|
require "singleton" unless defined?(Singleton)
|
24
24
|
|
25
25
|
class Chef
|
data/lib/chef/dsl/chef_vault.rb
CHANGED
data/lib/chef/dsl/data_query.rb
CHANGED
@@ -17,8 +17,8 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require_relative "../search/query"
|
20
|
-
|
21
|
-
|
20
|
+
Chef.autoload :DataBag, File.expand_path("../data_bag", __dir__)
|
21
|
+
Chef.autoload :DataBagItem, File.expand_path("../data_bag_item", __dir__)
|
22
22
|
require_relative "../encrypted_data_bag_item"
|
23
23
|
require_relative "../encrypted_data_bag_item/check_encrypted"
|
24
24
|
|
@@ -16,8 +16,8 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
|
20
|
-
|
19
|
+
autoload :ChefUtils, "chef-utils"
|
20
|
+
require_relative "../mixin/chef_utils_wiring" unless defined?(Chef::Mixin::ChefUtilsWiring)
|
21
21
|
|
22
22
|
class Chef
|
23
23
|
module DSL
|
@@ -79,14 +79,14 @@ class Chef
|
|
79
79
|
key_matches = []
|
80
80
|
keys = @values[platform].keys
|
81
81
|
keys.each do |k|
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
end
|
86
|
-
rescue Chef::Exceptions::InvalidVersionConstraint => e
|
87
|
-
Chef::Log.trace "Caught InvalidVersionConstraint. This means that a key in value_for_platform cannot be interpreted as a Chef::VersionConstraint::Platform."
|
88
|
-
Chef::Log.trace(e)
|
82
|
+
|
83
|
+
if Chef::VersionConstraint::Platform.new(k).include?(node_version)
|
84
|
+
key_matches << k
|
89
85
|
end
|
86
|
+
rescue Chef::Exceptions::InvalidVersionConstraint => e
|
87
|
+
Chef::Log.trace "Caught InvalidVersionConstraint. This means that a key in value_for_platform cannot be interpreted as a Chef::VersionConstraint::Platform."
|
88
|
+
Chef::Log.trace(e)
|
89
|
+
|
90
90
|
end
|
91
91
|
return @values[platform][version] if key_matches.include?(version)
|
92
92
|
|
@@ -17,11 +17,9 @@
|
|
17
17
|
#
|
18
18
|
|
19
19
|
require_relative "config"
|
20
|
-
|
20
|
+
Chef.autoload :DataBagItem, File.expand_path("data_bag_item", __dir__)
|
21
21
|
require_relative "encrypted_data_bag_item/decryptor"
|
22
22
|
require_relative "encrypted_data_bag_item/encryptor"
|
23
|
-
require_relative "dist"
|
24
|
-
require "open-uri"
|
25
23
|
|
26
24
|
# An EncryptedDataBagItem represents a read-only data bag item where
|
27
25
|
# all values, except for the value associated with the id key, have
|
@@ -129,9 +127,10 @@ class Chef::EncryptedDataBagItem
|
|
129
127
|
end
|
130
128
|
|
131
129
|
def self.load_secret(path = nil)
|
130
|
+
require "open-uri" unless defined?(OpenURI)
|
132
131
|
path ||= Chef::Config[:encrypted_data_bag_secret]
|
133
132
|
unless path
|
134
|
-
raise ArgumentError, "No secret specified and no secret found at #{Chef::Config.platform_specific_path(
|
133
|
+
raise ArgumentError, "No secret specified and no secret found at #{Chef::Config.platform_specific_path(ChefConfig::Config.etc_chef_dir) + "/encrypted_data_bag_secret"}"
|
135
134
|
end
|
136
135
|
|
137
136
|
secret = case path
|
@@ -16,10 +16,10 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
|
19
|
+
autoload :YAML, "yaml"
|
20
20
|
require_relative "../json_compat"
|
21
|
-
|
22
|
-
|
21
|
+
autoload :OpenSSL, "openssl"
|
22
|
+
autoload :Base64, "base64"
|
23
23
|
require "digest/sha2" unless defined?(Digest::SHA2)
|
24
24
|
require_relative "../encrypted_data_bag_item"
|
25
25
|
require_relative "unsupported_encrypted_data_bag_item_format"
|
@@ -16,10 +16,10 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
|
19
|
+
autoload :Base64, "base64"
|
20
20
|
require "digest/sha2" unless defined?(Digest::SHA2)
|
21
|
-
|
22
|
-
|
21
|
+
autoload :OpenSSL, "openssl"
|
22
|
+
autoload :FFI_Yajl, "ffi_yajl"
|
23
23
|
require_relative "../encrypted_data_bag_item"
|
24
24
|
require_relative "unsupported_encrypted_data_bag_item_format"
|
25
25
|
require_relative "encryption_failure"
|
data/lib/chef/environment.rb
CHANGED
@@ -25,7 +25,7 @@ require_relative "mixin/params_validate"
|
|
25
25
|
require_relative "mixin/from_file"
|
26
26
|
require_relative "version_constraint"
|
27
27
|
require_relative "server_api"
|
28
|
-
|
28
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
29
29
|
|
30
30
|
class Chef
|
31
31
|
class Environment
|
@@ -254,11 +254,11 @@ class Chef
|
|
254
254
|
js_file = File.join(Chef::Config[:environment_path], "#{name}.json")
|
255
255
|
rb_file = File.join(Chef::Config[:environment_path], "#{name}.rb")
|
256
256
|
|
257
|
-
if File.
|
257
|
+
if File.exist?(js_file)
|
258
258
|
# from_json returns object.class => json_class in the JSON.
|
259
259
|
hash = Chef::JSONCompat.parse(IO.read(js_file))
|
260
260
|
from_hash(hash)
|
261
|
-
elsif File.
|
261
|
+
elsif File.exist?(rb_file)
|
262
262
|
environment = Chef::Environment.new
|
263
263
|
environment.name(name)
|
264
264
|
environment.from_file(rb_file)
|
@@ -308,7 +308,7 @@ class Chef
|
|
308
308
|
def self.validate_cookbook_version(version)
|
309
309
|
if Chef::Config[:solo_legacy_mode]
|
310
310
|
raise Chef::Exceptions::IllegalVersionConstraint,
|
311
|
-
"Environment cookbook version constraints not allowed in #{
|
311
|
+
"Environment cookbook version constraints not allowed in #{ChefUtils::Dist::Solo::PRODUCT}"
|
312
312
|
else
|
313
313
|
Chef::VersionConstraint.new version
|
314
314
|
true
|
@@ -19,7 +19,7 @@
|
|
19
19
|
require_relative "base"
|
20
20
|
require_relative "../platform/query_helpers"
|
21
21
|
require_relative "../win32/eventlog"
|
22
|
-
|
22
|
+
require "chef-utils" unless defined?(ChefUtils::CANARY)
|
23
23
|
|
24
24
|
class Chef
|
25
25
|
module EventLoggers
|
@@ -36,7 +36,7 @@ class Chef
|
|
36
36
|
LOG_CATEGORY_ID = 11001
|
37
37
|
|
38
38
|
# Since we must install the event logger, this is not really configurable
|
39
|
-
SOURCE =
|
39
|
+
SOURCE = ChefUtils::Dist::Infra::SHORT.freeze
|
40
40
|
|
41
41
|
def self.available?
|
42
42
|
ChefUtils.windows?
|
data/lib/chef/exceptions.rb
CHANGED
@@ -18,7 +18,7 @@
|
|
18
18
|
# limitations under the License.
|
19
19
|
|
20
20
|
require "chef-config/exceptions"
|
21
|
-
|
21
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
22
22
|
require_relative "constants"
|
23
23
|
|
24
24
|
class Chef
|
@@ -301,7 +301,7 @@ class Chef
|
|
301
301
|
|
302
302
|
def client_run_failure(exception)
|
303
303
|
set_backtrace(exception.backtrace)
|
304
|
-
@all_failures << [ "#{
|
304
|
+
@all_failures << [ "#{ChefUtils::Dist::Infra::PRODUCT} run", exception ]
|
305
305
|
end
|
306
306
|
|
307
307
|
def notification_failure(exception)
|
@@ -402,7 +402,7 @@ class Chef
|
|
402
402
|
def initialize(response_length, content_length)
|
403
403
|
super <<~EOF
|
404
404
|
Response body length #{response_length} does not match HTTP Content-Length header #{content_length}.
|
405
|
-
This error is most often caused by network issues (proxies, etc) outside of #{
|
405
|
+
This error is most often caused by network issues (proxies, etc) outside of #{ChefUtils::Dist::Infra::CLIENT}.
|
406
406
|
EOF
|
407
407
|
end
|
408
408
|
end
|
@@ -423,7 +423,7 @@ class Chef
|
|
423
423
|
|
424
424
|
class ChecksumMismatch < RuntimeError
|
425
425
|
def initialize(res_cksum, cont_cksum)
|
426
|
-
super "Checksum on resource (#{res_cksum}) does not match checksum on content (#{cont_cksum})"
|
426
|
+
super "Checksum on resource (#{res_cksum}...) does not match checksum on content (#{cont_cksum}...)"
|
427
427
|
end
|
428
428
|
end
|
429
429
|
|
@@ -477,7 +477,7 @@ class Chef
|
|
477
477
|
class CookbookChefVersionMismatch < RuntimeError
|
478
478
|
def initialize(chef_version, cookbook_name, cookbook_version, *constraints)
|
479
479
|
constraint_str = constraints.map { |c| c.requirement.as_list.to_s }.join(", ")
|
480
|
-
super "Cookbook '#{cookbook_name}' version '#{cookbook_version}' depends on #{
|
480
|
+
super "Cookbook '#{cookbook_name}' version '#{cookbook_version}' depends on #{ChefUtils::Dist::Infra::PRODUCT} version #{constraint_str}, but the running #{ChefUtils::Dist::Infra::PRODUCT} version is #{chef_version}"
|
481
481
|
end
|
482
482
|
end
|
483
483
|
|
@@ -112,7 +112,11 @@ class Chef
|
|
112
112
|
|
113
113
|
def get_sid(value)
|
114
114
|
if value.is_a?(String)
|
115
|
-
|
115
|
+
begin
|
116
|
+
Security.convert_string_sid_to_sid(value)
|
117
|
+
rescue Chef::Exceptions::Win32APIError
|
118
|
+
SID.from_account(value)
|
119
|
+
end
|
116
120
|
elsif value.is_a?(SID)
|
117
121
|
value
|
118
122
|
else
|
@@ -39,15 +39,15 @@ class Chef
|
|
39
39
|
errors = [ ]
|
40
40
|
|
41
41
|
tempfile_dirnames.each do |tempfile_dirname|
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
42
|
+
|
43
|
+
# preserving the file extension of the target filename should be considered a public API
|
44
|
+
tf = ::Tempfile.open([tempfile_basename, tempfile_extension], tempfile_dirname)
|
45
|
+
break
|
46
|
+
rescue SystemCallError => e
|
47
|
+
message = "Creating temp file under '#{tempfile_dirname}' failed with: '#{e.message}'"
|
48
|
+
Chef::Log.trace(message)
|
49
|
+
errors << message
|
50
|
+
|
51
51
|
end
|
52
52
|
|
53
53
|
raise Chef::Exceptions::FileContentStagingError, errors if tf.nil?
|
@@ -76,7 +76,7 @@ class Chef
|
|
76
76
|
# complexity here is due to supporting mangling non-UTF8 strings (e.g. latin-1 filenames with characters that are illegal in UTF-8)
|
77
77
|
b = File.basename(@new_resource.path)
|
78
78
|
i = b.index(".")
|
79
|
-
i.nil? ? "" : b[i
|
79
|
+
i.nil? ? "" : b[i..].scrub
|
80
80
|
end
|
81
81
|
|
82
82
|
# Returns the possible directories for the tempfile to be created in.
|
data/lib/chef/formatters/doc.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
require_relative "base"
|
2
2
|
require_relative "../config"
|
3
|
-
|
3
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
4
4
|
|
5
5
|
class Chef
|
6
6
|
module Formatters
|
@@ -41,7 +41,8 @@ class Chef
|
|
41
41
|
end
|
42
42
|
|
43
43
|
def run_start(version, run_status)
|
44
|
-
puts_line "Starting #{
|
44
|
+
puts_line "Starting #{ChefUtils::Dist::Infra::PRODUCT}, version #{version}"
|
45
|
+
puts_line "Patents: #{ChefUtils::Dist::Org::PATENTS}"
|
45
46
|
puts_line "Targeting node: #{Chef::Config.target_mode.host}" if Chef::Config.target_mode?
|
46
47
|
puts_line "OpenSSL FIPS 140 mode enabled" if Chef::Config[:fips]
|
47
48
|
end
|
@@ -77,18 +78,18 @@ class Chef
|
|
77
78
|
puts_line ""
|
78
79
|
end
|
79
80
|
if Chef::Config[:why_run]
|
80
|
-
puts_line "#{
|
81
|
+
puts_line "#{ChefUtils::Dist::Infra::PRODUCT} finished, #{@updated_resources}/#{total_resources} resources would have been updated"
|
81
82
|
else
|
82
|
-
puts_line "#{
|
83
|
+
puts_line "#{ChefUtils::Dist::Infra::PRODUCT} finished, #{@updated_resources}/#{total_resources} resources updated in #{pretty_elapsed_time}"
|
83
84
|
end
|
84
85
|
end
|
85
86
|
|
86
87
|
def run_failed(exception)
|
87
88
|
@end_time = Time.now
|
88
89
|
if Chef::Config[:why_run]
|
89
|
-
puts_line "#{
|
90
|
+
puts_line "#{ChefUtils::Dist::Infra::PRODUCT} failed. #{@updated_resources} resources would have been updated"
|
90
91
|
else
|
91
|
-
puts_line "#{
|
92
|
+
puts_line "#{ChefUtils::Dist::Infra::PRODUCT} failed. #{@updated_resources} resources updated in #{pretty_elapsed_time}"
|
92
93
|
end
|
93
94
|
end
|
94
95
|
|