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
data/spec/unit/knife/ssh_spec.rb
CHANGED
@@ -283,10 +283,10 @@ describe Chef::Knife::Ssh do
|
|
283
283
|
end
|
284
284
|
|
285
285
|
describe "#ssh_command" do
|
286
|
-
let(:execution_channel) { double(:execution_channel, on_data: nil) }
|
286
|
+
let(:execution_channel) { double(:execution_channel, on_data: nil, on_extended_data: nil) }
|
287
287
|
let(:session_channel) { double(:session_channel, request_pty: nil) }
|
288
288
|
|
289
|
-
let(:execution_channel2) { double(:execution_channel, on_data: nil) }
|
289
|
+
let(:execution_channel2) { double(:execution_channel, on_data: nil, on_extended_data: nil) }
|
290
290
|
let(:session_channel2) { double(:session_channel, request_pty: nil) }
|
291
291
|
|
292
292
|
let(:session) { double(:session, loop: nil) }
|
@@ -108,7 +108,7 @@ describe Chef::Knife::SupermarketShare do
|
|
108
108
|
expect { @knife.run }.to raise_error(SystemExit)
|
109
109
|
end
|
110
110
|
|
111
|
-
if File.
|
111
|
+
if File.exist?("/usr/bin/gnutar") || File.exist?("/bin/gnutar")
|
112
112
|
it "should use gnutar to make a tarball of the cookbook" do
|
113
113
|
expect(@knife).to receive(:shell_out!) do |args|
|
114
114
|
expect(args.to_s).to match(/gnutar -czf/)
|
data/spec/unit/lwrp_spec.rb
CHANGED
@@ -169,7 +169,7 @@ describe "LWRP" do
|
|
169
169
|
describe "Lightweight Chef::Resource" do
|
170
170
|
|
171
171
|
before do
|
172
|
-
Dir[File.expand_path(File.join(
|
172
|
+
Dir[File.expand_path(File.join(__dir__, "..", "data", "lwrp", "resources", "*"))].each do |file|
|
173
173
|
Chef::Resource::LWRPBase.build_from_file("lwrp", file, nil)
|
174
174
|
end
|
175
175
|
end
|
@@ -211,7 +211,7 @@ describe "LWRP" do
|
|
211
211
|
node.normal[:penguin_name] = "jackass"
|
212
212
|
run_context = Chef::RunContext.new(node, Chef::CookbookCollection.new, @events)
|
213
213
|
|
214
|
-
Dir[File.expand_path(File.join(
|
214
|
+
Dir[File.expand_path(File.join(__dir__, "..", "data", "lwrp", "resources_with_default_attributes", "*"))].each do |file|
|
215
215
|
Chef::Resource::LWRPBase.build_from_file("lwrp", file, run_context)
|
216
216
|
end
|
217
217
|
|
@@ -654,7 +654,7 @@ describe "LWRP" do
|
|
654
654
|
end
|
655
655
|
|
656
656
|
let(:run_context) do
|
657
|
-
cookbook_repo = File.expand_path(File.join(
|
657
|
+
cookbook_repo = File.expand_path(File.join(__dir__, "..", "data", "cookbooks"))
|
658
658
|
cookbook_loader = Chef::CookbookLoader.new(cookbook_repo)
|
659
659
|
cookbook_loader.load_cookbooks
|
660
660
|
cookbook_collection = Chef::CookbookCollection.new(cookbook_loader)
|
@@ -236,6 +236,14 @@ describe Chef::Mixin::DeepMerge, "deep_merge!" do
|
|
236
236
|
@dm.deep_merge!(hash_src, hash_dst)
|
237
237
|
expect(hash_dst).to eq({ "item" => "orange" })
|
238
238
|
end
|
239
|
+
|
240
|
+
it "should overwrite a string with a nil when merging nil values" do
|
241
|
+
hash_src = { "item" => nil }
|
242
|
+
hash_dst = { "item" => "orange" }
|
243
|
+
@dm.deep_merge!(hash_src, hash_dst)
|
244
|
+
expect(hash_dst).to eq({ "item" => nil })
|
245
|
+
end
|
246
|
+
|
239
247
|
end # deep_merge!
|
240
248
|
|
241
249
|
# Chef specific
|
@@ -338,5 +346,12 @@ describe Chef::Mixin::DeepMerge do
|
|
338
346
|
merge_with_hash = { "top_level_a" => 2, "top_level_b" => true }
|
339
347
|
@dm.hash_only_merge(merge_ee_hash, merge_with_hash)
|
340
348
|
end
|
349
|
+
|
350
|
+
it "should overwrite a string with a nil when merging nil values" do
|
351
|
+
hash_src = { "item" => nil }
|
352
|
+
hash_dst = { "item" => "orange" }
|
353
|
+
merged_result = @dm.hash_only_merge(hash_dst, hash_src)
|
354
|
+
expect(merged_result).to eq({ "item" => nil })
|
355
|
+
end
|
341
356
|
end
|
342
357
|
end
|
@@ -99,7 +99,7 @@ describe Chef::Mixin::OpenSSLHelper do
|
|
99
99
|
|
100
100
|
context "When the dhparam.pem file does exist, and does contain a vaild dhparam key" do
|
101
101
|
it "returns true" do
|
102
|
-
@dhparam_file.puts(::OpenSSL::PKey::DH.new(
|
102
|
+
@dhparam_file.puts(::OpenSSL::PKey::DH.new(256).to_pem) # this is 256 to speed up specs
|
103
103
|
@dhparam_file.close
|
104
104
|
expect(instance.dhparam_pem_valid?(@dhparam_file.path)).to be_truthy
|
105
105
|
end
|
@@ -19,7 +19,7 @@
|
|
19
19
|
require "spec_helper"
|
20
20
|
require "chef/mixin/powershell_exec"
|
21
21
|
|
22
|
-
describe Chef::Mixin::PowershellExec, :windows_only do
|
22
|
+
describe Chef::Mixin::PowershellExec, :windows_only, :windows_gte_10 do
|
23
23
|
let(:powershell_mixin) { Class.new { include Chef::Mixin::PowershellExec } }
|
24
24
|
subject(:object) { powershell_mixin.new }
|
25
25
|
|
@@ -45,7 +45,7 @@ describe Chef::Mixin::Securable do
|
|
45
45
|
describe "unix-specific behavior" do
|
46
46
|
before(:each) do
|
47
47
|
platform_mock :unix do
|
48
|
-
load File.join(
|
48
|
+
load File.join(__dir__, "..", "..", "..", "lib", "chef", "mixin", "securable.rb")
|
49
49
|
@securable = Object.new
|
50
50
|
@securable.send(:extend, Chef::Mixin::Securable)
|
51
51
|
@securable.send(:extend, Chef::Mixin::ParamsValidate)
|
@@ -176,7 +176,7 @@ describe Chef::Mixin::Securable do
|
|
176
176
|
describe "windows-specific behavior" do
|
177
177
|
before(:each) do
|
178
178
|
platform_mock :windows do
|
179
|
-
load File.join(
|
179
|
+
load File.join(__dir__, "..", "..", "..", "lib", "chef", "mixin", "securable.rb")
|
180
180
|
securable_class = Class.new do
|
181
181
|
include Chef::Mixin::Securable
|
182
182
|
include Chef::Mixin::ParamsValidate
|
@@ -104,16 +104,16 @@ describe Chef::Mixin::Template, "render_template" do
|
|
104
104
|
end
|
105
105
|
|
106
106
|
it "should render local files" do
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
107
|
+
|
108
|
+
tf = Tempfile.new("partial")
|
109
|
+
tf.write "test"
|
110
|
+
tf.rewind
|
111
|
+
|
112
|
+
output = @template_context.render_template_from_string("before {<%= render '#{tf.path}', :local => true %>} after")
|
113
|
+
expect(output).to eq("before {test} after")
|
114
|
+
ensure
|
115
|
+
tf.close
|
116
|
+
|
117
117
|
end
|
118
118
|
|
119
119
|
it "should render partials from a different cookbook" do
|
@@ -124,16 +124,16 @@ describe Chef::Mixin::Template, "render_template" do
|
|
124
124
|
end
|
125
125
|
|
126
126
|
it "should render using the source argument if provided" do
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
127
|
+
|
128
|
+
tf = Tempfile.new("partial")
|
129
|
+
tf.write "test"
|
130
|
+
tf.rewind
|
131
|
+
|
132
|
+
output = @template_context.render_template_from_string("before {<%= render 'something', :local => true, :source => '#{tf.path}' %>} after")
|
133
|
+
expect(output).to eq("before {test} after")
|
134
|
+
ensure
|
135
|
+
tf.close
|
136
|
+
|
137
137
|
end
|
138
138
|
|
139
139
|
it "should pass the node to partials" do
|
@@ -195,11 +195,11 @@ describe Chef::Mixin::Template, "render_template" do
|
|
195
195
|
|
196
196
|
describe "the raised TemplateError" do
|
197
197
|
subject(:exception) do
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
198
|
+
|
199
|
+
do_raise
|
200
|
+
rescue Chef::Mixin::Template::TemplateError => e
|
201
|
+
e
|
202
|
+
|
203
203
|
end
|
204
204
|
|
205
205
|
it "should contain template file and line numbers" do
|
@@ -274,11 +274,11 @@ describe Chef::Mixin::Template, "render_template" do
|
|
274
274
|
|
275
275
|
describe "the raised TemplateError" do
|
276
276
|
before :each do
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
277
|
+
|
278
|
+
do_raise
|
279
|
+
rescue Chef::Mixin::Template::TemplateError => e
|
280
|
+
@exception = e
|
281
|
+
|
282
282
|
end
|
283
283
|
|
284
284
|
it "should have the original exception" do
|
@@ -50,10 +50,10 @@ describe Chef::Mixin::WindowsArchitectureHelper do
|
|
50
50
|
|
51
51
|
it "raises an error if an invalid architecture is passed to assert_valid_windows_architecture!" do
|
52
52
|
@invalid_architectures.each do |architecture|
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
53
|
+
|
54
|
+
expect(assert_valid_windows_architecture!(architecture)).to raise_error Chef::Exceptions::Win32ArchitectureIncorrect
|
55
|
+
rescue Chef::Exceptions::Win32ArchitectureIncorrect
|
56
|
+
|
57
57
|
end
|
58
58
|
end
|
59
59
|
|
@@ -73,7 +73,11 @@ shared_examples_for "Immutable#to_yaml" do
|
|
73
73
|
end
|
74
74
|
|
75
75
|
it "should create a YAML string with content" do
|
76
|
-
|
76
|
+
# Roundtrip the test string through YAML to compensate for some changes in libyaml-0.2.5
|
77
|
+
# See: https://github.com/yaml/libyaml/pull/186
|
78
|
+
expected = YAML.dump(YAML.load(parsed_yaml))
|
79
|
+
|
80
|
+
expect(copy).to eq(expected)
|
77
81
|
end
|
78
82
|
end
|
79
83
|
|
@@ -126,7 +130,7 @@ describe Chef::Node::ImmutableMash do
|
|
126
130
|
end
|
127
131
|
|
128
132
|
%w{to_h to_hash dup}.each do |immutable_meth|
|
129
|
-
describe
|
133
|
+
describe immutable_meth do
|
130
134
|
include_examples "ImmutableMash module", description
|
131
135
|
end
|
132
136
|
end
|
@@ -234,14 +238,14 @@ describe Chef::Node::ImmutableArray do
|
|
234
238
|
end
|
235
239
|
|
236
240
|
%w{to_a to_array dup}.each do |immutable_meth|
|
237
|
-
describe
|
241
|
+
describe immutable_meth do
|
238
242
|
include_examples "ImmutableArray module", description
|
239
243
|
end
|
240
244
|
end
|
241
245
|
|
242
246
|
describe "to_yaml" do
|
243
247
|
let(:copy) { @immutable_nested_array.to_yaml }
|
244
|
-
let(:parsed_yaml) { "---\n- level1\n- - foo\n - bar\n - baz\n - 1\n - 2\n - 3\n
|
248
|
+
let(:parsed_yaml) { "---\n- level1\n- - foo\n - bar\n - baz\n - 1\n - 2\n - 3\n -\n - true\n - false\n - - el\n - 0\n -\n- m: m\n" }
|
245
249
|
|
246
250
|
include_examples "Immutable#to_yaml"
|
247
251
|
end
|
data/spec/unit/node_spec.rb
CHANGED
@@ -1773,11 +1773,11 @@ describe Chef::Node do
|
|
1773
1773
|
end
|
1774
1774
|
|
1775
1775
|
let(:http_exception) do
|
1776
|
-
|
1777
|
-
|
1778
|
-
|
1779
|
-
|
1780
|
-
|
1776
|
+
|
1777
|
+
response.error!
|
1778
|
+
rescue => e
|
1779
|
+
e
|
1780
|
+
|
1781
1781
|
end
|
1782
1782
|
|
1783
1783
|
let(:trimmed_node) do
|
@@ -0,0 +1,97 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Chef::Provider::Mount::Linux do
|
4
|
+
|
5
|
+
let(:run_context) do
|
6
|
+
node = Chef::Node.new
|
7
|
+
events = Chef::EventDispatch::Dispatcher.new
|
8
|
+
run_context = Chef::RunContext.new(node, {}, events)
|
9
|
+
end
|
10
|
+
|
11
|
+
let(:new_resource) do
|
12
|
+
new_resource = Chef::Resource::Mount.new("/tmp/foo")
|
13
|
+
new_resource.device "/dev/sdz1"
|
14
|
+
new_resource.device_type :device
|
15
|
+
new_resource.fstype "ext3"
|
16
|
+
new_resource.supports remount: false
|
17
|
+
new_resource
|
18
|
+
end
|
19
|
+
|
20
|
+
let(:provider) do
|
21
|
+
Chef::Provider::Mount::Linux.new(new_resource, run_context)
|
22
|
+
end
|
23
|
+
|
24
|
+
before(:each) do
|
25
|
+
allow(::File).to receive(:exists?).with("/dev/sdz1").and_return true
|
26
|
+
allow(::File).to receive(:exists?).with("/tmp/foo").and_return true
|
27
|
+
allow(::File).to receive(:realpath).with("/dev/sdz1").and_return "/dev/sdz1"
|
28
|
+
allow(::File).to receive(:realpath).with("/tmp/foo").and_return "/tmp/foo"
|
29
|
+
end
|
30
|
+
|
31
|
+
context "to see if the volume is mounted" do
|
32
|
+
|
33
|
+
it "should set mounted true if the mount point is found in the mounts list" do
|
34
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: "/tmp/foo /dev/sdz1 type ext3 (rw)\n"))
|
35
|
+
provider.load_current_resource
|
36
|
+
expect(provider.current_resource.mounted).to be_truthy
|
37
|
+
end
|
38
|
+
|
39
|
+
it "should set mounted false if another mount point beginning with the same path is found in the mounts list" do
|
40
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: "/tmp/foobar /dev/sdz1 type ext3 (rw)\n"))
|
41
|
+
provider.load_current_resource
|
42
|
+
expect(provider.current_resource.mounted).to be_falsey
|
43
|
+
end
|
44
|
+
|
45
|
+
it "should set mounted true if the symlink target of the device is found in the mounts list" do
|
46
|
+
# expand the target path to correct specs on Windows
|
47
|
+
target = ::File.expand_path("/dev/mapper/target")
|
48
|
+
|
49
|
+
allow(::File).to receive(:symlink?).with((new_resource.device).to_s).and_return(true)
|
50
|
+
allow(::File).to receive(:readlink).with((new_resource.device).to_s).and_return(target)
|
51
|
+
|
52
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: "/tmp/foo #{target} type ext3 (rw)\n"))
|
53
|
+
provider.load_current_resource
|
54
|
+
expect(provider.current_resource.mounted).to be_truthy
|
55
|
+
end
|
56
|
+
|
57
|
+
it "should set mounted true if the symlink target of the device is relative and is found in the mounts list - CHEF-4957" do
|
58
|
+
target = "xsdz1"
|
59
|
+
|
60
|
+
# expand the target path to correct specs on Windows
|
61
|
+
absolute_target = ::File.expand_path("/dev/xsdz1")
|
62
|
+
|
63
|
+
allow(::File).to receive(:symlink?).with((new_resource.device).to_s).and_return(true)
|
64
|
+
allow(::File).to receive(:readlink).with((new_resource.device).to_s).and_return(target)
|
65
|
+
|
66
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: "/tmp/foo #{absolute_target} type ext3 (rw)\n"))
|
67
|
+
provider.load_current_resource
|
68
|
+
expect(provider.current_resource.mounted).to be_truthy
|
69
|
+
end
|
70
|
+
|
71
|
+
it "should set mounted true if the mount point is found last in the mounts list" do
|
72
|
+
mount = "#{new_resource.mount_point} /dev/sdy1 type ext3 (rw)\n"
|
73
|
+
mount << "#{new_resource.mount_point} #{new_resource.device} type ext3 (rw)\n"
|
74
|
+
|
75
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: mount))
|
76
|
+
provider.load_current_resource
|
77
|
+
expect(provider.current_resource.mounted).to be_truthy
|
78
|
+
end
|
79
|
+
|
80
|
+
it "should set mounted false if the mount point is not last in the mounts list" do
|
81
|
+
mount = "#{new_resource.device} on #{new_resource.mount_point} type ext3 (rw)\n"
|
82
|
+
mount << "/dev/sdy1 on #{new_resource.mount_point} type ext3 (rw)\n"
|
83
|
+
|
84
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: mount))
|
85
|
+
provider.load_current_resource
|
86
|
+
expect(provider.current_resource.mounted).to be_falsey
|
87
|
+
end
|
88
|
+
|
89
|
+
it "mounted should be false if the mount point is not found in the mounts list" do
|
90
|
+
allow(provider).to receive(:shell_out!).and_return(double(stdout: "/dev/sdy1 on /tmp/foo type ext3 (rw)\n"))
|
91
|
+
provider.load_current_resource
|
92
|
+
expect(provider.current_resource.mounted).to be_falsey
|
93
|
+
end
|
94
|
+
|
95
|
+
end
|
96
|
+
|
97
|
+
end
|
@@ -150,7 +150,7 @@ describe Chef::Provider::Package::Chocolatey, :windows_only do
|
|
150
150
|
new_resource.package_name("package-does-not-exist")
|
151
151
|
new_resource.returns([0])
|
152
152
|
allow(provider).to receive(:shell_out_compacted!)
|
153
|
-
.with(choco_exe, "list", "-r",
|
153
|
+
.with(choco_exe, "list", "-r", new_resource.package_name.first, { returns: new_resource.returns, timeout: timeout })
|
154
154
|
.and_raise(Mixlib::ShellOut::ShellCommandFailed, "Expected process to exit with [0], but received '2'")
|
155
155
|
expect { provider.send(:available_packages) }.to raise_error(Mixlib::ShellOut::ShellCommandFailed, "Expected process to exit with [0], but received '2'")
|
156
156
|
end
|
@@ -19,7 +19,7 @@
|
|
19
19
|
require "spec_helper"
|
20
20
|
require "chef/mixin/powershell_out"
|
21
21
|
|
22
|
-
describe Chef::Provider::Package::Powershell, :windows_only do
|
22
|
+
describe Chef::Provider::Package::Powershell, :windows_only, :windows_gte_10 do
|
23
23
|
include Chef::Mixin::PowershellOut
|
24
24
|
let(:timeout) { 900 }
|
25
25
|
let(:source) { nil }
|
@@ -387,8 +387,9 @@ describe Chef::Provider::Package::Rubygems do
|
|
387
387
|
before(:each) do
|
388
388
|
# We choose detect omnibus via RbConfig::CONFIG['bindir'] in Chef::Provider::Package::Rubygems.new
|
389
389
|
allow(RbConfig::CONFIG).to receive(:[]).with("bindir").and_return(bindir)
|
390
|
-
# Rubygems uses
|
390
|
+
# Rubygems uses these two interally
|
391
391
|
allow(RbConfig::CONFIG).to receive(:[]).with("arch").and_call_original
|
392
|
+
allow(RbConfig::CONFIG).to receive(:[]).with("ruby_install_name").and_call_original
|
392
393
|
allow(File).to receive(:executable?).and_return false
|
393
394
|
allow(File).to receive(:executable?).with("#{bindir}/gem").and_return true
|
394
395
|
# XXX: we can't stub the provider object directly here because referencing it will create it and that
|
@@ -467,6 +468,7 @@ describe Chef::Provider::Package::Rubygems do
|
|
467
468
|
it "searches for a gem binary when running on Omnibus on Unix" do
|
468
469
|
platform_mock :unix do
|
469
470
|
allow(ENV).to receive(:[]).with("PATH").and_return("/usr/bin:/usr/sbin:/opt/chef/embedded/bin")
|
471
|
+
allow(ENV).to receive(:[]).with("PATHEXT").and_return(nil)
|
470
472
|
allow(File).to receive(:executable?).with("/usr/bin/gem").and_return(false)
|
471
473
|
allow(File).to receive(:executable?).with("/usr/sbin/gem").and_return(true)
|
472
474
|
allow(File).to receive(:executable?).with("/opt/chef/embedded/bin/gem").and_return(true) # should not get here
|
@@ -480,6 +482,7 @@ describe Chef::Provider::Package::Rubygems do
|
|
480
482
|
it "searches for a gem binary when running on Omnibus on Windows" do
|
481
483
|
platform_mock :windows do
|
482
484
|
allow(ENV).to receive(:[]).with("PATH").and_return('C:\windows\system32;C:\windows;C:\Ruby186\bin')
|
485
|
+
allow(ENV).to receive(:[]).with("PATHEXT").and_return(nil)
|
483
486
|
allow(File).to receive(:executable?).with('C:\\windows\\system32/gem').and_return(false)
|
484
487
|
allow(File).to receive(:executable?).with('C:\\windows/gem').and_return(false)
|
485
488
|
allow(File).to receive(:executable?).with('C:\\Ruby186\\bin/gem').and_return(true)
|
@@ -30,14 +30,21 @@ describe Chef::Provider::PowershellScript, "action_run" do
|
|
30
30
|
Chef::Provider::PowershellScript.new(new_resource, run_context)
|
31
31
|
end
|
32
32
|
|
33
|
-
|
33
|
+
describe "#command" do
|
34
34
|
before(:each) do
|
35
35
|
allow(provider).to receive(:basepath).and_return("C:\\Windows\\system32")
|
36
|
+
allow(ChefUtils).to receive(:windows?).and_return(true)
|
36
37
|
end
|
37
38
|
|
38
|
-
it "
|
39
|
-
flags =
|
40
|
-
|
39
|
+
it "includes the user's flags after the default flags when building the command" do
|
40
|
+
new_resource.flags = "-InputFormat Fabulous"
|
41
|
+
provider.send(:script_file_path=, "C:\\Temp\\Script.ps1")
|
42
|
+
|
43
|
+
expected = <<~CMD.strip
|
44
|
+
"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\powershell.exe" -NoLogo -NonInteractive -NoProfile -ExecutionPolicy Bypass -InputFormat None -InputFormat Fabulous -File "C:\\Temp\\Script.ps1"
|
45
|
+
CMD
|
46
|
+
|
47
|
+
expect(provider.command).to eq(expected)
|
41
48
|
end
|
42
49
|
end
|
43
50
|
end
|
@@ -201,17 +201,17 @@ describe Chef::Provider::RemoteDirectory do
|
|
201
201
|
@fclass = Chef::CFCCheck.new
|
202
202
|
|
203
203
|
Dir.mktmpdir do |tmp_dir|
|
204
|
-
begin
|
205
|
-
@fclass.file_class.symlink(tmp_dir.dup, symlinked_dir_path)
|
206
|
-
expect(::File.exist?(symlinked_dir_path)).to be_truthy
|
207
204
|
|
208
|
-
|
205
|
+
@fclass.file_class.symlink(tmp_dir.dup, symlinked_dir_path)
|
206
|
+
expect(::File.exist?(symlinked_dir_path)).to be_truthy
|
207
|
+
|
208
|
+
@provider.run_action
|
209
|
+
|
210
|
+
expect(::File.exist?(symlinked_dir_path)).to be_falsey
|
211
|
+
expect(::File.exist?(tmp_dir)).to be_truthy
|
212
|
+
rescue Chef::Exceptions::Win32APIError
|
213
|
+
skip "This must be run as an Administrator to create symlinks"
|
209
214
|
|
210
|
-
expect(::File.exist?(symlinked_dir_path)).to be_falsey
|
211
|
-
expect(::File.exist?(tmp_dir)).to be_truthy
|
212
|
-
rescue Chef::Exceptions::Win32APIError
|
213
|
-
skip "This must be run as an Administrator to create symlinks"
|
214
|
-
end
|
215
215
|
end
|
216
216
|
end
|
217
217
|
end
|