chef 16.3.38-universal-mingw32 → 16.5.64-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 +19 -17
- 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 +54 -54
- 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 +1 -1
- 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/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 +9 -9
- 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/minimal.rb +5 -4
- data/lib/chef/handler.rb +2 -0
- data/lib/chef/http.rb +15 -13
- data/lib/chef/http/auth_credentials.rb +5 -1
- data/lib/chef/http/authenticator.rb +3 -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/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_show.rb +2 -2
- data/lib/chef/knife/serve.rb +3 -3
- data/lib/chef/knife/ssh.rb +22 -7
- data/lib/chef/knife/ssl_check.rb +3 -3
- data/lib/chef/knife/status.rb +2 -2
- 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 +2 -2
- data/lib/chef/mixin/uris.rb +2 -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 +2 -2
- data/lib/chef/platform/service_helpers.rb +1 -1
- data/lib/chef/policy_builder/policyfile.rb +2 -2
- data/lib/chef/property.rb +1 -1
- data/lib/chef/provider.rb +0 -4
- 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/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/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 +2 -2
- 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 +5 -5
- data/lib/chef/provider/user/mac.rb +10 -10
- 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 +7 -11
- data/lib/chef/resource/apt_repository.rb +2 -11
- 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 +148 -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_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 +19 -19
- 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/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 +4 -5
- data/lib/chef/server_api_versions.rb +4 -0
- 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 +1 -1
- 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 +2 -2
- data/lib/chef/win32/file/version_info.rb +5 -5
- data/lib/chef/win32/registry.rb +1 -2
- 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 -9
- 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/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 -113
- 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/http/api_versions_spec.rb +19 -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/server_api_spec.rb +43 -16
- 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
@@ -20,7 +20,13 @@
|
|
20
20
|
require_relative "base"
|
21
21
|
require_relative "../handler/error_report"
|
22
22
|
require_relative "../workstation_config_loader"
|
23
|
-
|
23
|
+
autoload :URI, "uri"
|
24
|
+
require "chef-utils" unless defined?(ChefUtils)
|
25
|
+
module Mixlib
|
26
|
+
module Authentication
|
27
|
+
autoload :Log, "mixlib/authentication"
|
28
|
+
end
|
29
|
+
end
|
24
30
|
|
25
31
|
# DO NOT MAKE EDITS, see Chef::Application::Base
|
26
32
|
#
|
@@ -45,7 +51,7 @@ class Chef::Application::Client < Chef::Application::Base
|
|
45
51
|
option :pid_file,
|
46
52
|
short: "-P PID_FILE",
|
47
53
|
long: "--pid PIDFILE",
|
48
|
-
description: "Set the PID file location, for the #{
|
54
|
+
description: "Set the PID file location, for the #{ChefUtils::Dist::Infra::CLIENT} daemon process. Defaults to /tmp/chef-client.pid.",
|
49
55
|
proc: nil
|
50
56
|
|
51
57
|
option :runlist,
|
@@ -100,7 +106,7 @@ class Chef::Application::Client < Chef::Application::Base
|
|
100
106
|
tarball_path = File.join(Chef::Config.chef_repo_path, "recipes.tgz")
|
101
107
|
fetch_recipe_tarball(Chef::Config[:recipe_url], tarball_path)
|
102
108
|
Mixlib::Archive.new(tarball_path).extract(Chef::Config.chef_repo_path, perms: false, ignore: /^\.$/)
|
103
|
-
config_path = File.join(Chef::Config.chef_repo_path, "#{
|
109
|
+
config_path = File.join(Chef::Config.chef_repo_path, "#{ChefUtils::Dist::Infra::USER_CONF_DIR}/config.rb")
|
104
110
|
Chef::Config.from_string(IO.read(config_path), config_path) if File.file?(config_path)
|
105
111
|
end
|
106
112
|
end
|
@@ -147,7 +153,7 @@ class Chef::Application::Client < Chef::Application::Base
|
|
147
153
|
if config[:local_mode]
|
148
154
|
config[:config_file] = Chef::WorkstationConfigLoader.new(nil, Chef::Log).config_location
|
149
155
|
else
|
150
|
-
config[:config_file] = Chef::Config.platform_specific_path("#{
|
156
|
+
config[:config_file] = Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/client.rb")
|
151
157
|
end
|
152
158
|
end
|
153
159
|
|
@@ -22,7 +22,7 @@ class Chef
|
|
22
22
|
# These are the exit codes defined in Chef RFC 062
|
23
23
|
# https://github.com/chef/chef-rfc/blob/master/rfc062-exit-status.md
|
24
24
|
class ExitCode
|
25
|
-
|
25
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
26
26
|
|
27
27
|
# -1 is defined as DEPRECATED_FAILURE in RFC 062, so it is
|
28
28
|
# not enumerated in an active constant.
|
@@ -36,6 +36,7 @@ class Chef
|
|
36
36
|
REBOOT_NEEDED: 37,
|
37
37
|
REBOOT_FAILED: 41,
|
38
38
|
# 42 was used by audit mode and should not be reused
|
39
|
+
CONFIG_FAILURE: 43,
|
39
40
|
CLIENT_UPGRADED: 213,
|
40
41
|
}.freeze
|
41
42
|
|
@@ -79,6 +80,8 @@ class Chef
|
|
79
80
|
VALID_RFC_062_EXIT_CODES[:REBOOT_NEEDED]
|
80
81
|
elsif reboot_failed?(exception)
|
81
82
|
VALID_RFC_062_EXIT_CODES[:REBOOT_FAILED]
|
83
|
+
elsif configuration_failure?(exception)
|
84
|
+
VALID_RFC_062_EXIT_CODES[:CONFIG_FAILURE]
|
82
85
|
elsif client_upgraded?(exception)
|
83
86
|
VALID_RFC_062_EXIT_CODES[:CLIENT_UPGRADED]
|
84
87
|
else
|
@@ -104,6 +107,12 @@ class Chef
|
|
104
107
|
end
|
105
108
|
end
|
106
109
|
|
110
|
+
def configuration_failure?(exception)
|
111
|
+
resolve_exception_array(exception).any? do |e|
|
112
|
+
e.is_a? Chef::Exceptions::ConfigurationError
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
107
116
|
def client_upgraded?(exception)
|
108
117
|
resolve_exception_array(exception).any? do |e|
|
109
118
|
e.is_a? Chef::Exceptions::ClientUpgraded
|
@@ -144,9 +153,9 @@ class Chef
|
|
144
153
|
end
|
145
154
|
|
146
155
|
def non_standard_exit_code_warning(exit_code)
|
147
|
-
"#{
|
148
|
-
" The #{
|
149
|
-
" defines the exit codes that should be used with #{
|
156
|
+
"#{ChefUtils::Dist::Infra::CLIENT} attempted to exit with a non-standard exit code of #{exit_code}." \
|
157
|
+
" The #{ChefUtils::Dist::Infra::PRODUCT} Exit Codes design document (https://github.com/chef/chef-rfc/blob/master/rfc062-exit-status.md)" \
|
158
|
+
" defines the exit codes that should be used with #{ChefUtils::Dist::Infra::CLIENT}. Chef::Application::ExitCode defines" \
|
150
159
|
" valid exit codes Non-standard exit codes are redefined as GENERIC_FAILURE."
|
151
160
|
end
|
152
161
|
|
@@ -19,8 +19,10 @@ require_relative "../knife"
|
|
19
19
|
require_relative "../application"
|
20
20
|
require "mixlib/log"
|
21
21
|
require "ohai/config"
|
22
|
-
|
23
|
-
|
22
|
+
module Net
|
23
|
+
autoload :HTTP, File.expand_path("../monkey_patches/net_http", __dir__)
|
24
|
+
end
|
25
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
24
26
|
|
25
27
|
class Chef::Application::Knife < Chef::Application
|
26
28
|
|
@@ -59,7 +61,7 @@ class Chef::Application::Knife < Chef::Application
|
|
59
61
|
option :environment,
|
60
62
|
short: "-E ENVIRONMENT",
|
61
63
|
long: "--environment ENVIRONMENT",
|
62
|
-
description: "Set the #{
|
64
|
+
description: "Set the #{ChefUtils::Dist::Infra::PRODUCT} environment (except for in searches, where this will be flagrantly ignored)."
|
63
65
|
|
64
66
|
option :editor,
|
65
67
|
short: "-e EDITOR",
|
@@ -84,18 +86,18 @@ class Chef::Application::Knife < Chef::Application
|
|
84
86
|
option :node_name,
|
85
87
|
short: "-u USER",
|
86
88
|
long: "--user USER",
|
87
|
-
description: "#{
|
89
|
+
description: "#{ChefUtils::Dist::Server::PRODUCT} API client username."
|
88
90
|
|
89
91
|
option :client_key,
|
90
92
|
short: "-k KEY",
|
91
93
|
long: "--key KEY",
|
92
|
-
description: "#{
|
94
|
+
description: "#{ChefUtils::Dist::Server::PRODUCT} API client key.",
|
93
95
|
proc: lambda { |path| File.expand_path(path, Dir.pwd) }
|
94
96
|
|
95
97
|
option :chef_server_url,
|
96
98
|
short: "-s URL",
|
97
99
|
long: "--server-url URL",
|
98
|
-
description: "#{
|
100
|
+
description: "#{ChefUtils::Dist::Server::PRODUCT} URL."
|
99
101
|
|
100
102
|
option :yes,
|
101
103
|
short: "-y",
|
@@ -120,16 +122,16 @@ class Chef::Application::Knife < Chef::Application
|
|
120
122
|
option :local_mode,
|
121
123
|
short: "-z",
|
122
124
|
long: "--local-mode",
|
123
|
-
description: "Point knife commands at local repository instead of #{
|
125
|
+
description: "Point knife commands at local repository instead of #{ChefUtils::Dist::Server::PRODUCT}.",
|
124
126
|
boolean: true
|
125
127
|
|
126
128
|
option :chef_zero_host,
|
127
129
|
long: "--chef-zero-host HOST",
|
128
|
-
description: "Host to start #{
|
130
|
+
description: "Host to start #{ChefUtils::Dist::Zero::PRODUCT} on."
|
129
131
|
|
130
132
|
option :chef_zero_port,
|
131
133
|
long: "--chef-zero-port PORT",
|
132
|
-
description: "Port (or port range) to start #{
|
134
|
+
description: "Port (or port range) to start #{ChefUtils::Dist::Zero::PRODUCT} on. Port ranges like 1000,1010 or 8889-9999 will try all given ports until one works."
|
133
135
|
|
134
136
|
option :listen,
|
135
137
|
long: "--[no-]listen",
|
@@ -139,9 +141,9 @@ class Chef::Application::Knife < Chef::Application
|
|
139
141
|
option :version,
|
140
142
|
short: "-v",
|
141
143
|
long: "--version",
|
142
|
-
description: "Show #{
|
144
|
+
description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version.",
|
143
145
|
boolean: true,
|
144
|
-
proc: lambda { |v| puts "#{
|
146
|
+
proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
|
145
147
|
exit: 0
|
146
148
|
|
147
149
|
option :fips,
|
@@ -214,6 +216,15 @@ class Chef::Application::Knife < Chef::Application
|
|
214
216
|
rescue OptionParser::InvalidOption => e
|
215
217
|
puts "#{e}\n"
|
216
218
|
end
|
219
|
+
|
220
|
+
if want_help?
|
221
|
+
puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{Chef::VERSION}"
|
222
|
+
puts
|
223
|
+
puts "Docs: #{ChefUtils::Dist::Org::KNIFE_DOCS}"
|
224
|
+
puts "Patents: #{ChefUtils::Dist::Org::PATENTS}"
|
225
|
+
puts
|
226
|
+
end
|
227
|
+
|
217
228
|
puts opt_parser
|
218
229
|
puts
|
219
230
|
Chef::Knife.list_commands
|
@@ -21,6 +21,7 @@ require_relative "../../chef"
|
|
21
21
|
require_relative "client"
|
22
22
|
require "fileutils" unless defined?(FileUtils)
|
23
23
|
require "pathname" unless defined?(Pathname)
|
24
|
+
require "chef-utils" unless defined?(ChefUtils)
|
24
25
|
|
25
26
|
# DO NOT MAKE EDITS, see Chef::Application::Base
|
26
27
|
#
|
@@ -33,7 +34,7 @@ class Chef::Application::Solo < Chef::Application::Base
|
|
33
34
|
option :config_file,
|
34
35
|
short: "-c CONFIG",
|
35
36
|
long: "--config CONFIG",
|
36
|
-
default: Chef::Config.platform_specific_path("#{
|
37
|
+
default: Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/solo.rb"),
|
37
38
|
description: "The configuration file to use."
|
38
39
|
|
39
40
|
unless ChefUtils.windows?
|
@@ -29,7 +29,7 @@ require "socket" unless defined?(Socket)
|
|
29
29
|
require "uri" unless defined?(URI)
|
30
30
|
require "win32/daemon"
|
31
31
|
require_relative "../mixin/shell_out"
|
32
|
-
|
32
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
33
33
|
|
34
34
|
class Chef
|
35
35
|
class Application
|
@@ -41,7 +41,7 @@ class Chef
|
|
41
41
|
short: "-c CONFIG",
|
42
42
|
long: "--config CONFIG",
|
43
43
|
default: "#{Chef::Config.etc_chef_dir}/client.rb",
|
44
|
-
description: "The configuration file to use for #{
|
44
|
+
description: "The configuration file to use for #{ChefUtils::Dist::Infra::PRODUCT} runs."
|
45
45
|
|
46
46
|
option :log_location,
|
47
47
|
short: "-L LOGLOCATION",
|
@@ -57,7 +57,7 @@ class Chef
|
|
57
57
|
option :interval,
|
58
58
|
short: "-i SECONDS",
|
59
59
|
long: "--interval SECONDS",
|
60
|
-
description: "Set the number of seconds to wait between #{
|
60
|
+
description: "Set the number of seconds to wait between #{ChefUtils::Dist::Infra::PRODUCT} runs.",
|
61
61
|
proc: lambda { |s| s.to_i }
|
62
62
|
|
63
63
|
DEFAULT_LOG_LOCATION ||= "#{Chef::Config.c_chef_dir}/client.log".freeze
|
@@ -67,7 +67,7 @@ class Chef
|
|
67
67
|
@service_signal = ConditionVariable.new
|
68
68
|
|
69
69
|
reconfigure
|
70
|
-
Chef::Log.info("#{
|
70
|
+
Chef::Log.info("#{ChefUtils::Dist::Infra::CLIENT} Service initialized")
|
71
71
|
end
|
72
72
|
|
73
73
|
def service_main(*startup_parameters)
|
@@ -78,33 +78,33 @@ class Chef
|
|
78
78
|
while running?
|
79
79
|
# Grab the service_action_mutex to make a chef-client run
|
80
80
|
@service_action_mutex.synchronize do
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
81
|
+
|
82
|
+
Chef::Log.info("Next #{ChefUtils::Dist::Infra::CLIENT} run will happen in #{timeout} seconds")
|
83
|
+
@service_signal.wait(@service_action_mutex, timeout)
|
84
|
+
|
85
|
+
# Continue only if service is RUNNING
|
86
|
+
next if state != RUNNING
|
87
|
+
|
88
|
+
# Reconfigure each time through to pick up any changes in the client file
|
89
|
+
Chef::Log.info("Reconfiguring with startup parameters")
|
90
|
+
reconfigure(startup_parameters)
|
91
|
+
timeout = Chef::Config[:interval]
|
92
|
+
|
93
|
+
# Honor splay sleep config
|
94
|
+
timeout += rand Chef::Config[:splay]
|
95
|
+
|
96
|
+
# run chef-client only if service is in RUNNING state
|
97
|
+
next if state != RUNNING
|
98
|
+
|
99
|
+
Chef::Log.info("#{ChefUtils::Dist::Infra::CLIENT} service is starting a #{ChefUtils::Dist::Infra::CLIENT} run...")
|
100
|
+
run_chef_client
|
101
|
+
rescue SystemExit => e
|
102
|
+
# Do not raise any of the errors here in order to
|
103
|
+
# prevent service crash
|
104
|
+
Chef::Log.error("#{e.class}: #{e}")
|
105
|
+
rescue Exception => e
|
106
|
+
Chef::Log.error("#{e.class}: #{e}")
|
107
|
+
|
108
108
|
end
|
109
109
|
end
|
110
110
|
|
@@ -131,12 +131,12 @@ class Chef
|
|
131
131
|
break
|
132
132
|
else
|
133
133
|
unless run_warning_displayed
|
134
|
-
Chef::Log.info("Currently a #{
|
134
|
+
Chef::Log.info("Currently a #{ChefUtils::Dist::Infra::PRODUCT} run is happening on this system.")
|
135
135
|
Chef::Log.info("Service will stop when run is completed.")
|
136
136
|
run_warning_displayed = true
|
137
137
|
end
|
138
138
|
|
139
|
-
Chef::Log.trace("Waiting for #{
|
139
|
+
Chef::Log.trace("Waiting for #{ChefUtils::Dist::Infra::PRODUCT} run...")
|
140
140
|
sleep 1
|
141
141
|
end
|
142
142
|
end
|
@@ -150,7 +150,7 @@ class Chef
|
|
150
150
|
# since this is a PAUSE signal.
|
151
151
|
|
152
152
|
if @service_action_mutex.locked?
|
153
|
-
Chef::Log.info("Currently a #{
|
153
|
+
Chef::Log.info("Currently a #{ChefUtils::Dist::Infra::PRODUCT} run is happening.")
|
154
154
|
Chef::Log.info("Service will pause once it's completed.")
|
155
155
|
else
|
156
156
|
Chef::Log.info("Service is pausing....")
|
@@ -185,7 +185,7 @@ class Chef
|
|
185
185
|
# The log_location and config_file of the parent process is passed to the new chef-client process.
|
186
186
|
# We need to add the --no-fork, as by default it is set to fork=true.
|
187
187
|
|
188
|
-
Chef::Log.info "Starting #{
|
188
|
+
Chef::Log.info "Starting #{ChefUtils::Dist::Infra::CLIENT} in a new process"
|
189
189
|
# Pass config params to the new process
|
190
190
|
config_params = " --no-fork"
|
191
191
|
config_params += " -c #{Chef::Config[:config_file]}" unless Chef::Config[:config_file].nil?
|
@@ -197,20 +197,20 @@ class Chef
|
|
197
197
|
# Starts a new process and waits till the process exits
|
198
198
|
|
199
199
|
result = shell_out(
|
200
|
-
"#{
|
200
|
+
"#{ChefUtils::Dist::Infra::CLIENT}.bat #{config_params}",
|
201
201
|
timeout: Chef::Config[:windows_service][:watchdog_timeout],
|
202
202
|
logger: Chef::Log
|
203
203
|
)
|
204
204
|
Chef::Log.trace (result.stdout).to_s
|
205
205
|
Chef::Log.trace (result.stderr).to_s
|
206
206
|
rescue Mixlib::ShellOut::CommandTimeout => e
|
207
|
-
Chef::Log.error "#{
|
207
|
+
Chef::Log.error "#{ChefUtils::Dist::Infra::CLIENT} timed out\n(#{e})"
|
208
208
|
Chef::Log.error(<<-EOF)
|
209
|
-
Your #{
|
209
|
+
Your #{ChefUtils::Dist::Infra::CLIENT} run timed out. You can increase the time #{ChefUtils::Dist::Infra::CLIENT} is given
|
210
210
|
to complete by configuring windows_service.watchdog_timeout in your client.rb.
|
211
211
|
EOF
|
212
212
|
rescue Mixlib::ShellOut::ShellCommandFailed => e
|
213
|
-
Chef::Log.warn "Not able to start #{
|
213
|
+
Chef::Log.warn "Not able to start #{ChefUtils::Dist::Infra::CLIENT} in new process (#{e})"
|
214
214
|
rescue => e
|
215
215
|
Chef::Log.error e
|
216
216
|
ensure
|
@@ -21,7 +21,7 @@ if RUBY_PLATFORM.match?(/mswin|mingw32|windows/)
|
|
21
21
|
end
|
22
22
|
require_relative "../config"
|
23
23
|
require "mixlib/cli" unless defined?(Mixlib::CLI)
|
24
|
-
|
24
|
+
require "chef-utils/dist" unless defined?(ChefUtils::Dist)
|
25
25
|
|
26
26
|
class Chef
|
27
27
|
class Application
|
@@ -41,18 +41,18 @@ class Chef
|
|
41
41
|
short: "-a ACTION",
|
42
42
|
long: "--action ACTION",
|
43
43
|
default: "status",
|
44
|
-
description: "Action to carry out on #{
|
44
|
+
description: "Action to carry out on #{ChefUtils::Dist::Infra::SHORT}-service (install, uninstall, status, start, stop, pause, or resume)."
|
45
45
|
|
46
46
|
option :config_file,
|
47
47
|
short: "-c CONFIG",
|
48
48
|
long: "--config CONFIG",
|
49
49
|
default: "#{ChefConfig::Config.c_chef_dir}/client.rb",
|
50
|
-
description: "The configuration file to use for #{
|
50
|
+
description: "The configuration file to use for #{ChefUtils::Dist::Infra::PRODUCT} runs."
|
51
51
|
|
52
52
|
option :log_location,
|
53
53
|
short: "-L LOGLOCATION",
|
54
54
|
long: "--logfile LOGLOCATION",
|
55
|
-
description: "Set the log file location for #{
|
55
|
+
description: "Set the log file location for #{ChefUtils::Dist::Infra::SHORT}-service."
|
56
56
|
|
57
57
|
option :help,
|
58
58
|
short: "-h",
|
@@ -66,9 +66,9 @@ class Chef
|
|
66
66
|
option :version,
|
67
67
|
short: "-v",
|
68
68
|
long: "--version",
|
69
|
-
description: "Show #{
|
69
|
+
description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version.",
|
70
70
|
boolean: true,
|
71
|
-
proc: lambda { |v| puts "#{
|
71
|
+
proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
|
72
72
|
exit: 0
|
73
73
|
|
74
74
|
def initialize(service_options)
|
data/lib/chef/chef_class.rb
CHANGED
@@ -172,11 +172,11 @@ class Chef
|
|
172
172
|
@memory_store.create_dir(path, name, *options)
|
173
173
|
else
|
174
174
|
with_parent_dir(path + [name], *options) do |parent, name|
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
175
|
+
|
176
|
+
parent.create_child(name, nil)
|
177
|
+
rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
|
178
|
+
raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
|
179
|
+
|
180
180
|
end
|
181
181
|
end
|
182
182
|
end
|
@@ -251,11 +251,11 @@ class Chef
|
|
251
251
|
end
|
252
252
|
|
253
253
|
with_parent_dir(path + [name], *options) do |parent, name|
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
254
|
+
|
255
|
+
parent.create_child(name, data)
|
256
|
+
rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
|
257
|
+
raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
|
258
|
+
|
259
259
|
end
|
260
260
|
end
|
261
261
|
end
|
@@ -349,11 +349,11 @@ class Chef
|
|
349
349
|
|
350
350
|
else
|
351
351
|
with_entry(path) do |entry|
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
352
|
+
|
353
|
+
entry.read
|
354
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError => e
|
355
|
+
raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
|
356
|
+
|
357
357
|
end
|
358
358
|
end
|
359
359
|
end
|
@@ -433,15 +433,15 @@ class Chef
|
|
433
433
|
|
434
434
|
else
|
435
435
|
with_entry(path) do |entry|
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
end
|
442
|
-
rescue Chef::ChefFS::FileSystem::NotFoundError => e
|
443
|
-
raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
|
436
|
+
|
437
|
+
if %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length >= 3
|
438
|
+
entry.delete(true)
|
439
|
+
else
|
440
|
+
entry.delete(false)
|
444
441
|
end
|
442
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError => e
|
443
|
+
raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
|
444
|
+
|
445
445
|
end
|
446
446
|
end
|
447
447
|
end
|
@@ -471,11 +471,11 @@ class Chef
|
|
471
471
|
|
472
472
|
else
|
473
473
|
with_entry(path) do |entry|
|
474
|
-
|
475
|
-
|
476
|
-
|
477
|
-
|
478
|
-
|
474
|
+
|
475
|
+
entry.delete(options.include?(:recursive))
|
476
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError => e
|
477
|
+
raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
|
478
|
+
|
479
479
|
end
|
480
480
|
end
|
481
481
|
end
|
@@ -487,11 +487,11 @@ class Chef
|
|
487
487
|
# LIST /policies
|
488
488
|
elsif path == [ "policies" ]
|
489
489
|
with_entry([ path[0] ]) do |policies|
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
|
490
|
+
|
491
|
+
policies.children.map { |policy| policy.name[0..-6].rpartition("-")[0] }.uniq
|
492
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError
|
493
|
+
[]
|
494
|
+
|
495
495
|
end
|
496
496
|
|
497
497
|
# LIST /policies/POLICY/revisions
|
@@ -524,19 +524,19 @@ class Chef
|
|
524
524
|
|
525
525
|
elsif %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length == 1
|
526
526
|
with_entry(path) do |entry|
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
|
532
|
-
|
533
|
-
|
534
|
-
|
535
|
-
end
|
536
|
-
rescue Chef::ChefFS::FileSystem::NotFoundError
|
537
|
-
# If the cookbooks dir doesn't exist, we have no cookbooks (not 404)
|
538
|
-
[]
|
527
|
+
|
528
|
+
if path[0] == "cookbook_artifacts"
|
529
|
+
entry.children.map { |child| child.name.rpartition("-")[0] }.uniq
|
530
|
+
elsif chef_fs.versioned_cookbooks
|
531
|
+
# /cookbooks/name-version -> /cookbooks/name
|
532
|
+
entry.children.map { |child| split_name_version(child.name)[0] }.uniq
|
533
|
+
else
|
534
|
+
entry.children.map(&:name)
|
539
535
|
end
|
536
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError
|
537
|
+
# If the cookbooks dir doesn't exist, we have no cookbooks (not 404)
|
538
|
+
[]
|
539
|
+
|
540
540
|
end
|
541
541
|
|
542
542
|
elsif %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length == 2
|
@@ -560,16 +560,16 @@ class Chef
|
|
560
560
|
|
561
561
|
else
|
562
562
|
result = with_entry(path) do |entry|
|
563
|
-
|
564
|
-
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
|
569
|
-
|
570
|
-
|
571
|
-
end
|
563
|
+
|
564
|
+
entry.children.map { |c| zero_filename(c) }.sort
|
565
|
+
rescue Chef::ChefFS::FileSystem::NotFoundError => e
|
566
|
+
# /cookbooks, /data, etc. never return 404
|
567
|
+
if path_always_exists?(path)
|
568
|
+
[]
|
569
|
+
else
|
570
|
+
raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
|
572
571
|
end
|
572
|
+
|
573
573
|
end
|
574
574
|
|
575
575
|
# Older versions of chef-zero do not understand policies and cookbook_artifacts,
|