chef 16.2.50-universal-mingw32 → 16.4.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 +3 -16
- data/chef-universal-mingw32.gemspec +2 -3
- data/chef.gemspec +4 -3
- data/lib/chef/action_collection.rb +4 -0
- data/lib/chef/api_client/registration.rb +2 -2
- data/lib/chef/application.rb +13 -1
- data/lib/chef/application/apply.rb +6 -5
- data/lib/chef/application/windows_service.rb +27 -27
- data/lib/chef/{whitelist.rb → attribute_allowlist.rb} +11 -11
- data/lib/chef/{blacklist.rb → attribute_blocklist.rb} +9 -9
- 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/data_handler/organization_data_handler.rb +1 -2
- data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
- data/lib/chef/chef_fs/file_system/chef_server/cookbook_file.rb +2 -2
- data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +1 -5
- 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/base_file.rb +1 -0
- 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/parallelizer/parallel_enumerable.rb +1 -1
- data/lib/chef/client.rb +14 -14
- 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/data_collector/run_end_message.rb +11 -1
- data/lib/chef/deprecated.rb +8 -0
- data/lib/chef/digester.rb +3 -2
- data/lib/chef/dsl/platform_introspection.rb +9 -7
- data/lib/chef/encrypted_data_bag_item/decryptor.rb +1 -1
- data/lib/chef/environment.rb +3 -4
- data/lib/chef/exceptions.rb +4 -1
- data/lib/chef/file_access_control/windows.rb +2 -2
- data/lib/chef/file_content_management/deploy/mv_unix.rb +1 -1
- data/lib/chef/file_content_management/tempfile.rb +9 -9
- data/lib/chef/handler.rb +2 -0
- data/lib/chef/http.rb +12 -12
- data/lib/chef/http/authenticator.rb +3 -1
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/knife.rb +4 -4
- data/lib/chef/knife/bootstrap.rb +18 -15
- 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_download.rb +1 -1
- data/lib/chef/knife/cookbook_metadata.rb +1 -1
- data/lib/chef/knife/cookbook_upload.rb +29 -37
- data/lib/chef/knife/core/bootstrap_context.rb +1 -1
- data/lib/chef/knife/core/gem_glob_loader.rb +1 -1
- data/lib/chef/knife/core/generic_presenter.rb +1 -1
- data/lib/chef/knife/core/hashed_command_loader.rb +3 -2
- 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 +33 -26
- data/lib/chef/knife/delete.rb +15 -15
- data/lib/chef/knife/exec.rb +2 -2
- data/lib/chef/knife/rehash.rb +3 -21
- data/lib/chef/knife/ssh.rb +11 -7
- data/lib/chef/knife/xargs.rb +19 -19
- data/lib/chef/knife/yaml_convert.rb +1 -1
- data/lib/chef/log.rb +7 -2
- data/lib/chef/mixin/checksum.rb +0 -1
- data/{spec/functional/resource/base.rb → lib/chef/mixin/chef_utils_wiring.rb} +24 -12
- data/lib/chef/mixin/deep_merge.rb +35 -6
- data/{spec/unit/log_spec.rb → lib/chef/mixin/default_paths.rb} +13 -5
- data/lib/chef/mixin/openssl_helper.rb +30 -6
- 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/monkey_patches/webrick-utils.rb +10 -10
- data/lib/chef/node.rb +36 -12
- data/lib/chef/node/attribute.rb +2 -4
- data/lib/chef/node_map.rb +21 -18
- data/lib/chef/platform/service_helpers.rb +31 -28
- data/lib/chef/property.rb +1 -1
- data/lib/chef/provider/cron/unix.rb +0 -2
- data/lib/chef/provider/git.rb +17 -9
- 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/mount.rb +0 -2
- data/lib/chef/provider/mount/solaris.rb +0 -1
- data/lib/chef/provider/package.rb +0 -2
- data/lib/chef/provider/package/rubygems.rb +1 -1
- data/lib/chef/provider/package/snap.rb +3 -4
- data/lib/chef/provider/package/windows.rb +9 -4
- data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +9 -9
- data/lib/chef/provider/package/zypper.rb +0 -1
- data/lib/chef/provider/powershell_script.rb +21 -5
- data/lib/chef/provider/route.rb +1 -1
- data/lib/chef/provider/service.rb +2 -2
- 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 +2 -2
- 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/user/dscl.rb +2 -2
- data/lib/chef/provider/user/mac.rb +9 -9
- data/lib/chef/provider/windows_task.rb +0 -3
- data/lib/chef/provider/yum_repository.rb +1 -1
- data/lib/chef/provider/zypper_repository.rb +1 -2
- data/lib/chef/providers.rb +0 -1
- data/lib/chef/recipe.rb +1 -1
- data/lib/chef/resource.rb +9 -11
- data/lib/chef/resource/apt_repository.rb +1 -10
- data/lib/chef/resource/build_essential.rb +2 -2
- data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
- data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
- data/lib/chef/resource/chef_vault_secret.rb +13 -13
- 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/dmg_package.rb +1 -1
- data/lib/chef/resource/execute.rb +4 -5
- data/lib/chef/resource/homebrew_update.rb +2 -2
- data/lib/chef/resource/hostname.rb +18 -18
- data/lib/chef/resource/launchd.rb +1 -1
- data/lib/chef/resource/lwrp_base.rb +1 -0
- data/lib/chef/resource/macos_userdefaults.rb +176 -61
- data/lib/chef/resource/openssl_dhparam.rb +2 -0
- data/lib/chef/resource/openssl_ec_private_key.rb +2 -0
- data/lib/chef/resource/openssl_ec_public_key.rb +2 -0
- data/lib/chef/resource/openssl_rsa_private_key.rb +2 -0
- data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
- data/lib/chef/resource/openssl_x509_certificate.rb +35 -35
- data/lib/chef/resource/openssl_x509_crl.rb +3 -2
- data/lib/chef/resource/openssl_x509_request.rb +23 -20
- data/lib/chef/resource/osx_profile.rb +227 -5
- data/lib/chef/resource/powershell_package_source.rb +1 -1
- data/lib/chef/resource/powershell_script.rb +24 -30
- 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 +2 -2
- data/lib/chef/resource/sysctl.rb +5 -5
- data/lib/chef/resource/user_ulimit.rb +1 -1
- data/lib/chef/resource/windows_ad_join.rb +2 -0
- 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 +2 -0
- 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 +25 -5
- 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 +199 -0
- data/lib/chef/resource/windows_firewall_rule.rb +5 -3
- data/lib/chef/resource/windows_font.rb +3 -1
- data/lib/chef/resource/windows_pagefile.rb +4 -0
- data/lib/chef/resource/windows_printer.rb +17 -18
- data/lib/chef/resource/windows_printer_port.rb +14 -13
- data/lib/chef/resource/windows_security_policy.rb +51 -20
- 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 +27 -2
- data/lib/chef/resource/windows_workgroup.rb +2 -3
- data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
- data/lib/chef/resource_inspector.rb +7 -1
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/role.rb +3 -4
- data/lib/chef/run_context/cookbook_compiler.rb +20 -20
- data/lib/chef/run_status.rb +2 -6
- data/lib/chef/server_api_versions.rb +4 -0
- data/lib/chef/shell.rb +1 -1
- data/lib/chef/shell/shell_session.rb +2 -0
- data/lib/chef/util/backup.rb +1 -1
- data/lib/chef/util/diff.rb +11 -12
- data/lib/chef/util/powershell/cmdlet.rb +1 -1
- data/lib/chef/version.rb +2 -2
- 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/ssl/chef-rspec.cert +15 -15
- data/spec/functional/knife/configure_spec.rb +1 -1
- data/spec/functional/knife/ssh_spec.rb +5 -16
- data/spec/functional/resource/aix_service_spec.rb +9 -2
- data/spec/functional/resource/aixinit_service_spec.rb +8 -9
- data/spec/functional/resource/apt_package_spec.rb +0 -1
- data/spec/functional/resource/bash_spec.rb +3 -2
- data/spec/functional/resource/bff_spec.rb +3 -3
- data/spec/functional/resource/chocolatey_package_spec.rb +4 -0
- data/spec/functional/resource/cookbook_file_spec.rb +1 -1
- data/spec/functional/resource/cron_spec.rb +10 -2
- data/spec/functional/resource/dnf_package_spec.rb +4 -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/execute_spec.rb +1 -1
- data/spec/functional/resource/git_spec.rb +23 -1
- data/spec/functional/resource/group_spec.rb +21 -9
- data/spec/functional/resource/ifconfig_spec.rb +9 -1
- data/spec/functional/resource/insserv_spec.rb +7 -7
- data/spec/functional/resource/link_spec.rb +22 -25
- data/spec/functional/resource/mount_spec.rb +9 -1
- data/spec/functional/resource/msu_package_spec.rb +9 -3
- data/spec/functional/resource/powershell_script_spec.rb +8 -8
- data/spec/functional/resource/remote_file_spec.rb +7 -13
- data/spec/functional/resource/rpm_spec.rb +3 -3
- data/spec/functional/resource/timezone_spec.rb +2 -0
- 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_package_spec.rb +0 -1
- data/spec/functional/resource/windows_path_spec.rb +4 -0
- data/spec/functional/resource/windows_security_policy_spec.rb +0 -4
- data/spec/functional/resource/windows_service_spec.rb +4 -0
- data/spec/functional/resource/windows_task_spec.rb +4 -3
- data/spec/functional/resource/windows_user_privilege_spec.rb +1 -2
- data/spec/functional/resource/yum_package_spec.rb +4 -1
- data/spec/functional/resource/zypper_package_spec.rb +4 -1
- data/spec/functional/run_lock_spec.rb +26 -25
- data/spec/functional/shell_spec.rb +5 -6
- data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/crypto_spec.rb +1 -1
- data/spec/functional/win32/registry_spec.rb +8 -8
- data/spec/functional/win32/service_manager_spec.rb +1 -1
- data/spec/integration/knife/common_options_spec.rb +12 -12
- data/spec/integration/knife/config_get_profile_spec.rb +69 -68
- data/spec/integration/knife/config_get_spec.rb +126 -125
- data/spec/integration/knife/config_list_profiles_spec.rb +181 -152
- data/spec/integration/knife/config_use_profile_spec.rb +110 -109
- data/spec/integration/knife/cookbook_upload_spec.rb +28 -1
- data/spec/integration/knife/data_bag_from_file_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/environment_from_file_spec.rb +1 -1
- data/spec/integration/knife/node_from_file_spec.rb +1 -1
- data/spec/integration/knife/role_from_file_spec.rb +1 -1
- data/spec/integration/knife/serve_spec.rb +5 -5
- data/spec/integration/knife/upload_spec.rb +3 -1
- data/spec/integration/recipes/accumulator_spec.rb +1 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +2 -2
- 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 +5 -1
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +2 -0
- data/spec/integration/recipes/resource_load_spec.rb +4 -2
- 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 +16 -10
- data/spec/support/chef_helpers.rb +1 -20
- data/spec/support/platform_helpers.rb +9 -11
- 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 -21
- data/spec/support/shared/functional/securable_resource.rb +1 -2
- data/spec/support/shared/functional/securable_resource_with_reporting.rb +0 -1
- data/spec/support/shared/functional/win32_service.rb +1 -1
- data/spec/support/shared/functional/windows_script.rb +5 -5
- data/spec/support/shared/integration/integration_helper.rb +22 -52
- data/spec/support/shared/integration/knife_support.rb +2 -9
- data/spec/support/shared/unit/application_dot_d.rb +0 -1
- data/spec/support/shared/unit/provider/file.rb +12 -8
- data/spec/support/shared/unit/script_resource.rb +6 -20
- data/spec/support/shared/unit/windows_script_resource.rb +15 -28
- data/spec/unit/application/solo_spec.rb +4 -2
- data/spec/unit/application_spec.rb +4 -2
- data/spec/unit/chef_fs/config_spec.rb +2 -2
- data/spec/unit/chef_fs/diff_spec.rb +8 -8
- 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/client_spec.rb +4 -1
- data/spec/unit/cookbook/gem_installer_spec.rb +2 -1
- data/spec/unit/cookbook/synchronizer_spec.rb +26 -24
- data/spec/unit/data_bag_spec.rb +6 -3
- data/spec/unit/data_collector_spec.rb +29 -1
- data/spec/unit/decorator_spec.rb +23 -23
- data/spec/unit/dsl/platform_introspection_spec.rb +1 -0
- data/spec/unit/environment_spec.rb +12 -8
- data/spec/unit/event_dispatch/dispatcher_spec.rb +3 -0
- data/spec/unit/guard_interpreter_spec.rb +1 -1
- data/spec/unit/http/api_versions_spec.rb +20 -2
- data/spec/unit/json_compat_spec.rb +1 -1
- data/spec/unit/knife/bootstrap_spec.rb +17 -20
- data/spec/unit/knife/cookbook_download_spec.rb +6 -6
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
- data/spec/unit/knife/cookbook_show_spec.rb +6 -7
- data/spec/unit/knife/cookbook_upload_spec.rb +7 -10
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
- data/spec/unit/knife/data_bag_edit_spec.rb +1 -1
- data/spec/unit/knife/supermarket_share_spec.rb +1 -1
- data/spec/unit/log/syslog_spec.rb +6 -10
- data/spec/unit/log/winevt_spec.rb +21 -13
- data/spec/unit/lwrp_spec.rb +9 -6
- 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/powershell_out_spec.rb +2 -4
- data/spec/unit/mixin/powershell_type_coercions_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/subclass_directive_spec.rb +2 -2
- data/spec/unit/mixin/template_spec.rb +30 -30
- data/spec/unit/mixin/unformatter_spec.rb +2 -2
- data/spec/unit/mixin/uris_spec.rb +1 -1
- data/spec/unit/mixin/which.rb +8 -0
- data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
- data/spec/unit/node/immutable_collections_spec.rb +6 -2
- data/spec/unit/node_spec.rb +103 -16
- data/spec/unit/property_spec.rb +5 -5
- data/spec/unit/provider/batch_spec.rb +1 -1
- data/spec/unit/provider/cron/unix_spec.rb +1 -1
- data/spec/unit/provider/dsc_resource_spec.rb +22 -38
- data/spec/unit/provider/dsc_script_spec.rb +10 -10
- data/spec/unit/provider/execute_spec.rb +1 -8
- data/spec/unit/provider/git_spec.rb +3 -3
- data/spec/unit/provider/ifconfig_spec.rb +0 -1
- data/spec/unit/provider/mdadm_spec.rb +1 -3
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -1
- data/spec/unit/provider/package/openbsd_spec.rb +1 -1
- data/spec/unit/provider/package/pacman_spec.rb +17 -20
- 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/registry_uninstall_entry_spec.rb +3 -3
- data/spec/unit/provider/package/windows_spec.rb +30 -53
- data/spec/unit/provider/powershell_script_spec.rb +11 -4
- data/spec/unit/provider/remote_directory_spec.rb +9 -9
- 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 +3 -3
- data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
- data/spec/unit/provider/service/windows_spec.rb +2 -6
- data/spec/unit/provider/systemd_unit_spec.rb +28 -24
- data/spec/unit/provider/user/dscl_spec.rb +2 -2
- data/spec/unit/provider/windows_env_spec.rb +5 -4
- data/spec/unit/provider_resolver_spec.rb +6 -6
- data/spec/unit/provider_spec.rb +1 -0
- data/spec/unit/resource/batch_spec.rb +6 -6
- data/spec/unit/resource/chef_client_cron_spec.rb +23 -7
- data/spec/unit/resource/chef_client_systemd_timer_spec.rb +7 -4
- data/spec/unit/resource/execute_spec.rb +123 -118
- data/spec/unit/resource/file/verification_spec.rb +2 -1
- data/spec/unit/resource/macos_user_defaults_spec.rb +103 -2
- data/spec/unit/resource/osx_profile_spec.rb +233 -0
- data/spec/unit/resource/powershell_script_spec.rb +11 -29
- data/spec/unit/resource/script_spec.rb +6 -1
- data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
- 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/resource_spec.rb +25 -8
- data/spec/unit/role_spec.rb +30 -28
- 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/server_api_spec.rb +43 -16
- data/spec/unit/util/backup_spec.rb +1 -1
- data/spec/unit/util/diff_spec.rb +1 -15
- data/spec/unit/util/powershell/ps_credential_spec.rb +2 -2
- data/spec/unit/util/selinux_spec.rb +2 -1
- data/spec/unit/win32/security_spec.rb +4 -3
- data/tasks/rspec.rb +1 -1
- metadata +53 -40
- data/lib/chef/provider/osx_profile.rb +0 -255
- data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -22,6 +22,7 @@ describe Chef::Resource::WindowsFeaturePowershell do
|
|
22
22
|
let(:events) { Chef::EventDispatch::Dispatcher.new }
|
23
23
|
let(:run_context) { Chef::RunContext.new(node, {}, events) }
|
24
24
|
let(:resource) { Chef::Resource::WindowsFeaturePowershell.new(%w{SNMP DHCP}, run_context) }
|
25
|
+
let(:provider) { resource.provider_for_action(:install) }
|
25
26
|
|
26
27
|
it "sets resource name as :windows_feature_powershell" do
|
27
28
|
expect(resource.resource_name).to eql(:windows_feature_powershell)
|
@@ -35,10 +36,6 @@ describe Chef::Resource::WindowsFeaturePowershell do
|
|
35
36
|
expect(resource.feature_name).to eql(%w{snmp dhcp})
|
36
37
|
end
|
37
38
|
|
38
|
-
it "sets the default action as :install" do
|
39
|
-
expect(resource.action).to eql([:install])
|
40
|
-
end
|
41
|
-
|
42
39
|
it "supports :delete, :install, :remove actions" do
|
43
40
|
expect { resource.action :delete }.not_to raise_error
|
44
41
|
expect { resource.action :install }.not_to raise_error
|
@@ -54,4 +51,33 @@ describe Chef::Resource::WindowsFeaturePowershell do
|
|
54
51
|
resource.feature_name "SNMP"
|
55
52
|
expect(resource.feature_name).to eql(["snmp"])
|
56
53
|
end
|
54
|
+
|
55
|
+
it "install a single feature" do
|
56
|
+
resource.feature_name "snmp"
|
57
|
+
expect { resource.action :install }.not_to raise_error
|
58
|
+
end
|
59
|
+
|
60
|
+
it "install multi feature" do
|
61
|
+
resource.feature_name "SNMP, DHCP"
|
62
|
+
expect { resource.action :install }.not_to raise_error
|
63
|
+
end
|
64
|
+
|
65
|
+
it "does not attempt to install features that have been removed" do
|
66
|
+
node.default["powershell_features_cache"] ||= {}
|
67
|
+
node.default["powershell_features_cache"]["disabled"] = ["dhcp"]
|
68
|
+
node.default["powershell_features_cache"]["removed"] = ["snmp"]
|
69
|
+
resource.feature_name "dhcp, snmp"
|
70
|
+
|
71
|
+
expect(provider.features_to_install).to eq(["dhcp"])
|
72
|
+
end
|
73
|
+
|
74
|
+
it "attempts to install features that have been removed when source is set" do
|
75
|
+
node.default["powershell_features_cache"] ||= {}
|
76
|
+
node.default["powershell_features_cache"]["disabled"] = ["dhcp"]
|
77
|
+
node.default["powershell_features_cache"]["removed"] = ["snmp"]
|
78
|
+
resource.feature_name "dhcp, snmp"
|
79
|
+
resource.source 'D:\\sources\\sxs'
|
80
|
+
|
81
|
+
expect(provider.features_to_install).to eq(%w{dhcp snmp})
|
82
|
+
end
|
57
83
|
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
#
|
2
|
+
# Copyright:: Copyright (c) Chef Software Inc.
|
3
|
+
# License:: Apache License, Version 2.0
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
#
|
17
|
+
|
18
|
+
require "spec_helper"
|
19
|
+
|
20
|
+
describe Chef::Resource::WindowsFirewallProfile do
|
21
|
+
let(:resource) { Chef::Resource::WindowsFirewallProfile.new("fakey_fakerton") }
|
22
|
+
|
23
|
+
it "sets resource name as :windows_firewall_profile" do
|
24
|
+
expect(resource.resource_name).to eql(:windows_firewall_profile)
|
25
|
+
end
|
26
|
+
|
27
|
+
%w{ Domain Private Public }.each do |this_profile|
|
28
|
+
it "The profile accepts values for the \"#{this_profile}\" Profile" do
|
29
|
+
expect { resource.profile this_profile }.not_to raise_error
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
it "the profile property does not accept bad profile names" do
|
34
|
+
expect { resource.profile "Special" }.to raise_error(Chef::Exceptions::ValidationFailed)
|
35
|
+
end
|
36
|
+
|
37
|
+
it "the resource's default_inbound_action property only strings Block, Allow, or NotConfigured" do
|
38
|
+
expect { resource.default_inbound_action "AllowSome" }.to raise_error(ArgumentError)
|
39
|
+
expect { resource.default_inbound_action "Block" }.not_to raise_error
|
40
|
+
end
|
41
|
+
it "the resource's default_outbound_action property only accepts strings Block, Allow, or NotConfigured" do
|
42
|
+
expect { resource.default_outbound_action "BlockMost" }.to raise_error(ArgumentError)
|
43
|
+
expect { resource.default_outbound_action "Allow" }.not_to raise_error
|
44
|
+
end
|
45
|
+
it "the resource's allow_inbound_rules property only accepts strings true, false, or NotConfigured" do
|
46
|
+
expect { resource.allow_inbound_rules "Yes" }.to raise_error(ArgumentError)
|
47
|
+
expect { resource.allow_inbound_rules true }.not_to raise_error
|
48
|
+
end
|
49
|
+
it "the resource's allow_local_firewall_rules property only accepts strings true, false, or NotConfigured" do
|
50
|
+
expect { resource.allow_local_firewall_rules "No" }.to raise_error(ArgumentError)
|
51
|
+
expect { resource.allow_local_firewall_rules false }.not_to raise_error
|
52
|
+
end
|
53
|
+
it "the resource's allow_local_ipsec_rules property only accepts strings true, false, or NotConfigured" do
|
54
|
+
expect { resource.allow_local_ipsec_rules "Yes" }.to raise_error(ArgumentError)
|
55
|
+
expect { resource.allow_local_ipsec_rules true }.not_to raise_error
|
56
|
+
end
|
57
|
+
it "the resource's allow_user_apps property only accepts strings true, false, or NotConfigured" do
|
58
|
+
expect { resource.allow_user_apps "No" }.to raise_error(ArgumentError)
|
59
|
+
expect { resource.allow_user_apps false }.not_to raise_error
|
60
|
+
end
|
61
|
+
it "the resource's allow_user_ports property only accepts strings true, false, or NotConfigured" do
|
62
|
+
expect { resource.allow_user_ports "Nope" }.to raise_error(ArgumentError)
|
63
|
+
expect { resource.allow_user_ports "NotConfigured" }.not_to raise_error
|
64
|
+
end
|
65
|
+
it "the resource's allow_unicast_response property only accepts strings true, false, or NotConfigured" do
|
66
|
+
expect { resource.allow_unicast_response "True" }.to raise_error(ArgumentError)
|
67
|
+
expect { resource.allow_unicast_response true }.not_to raise_error
|
68
|
+
end
|
69
|
+
it "the resource's display_notification property only accepts strings true, false, or NotConfigured" do
|
70
|
+
expect { resource.display_notification "False" }.to raise_error(ArgumentError)
|
71
|
+
expect { resource.display_notification false }.not_to raise_error
|
72
|
+
end
|
73
|
+
|
74
|
+
it "sets the default action as :configure" do
|
75
|
+
expect(resource.action).to eql([:enable])
|
76
|
+
end
|
77
|
+
end
|
@@ -58,6 +58,7 @@ describe Chef::Resource::WindowsPackage, "initialize" do
|
|
58
58
|
expect { resource.installer_type :msi }.not_to raise_error
|
59
59
|
expect { resource.installer_type :nsis }.not_to raise_error
|
60
60
|
expect { resource.installer_type :wise }.not_to raise_error
|
61
|
+
expect { resource.installer_type :something_else_entirely }.to raise_error(Chef::Exceptions::ValidationFailed)
|
61
62
|
expect { resource.installer_type "msi" }.to raise_error(Chef::Exceptions::ValidationFailed)
|
62
63
|
end
|
63
64
|
|
data/spec/unit/resource_spec.rb
CHANGED
@@ -1255,19 +1255,36 @@ describe Chef::Resource do
|
|
1255
1255
|
expect(block_value).to eq(original_umask)
|
1256
1256
|
end
|
1257
1257
|
|
1258
|
-
|
1259
|
-
|
1258
|
+
if windows?
|
1259
|
+
it "is a no-op on Windows" do
|
1260
|
+
resource.umask = "0123"
|
1260
1261
|
|
1261
|
-
|
1262
|
+
block_value = nil
|
1262
1263
|
|
1263
|
-
|
1264
|
-
|
1264
|
+
resource.with_umask do
|
1265
|
+
block_value = ::File.umask
|
1266
|
+
end
|
1267
|
+
|
1268
|
+
# Format the returned value so a potential error message is easier to understand.
|
1269
|
+
actual_value = block_value.to_s(8).rjust(4, "0")
|
1270
|
+
|
1271
|
+
expect(actual_value).to eq("0000")
|
1265
1272
|
end
|
1273
|
+
else
|
1274
|
+
it "changes the umask in the block to the set value" do
|
1275
|
+
resource.umask = "0123"
|
1276
|
+
|
1277
|
+
block_value = nil
|
1266
1278
|
|
1267
|
-
|
1268
|
-
|
1279
|
+
resource.with_umask do
|
1280
|
+
block_value = ::File.umask
|
1281
|
+
end
|
1269
1282
|
|
1270
|
-
|
1283
|
+
# Format the returned value so a potential error message is easier to understand.
|
1284
|
+
actual_value = block_value.to_s(8).rjust(4, "0")
|
1285
|
+
|
1286
|
+
expect(actual_value).to eq("0123")
|
1287
|
+
end
|
1271
1288
|
end
|
1272
1289
|
|
1273
1290
|
it "resets the umask afterwards" do
|
data/spec/unit/role_spec.rb
CHANGED
@@ -259,7 +259,7 @@ describe Chef::Role do
|
|
259
259
|
it "should return a Chef::Role object from JSON" do
|
260
260
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/memes", "#{Chef::Config[:role_path]}/memes/lolcat.json"])
|
261
261
|
file_path = File.join(Chef::Config[:role_path], "memes/lolcat.json")
|
262
|
-
expect(File).to receive(:
|
262
|
+
expect(File).to receive(:exist?).with(file_path).exactly(1).times.and_return(true)
|
263
263
|
expect(IO).to receive(:read).with(file_path).and_return('{"name": "ceiling_cat", "json_class": "Chef::Role" }')
|
264
264
|
expect(@role).to be_a_kind_of(Chef::Role)
|
265
265
|
@role.class.from_disk("lolcat")
|
@@ -268,7 +268,7 @@ describe Chef::Role do
|
|
268
268
|
it "should return a Chef::Role object from a Ruby DSL" do
|
269
269
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/memes", "#{Chef::Config[:role_path]}/memes/lolcat.rb"])
|
270
270
|
rb_path = File.join(Chef::Config[:role_path], "memes/lolcat.rb")
|
271
|
-
expect(File).to receive(:
|
271
|
+
expect(File).to receive(:exist?).with(rb_path).exactly(1).times.and_return(true)
|
272
272
|
expect(File).to receive(:readable?).with(rb_path).exactly(1).times.and_return(true)
|
273
273
|
expect(File).to receive(:file?).with(rb_path).exactly(1).times.and_return(true)
|
274
274
|
expect(IO).to receive(:read).with(rb_path).and_return(ROLE_DSL)
|
@@ -280,8 +280,8 @@ describe Chef::Role do
|
|
280
280
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/memes", "#{Chef::Config[:role_path]}/memes/lolcat.json", "#{Chef::Config[:role_path]}/memes/lolcat.rb"])
|
281
281
|
js_path = File.join(Chef::Config[:role_path], "memes/lolcat.json")
|
282
282
|
rb_path = File.join(Chef::Config[:role_path], "memes/lolcat.rb")
|
283
|
-
expect(File).to receive(:
|
284
|
-
expect(File).not_to receive(:
|
283
|
+
expect(File).to receive(:exist?).with(js_path).exactly(1).times.and_return(true)
|
284
|
+
expect(File).not_to receive(:exist?).with(rb_path)
|
285
285
|
expect(IO).to receive(:read).with(js_path).and_return('{"name": "ceiling_cat", "json_class": "Chef::Role" }')
|
286
286
|
expect(@role).to be_a_kind_of(Chef::Role)
|
287
287
|
@role.class.from_disk("lolcat")
|
@@ -289,19 +289,19 @@ describe Chef::Role do
|
|
289
289
|
|
290
290
|
it "should raise an exception if the file does not exist" do
|
291
291
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/meme.rb"])
|
292
|
-
expect(File).not_to receive(:
|
292
|
+
expect(File).not_to receive(:exist?)
|
293
293
|
expect { @role.class.from_disk("lolcat") }.to raise_error(Chef::Exceptions::RoleNotFound)
|
294
294
|
end
|
295
295
|
|
296
296
|
it "should raise an exception if two files exist with the same name" do
|
297
297
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/memes/lolcat.rb", "#{Chef::Config[:role_path]}/lolcat.rb"])
|
298
|
-
expect(File).not_to receive(:
|
298
|
+
expect(File).not_to receive(:exist?)
|
299
299
|
expect { @role.class.from_disk("lolcat") }.to raise_error(Chef::Exceptions::DuplicateRole)
|
300
300
|
end
|
301
301
|
|
302
302
|
it "should not raise an exception if two files exist with a similar name" do
|
303
303
|
expect(Dir).to receive(:glob).and_return(["#{Chef::Config[:role_path]}/memes/lolcat.rb", "#{Chef::Config[:role_path]}/super_lolcat.rb"])
|
304
|
-
expect(File).to receive(:
|
304
|
+
expect(File).to receive(:exist?).with("#{Chef::Config[:role_path]}/memes/lolcat.rb").and_return(true)
|
305
305
|
allow_any_instance_of(Chef::Role).to receive(:from_file).with("#{Chef::Config[:role_path]}/memes/lolcat.rb")
|
306
306
|
expect { @role.class.from_disk("lolcat") }.not_to raise_error
|
307
307
|
end
|
@@ -310,50 +310,52 @@ describe Chef::Role do
|
|
310
310
|
describe "when loading from disk and role_path is an array" do
|
311
311
|
|
312
312
|
before(:each) do
|
313
|
-
Chef::Config[:role_path] = ["/path1", "/
|
313
|
+
Chef::Config[:role_path] = ["/path1", "/path1/path2"]
|
314
314
|
end
|
315
315
|
|
316
|
+
let(:root) { windows? ? "C:/path1" : "/path1" }
|
317
|
+
|
316
318
|
it "should return a Chef::Role object from JSON" do
|
317
|
-
expect(Dir).to receive(:glob).with(File.join(
|
318
|
-
expect(File).to receive(:
|
319
|
-
expect(IO).to receive(:read).with("/
|
319
|
+
expect(Dir).to receive(:glob).with(File.join(root, "**", "**")).exactly(1).times.and_return(["#{root}/lolcat.json"])
|
320
|
+
expect(File).to receive(:exist?).with("#{root}/lolcat.json").exactly(1).times.and_return(true)
|
321
|
+
expect(IO).to receive(:read).with("#{root}/lolcat.json").and_return('{"name": "ceiling_cat", "json_class": "Chef::Role" }')
|
320
322
|
expect(@role).to be_a_kind_of(Chef::Role)
|
321
323
|
@role.class.from_disk("lolcat")
|
322
324
|
end
|
323
325
|
|
324
326
|
it "should return a Chef::Role object from JSON when role is in the second path" do
|
325
|
-
expect(Dir).to receive(:glob).with(File.join(
|
326
|
-
expect(Dir).to receive(:glob).with(File.join("/
|
327
|
-
expect(File).to receive(:
|
328
|
-
expect(IO).to receive(:read).with("/
|
327
|
+
expect(Dir).to receive(:glob).with(File.join(root, "**", "**")).exactly(1).times.and_return([])
|
328
|
+
expect(Dir).to receive(:glob).with(File.join("#{root}/path2", "**", "**")).exactly(1).times.and_return(["#{root}/path2/lolcat.json"])
|
329
|
+
expect(File).to receive(:exist?).with("#{root}/path2/lolcat.json").exactly(1).times.and_return(true)
|
330
|
+
expect(IO).to receive(:read).with("#{root}/path2/lolcat.json").and_return('{"name": "ceiling_cat", "json_class": "Chef::Role" }')
|
329
331
|
expect(@role).to be_a_kind_of(Chef::Role)
|
330
332
|
@role.class.from_disk("lolcat")
|
331
333
|
end
|
332
334
|
|
333
335
|
it "should return a Chef::Role object from a Ruby DSL" do
|
334
|
-
expect(Dir).to receive(:glob).with(File.join(
|
335
|
-
expect(File).to receive(:
|
336
|
-
expect(File).to receive(:readable?).with("/
|
337
|
-
expect(File).to receive(:file?).with("/
|
338
|
-
expect(IO).to receive(:read).with("/
|
336
|
+
expect(Dir).to receive(:glob).with(File.join(root, "**", "**")).exactly(1).times.and_return(["#{root}/lolcat.rb"])
|
337
|
+
expect(File).to receive(:exist?).with("#{root}/lolcat.rb").exactly(1).times.and_return(true)
|
338
|
+
expect(File).to receive(:readable?).with("#{root}/lolcat.rb").and_return(true)
|
339
|
+
expect(File).to receive(:file?).with("#{root}/lolcat.rb").and_return(true)
|
340
|
+
expect(IO).to receive(:read).with("#{root}/lolcat.rb").exactly(1).times.and_return(ROLE_DSL)
|
339
341
|
expect(@role).to be_a_kind_of(Chef::Role)
|
340
342
|
@role.class.from_disk("lolcat")
|
341
343
|
end
|
342
344
|
|
343
345
|
it "should return a Chef::Role object from a Ruby DSL when role is in the second path" do
|
344
|
-
expect(Dir).to receive(:glob).with(File.join(
|
345
|
-
expect(Dir).to receive(:glob).with(File.join("/
|
346
|
-
expect(File).to receive(:
|
347
|
-
expect(File).to receive(:readable?).with("/
|
348
|
-
expect(File).to receive(:file?).with("/
|
349
|
-
expect(IO).to receive(:read).with("/
|
346
|
+
expect(Dir).to receive(:glob).with(File.join(root, "**", "**")).exactly(1).times.and_return([])
|
347
|
+
expect(Dir).to receive(:glob).with(File.join("#{root}/path2", "**", "**")).exactly(1).times.and_return(["#{root}/path2/lolcat.rb"])
|
348
|
+
expect(File).to receive(:exist?).with("#{root}/path2/lolcat.rb").exactly(1).times.and_return(true)
|
349
|
+
expect(File).to receive(:readable?).with("#{root}/path2/lolcat.rb").and_return(true)
|
350
|
+
expect(File).to receive(:file?).with("#{root}/path2/lolcat.rb").and_return(true)
|
351
|
+
expect(IO).to receive(:read).with("#{root}/path2/lolcat.rb").exactly(1).times.and_return(ROLE_DSL)
|
350
352
|
expect(@role).to be_a_kind_of(Chef::Role)
|
351
353
|
@role.class.from_disk("lolcat")
|
352
354
|
end
|
353
355
|
|
354
356
|
it "should raise an exception if the file does not exist" do
|
355
|
-
expect(Dir).to receive(:glob).with(File.join(
|
356
|
-
expect(Dir).to receive(:glob).with(File.join("/
|
357
|
+
expect(Dir).to receive(:glob).with(File.join(root, "**", "**")).exactly(1).times.and_return([])
|
358
|
+
expect(Dir).to receive(:glob).with(File.join("#{root}/path2", "**", "**")).exactly(1).times.and_return([])
|
357
359
|
expect { @role.class.from_disk("lolcat") }.to raise_error(Chef::Exceptions::RoleNotFound)
|
358
360
|
end
|
359
361
|
|
@@ -175,7 +175,7 @@ describe Chef::RunContext::CookbookCompiler do
|
|
175
175
|
describe "event dispatch" do
|
176
176
|
let(:recipe) { "dependency1::default" }
|
177
177
|
let(:recipe_path) do
|
178
|
-
File.expand_path("
|
178
|
+
File.expand_path("../../data/run_context/cookbooks/dependency1/recipes/default.rb", __dir__)
|
179
179
|
end
|
180
180
|
before do
|
181
181
|
node.run_list(recipe)
|
data/spec/unit/run_lock_spec.rb
CHANGED
@@ -59,20 +59,22 @@ describe Chef::ServerAPI do
|
|
59
59
|
end
|
60
60
|
|
61
61
|
context "versioned apis" do
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
62
|
+
let(:version_class) do
|
63
|
+
Class.new do
|
64
|
+
extend Chef::Mixin::VersionedAPIFactory
|
65
|
+
|
66
|
+
version_class_v0 = Class.new do
|
67
|
+
extend Chef::Mixin::VersionedAPI
|
68
|
+
minimum_api_version 0
|
69
|
+
end
|
70
|
+
add_versioned_api_class version_class_v0
|
71
|
+
|
72
|
+
version_class_v2 = Class.new do
|
73
|
+
extend Chef::Mixin::VersionedAPI
|
74
|
+
minimum_api_version 2
|
75
|
+
end
|
76
|
+
add_versioned_api_class version_class_v2
|
77
|
+
end
|
76
78
|
end
|
77
79
|
|
78
80
|
before do
|
@@ -80,7 +82,7 @@ describe Chef::ServerAPI do
|
|
80
82
|
end
|
81
83
|
|
82
84
|
let(:versioned_client) do
|
83
|
-
Chef::ServerAPI.new(url, version_class:
|
85
|
+
Chef::ServerAPI.new(url, version_class: version_class)
|
84
86
|
end
|
85
87
|
|
86
88
|
it "on protocol negotiation it posts the same message body without doubly-encoding the json string" do
|
@@ -114,11 +116,36 @@ describe Chef::ServerAPI do
|
|
114
116
|
|
115
117
|
it "500 on a get retries and gets correctly " do
|
116
118
|
WebMock.disable_net_connect!
|
117
|
-
get_body = { bar: "baz" }
|
118
119
|
headers = { "Accept" => "application/json", "Accept-Encoding" => "gzip;q=1.0,deflate;q=0.6,identity;q=0.3", "Host" => "chef.example.com:4000", "X-Chef-Version" => Chef::VERSION, "X-Ops-Sign" => "algorithm=sha1;version=1.1;", "X-Ops-Userid" => "silent-bob" }
|
119
120
|
stub_request(:get, "http://chef.example.com:4000/foo").with(headers: headers).to_return(status: [500, "Internal Server Error"])
|
120
121
|
stub_request(:get, "http://chef.example.com:4000/foo").with(headers: headers).to_return(status: 200, body: "", headers: {})
|
121
122
|
client.get("foo")
|
122
123
|
end
|
124
|
+
|
125
|
+
it "406 on a post does protocol negotiation" do
|
126
|
+
WebMock.disable_net_connect!
|
127
|
+
post_body = { bar: "baz" }
|
128
|
+
body_406 = '{"error":"invalid-x-ops-server-api-version","message":"Specified version 2 not supported","min_version":0,"max_version":1}'
|
129
|
+
stub_request(:post, "http://chef.example.com:4000/foo").with(body: post_body.to_json, headers: { "X-Ops-Server-Api-Version" => "2" }).to_return(status: [406, "Not Acceptable"], body: body_406 )
|
130
|
+
stub_request(:post, "http://chef.example.com:4000/foo").with(body: post_body.to_json, headers: { "X-Ops-Server-Api-Version" => "0" }).to_return(status: 200, body: "", headers: {})
|
131
|
+
client.post("foo", post_body)
|
132
|
+
end
|
133
|
+
|
134
|
+
it "406 on a put does protocol negotiation" do
|
135
|
+
WebMock.disable_net_connect!
|
136
|
+
put_body = { bar: "baz" }
|
137
|
+
body_406 = '{"error":"invalid-x-ops-server-api-version","message":"Specified version 2 not supported","min_version":0,"max_version":1}'
|
138
|
+
stub_request(:put, "http://chef.example.com:4000/foo").with(body: put_body.to_json, headers: { "X-Ops-Server-Api-Version" => "2" }).to_return(status: [406, "Not Acceptable"], body: body_406 )
|
139
|
+
stub_request(:put, "http://chef.example.com:4000/foo").with(body: put_body.to_json, headers: { "X-Ops-Server-Api-Version" => "0" }).to_return(status: 200, body: "", headers: {})
|
140
|
+
client.put("foo", put_body)
|
141
|
+
end
|
142
|
+
|
143
|
+
it "406 on a get does protocol negotiation" do
|
144
|
+
WebMock.disable_net_connect!
|
145
|
+
body_406 = '{"error":"invalid-x-ops-server-api-version","message":"Specified version 2 not supported","min_version":0,"max_version":1}'
|
146
|
+
stub_request(:get, "http://chef.example.com:4000/foo").with(headers: { "X-Ops-Server-Api-Version" => "2" }).to_return(status: [406, "Not Acceptable"], body: body_406 )
|
147
|
+
stub_request(:get, "http://chef.example.com:4000/foo").with(headers: { "X-Ops-Server-Api-Version" => "0" }).to_return(status: 200, body: "", headers: {})
|
148
|
+
client.get("foo")
|
149
|
+
end
|
123
150
|
end
|
124
151
|
end
|
data/spec/unit/util/diff_spec.rb
CHANGED
@@ -61,10 +61,6 @@ shared_examples_for "a diff util" do
|
|
61
61
|
Chef::Config[:diff_disabled] = true
|
62
62
|
end
|
63
63
|
|
64
|
-
after do
|
65
|
-
Chef::Config[:diff_disabled] = false
|
66
|
-
end
|
67
|
-
|
68
64
|
it "calling for_output should return the error message" do
|
69
65
|
expect(differ.for_output).to eql( [ "(diff output suppressed by config)" ] )
|
70
66
|
end
|
@@ -300,14 +296,9 @@ shared_examples_for "a diff util" do
|
|
300
296
|
|
301
297
|
describe "when testing the diff_filesize_threshold" do
|
302
298
|
before do
|
303
|
-
@diff_filesize_threshold_saved = Chef::Config[:diff_filesize_threshold]
|
304
299
|
Chef::Config[:diff_filesize_threshold] = 10
|
305
300
|
end
|
306
301
|
|
307
|
-
after do
|
308
|
-
Chef::Config[:diff_filesize_threshold] = @diff_filesize_threshold_saved
|
309
|
-
end
|
310
|
-
|
311
302
|
describe "when the old_file goes over the threshold" do
|
312
303
|
before do
|
313
304
|
old_tempfile.write("But thats what you get when Wu-Tang raised you")
|
@@ -359,14 +350,9 @@ shared_examples_for "a diff util" do
|
|
359
350
|
describe "when the diff output is too long" do
|
360
351
|
|
361
352
|
before do
|
362
|
-
@diff_output_threshold_saved = Chef::Config[:diff_output_threshold]
|
363
353
|
Chef::Config[:diff_output_threshold] = 10
|
364
354
|
end
|
365
355
|
|
366
|
-
after do
|
367
|
-
Chef::Config[:diff_output_threshold] = @diff_output_threshold_saved
|
368
|
-
end
|
369
|
-
|
370
356
|
it "calling for_output should return the error message" do
|
371
357
|
expect(differ.for_output).to eql(["(long diff of over 10 characters, diff output suppressed)"])
|
372
358
|
end
|
@@ -546,7 +532,7 @@ shared_examples_for "a diff util" do
|
|
546
532
|
|
547
533
|
end
|
548
534
|
|
549
|
-
describe Chef::Util::Diff
|
535
|
+
describe Chef::Util::Diff do
|
550
536
|
let!(:old_file) { old_tempfile.path }
|
551
537
|
let!(:new_file) { new_tempfile.path }
|
552
538
|
|