chef 14.2.0 → 14.3.37
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +13 -12
- data/Gemfile +15 -0
- data/README.md +36 -40
- data/Rakefile +1 -1
- data/VERSION +1 -1
- data/bin/chef-apply +0 -1
- data/bin/chef-client +1 -2
- data/bin/chef-shell +1 -6
- data/bin/chef-solo +1 -2
- data/bin/knife +1 -2
- data/chef-universal-mingw32.gemspec +2 -2
- data/chef.gemspec +1 -1
- data/distro/ruby_bin_folder/Chef.PowerShell.Wrapper.dll +0 -0
- data/distro/ruby_bin_folder/Chef.PowerShell.dll +0 -0
- data/distro/{powershell/chef → ruby_bin_folder}/Newtonsoft.Json.dll +0 -0
- data/lib/chef/api_client.rb +10 -10
- data/lib/chef/api_client/registration.rb +5 -5
- data/lib/chef/api_client_v1.rb +15 -15
- data/lib/chef/application.rb +1 -1
- data/lib/chef/application/apply.rb +56 -56
- data/lib/chef/application/client.rb +169 -170
- data/lib/chef/application/exit_code.rb +2 -2
- data/lib/chef/application/knife.rb +79 -78
- data/lib/chef/application/solo.rb +120 -120
- data/lib/chef/application/windows_service.rb +21 -21
- data/lib/chef/application/windows_service_manager.rb +39 -39
- data/lib/chef/audit/audit_event_proxy.rb +6 -6
- data/lib/chef/audit/audit_reporter.rb +2 -2
- data/lib/chef/audit/control_group_data.rb +15 -15
- data/lib/chef/audit/runner.rb +1 -1
- data/lib/chef/chef_class.rb +16 -8
- data/lib/chef/chef_fs/chef_fs_data_store.rb +8 -8
- data/lib/chef/chef_fs/config.rb +2 -2
- data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/acls_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/chef_server_root_dir.rb +2 -2
- data/lib/chef/chef_fs/file_system/chef_server/cookbooks_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/versioned_cookbooks_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/acls_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +3 -3
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +2 -2
- data/lib/chef/chef_fs/file_system/repository/directory.rb +3 -3
- data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +3 -3
- data/lib/chef/chef_fs/knife.rb +6 -6
- data/lib/chef/chef_fs/parallelizer.rb +1 -1
- data/lib/chef/client.rb +3 -0
- data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
- data/lib/chef/cookbook/file_system_file_vendor.rb +1 -1
- data/lib/chef/cookbook/manifest_v0.rb +1 -1
- data/lib/chef/cookbook/metadata.rb +61 -61
- data/lib/chef/cookbook/remote_file_vendor.rb +1 -1
- data/lib/chef/cookbook/synchronizer.rb +2 -2
- data/lib/chef/cookbook_loader.rb +3 -3
- data/lib/chef/cookbook_manifest.rb +5 -5
- data/lib/chef/cookbook_site_streaming_uploader.rb +5 -5
- data/lib/chef/cookbook_uploader.rb +2 -2
- data/lib/chef/cookbook_version.rb +2 -2
- data/lib/chef/data_bag.rb +3 -3
- data/lib/chef/data_bag_item.rb +2 -2
- data/lib/chef/deprecated.rb +110 -176
- data/lib/chef/dsl/audit.rb +1 -1
- data/lib/chef/dsl/definitions.rb +1 -1
- data/lib/chef/dsl/platform_introspection.rb +5 -0
- data/lib/chef/dsl/reboot_pending.rb +1 -1
- data/lib/chef/encrypted_data_bag_item.rb +2 -2
- data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +1 -1
- data/lib/chef/encrypted_data_bag_item/encryptor.rb +1 -1
- data/lib/chef/environment.rb +10 -10
- data/lib/chef/event_loggers/windows_eventlog.rb +21 -21
- data/lib/chef/exceptions.rb +3 -3
- data/lib/chef/file_cache.rb +18 -16
- data/lib/chef/formatters/base.rb +9 -10
- data/lib/chef/formatters/doc.rb +12 -16
- data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +51 -51
- data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +10 -10
- data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +13 -13
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +39 -39
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +1 -1
- data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +16 -16
- data/lib/chef/formatters/indentable_output_stream.rb +4 -4
- data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +3 -3
- data/lib/chef/handler/json_file.rb +1 -1
- data/lib/chef/http/auth_credentials.rb +2 -2
- data/lib/chef/http/authenticator.rb +6 -6
- data/lib/chef/http/cookie_manager.rb +1 -1
- data/lib/chef/http/http_request.rb +3 -3
- data/lib/chef/http/json_input.rb +1 -1
- data/lib/chef/http/json_to_model_output.rb +1 -1
- data/lib/chef/http/socketless_chef_zero_client.rb +1 -1
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/key.rb +9 -9
- data/lib/chef/knife.rb +5 -5
- data/lib/chef/knife/bootstrap.rb +116 -116
- data/lib/chef/knife/bootstrap/client_builder.rb +1 -1
- data/lib/chef/knife/client_bulk_delete.rb +3 -3
- data/lib/chef/knife/client_create.rb +17 -17
- data/lib/chef/knife/client_delete.rb +3 -3
- data/lib/chef/knife/client_list.rb +3 -3
- data/lib/chef/knife/client_reregister.rb +3 -3
- data/lib/chef/knife/config_get.rb +126 -0
- data/lib/chef/knife/configure.rb +25 -25
- data/lib/chef/knife/cookbook_bulk_delete.rb +1 -1
- data/lib/chef/knife/cookbook_delete.rb +2 -2
- data/lib/chef/knife/cookbook_download.rb +11 -11
- data/lib/chef/knife/cookbook_list.rb +6 -6
- data/lib/chef/knife/cookbook_metadata.rb +7 -8
- data/lib/chef/knife/cookbook_metadata_from_file.rb +0 -1
- data/lib/chef/knife/cookbook_show.rb +16 -16
- data/lib/chef/knife/cookbook_site_download.rb +11 -10
- data/lib/chef/knife/cookbook_site_install.rb +24 -24
- data/lib/chef/knife/cookbook_site_list.rb +8 -8
- data/lib/chef/knife/cookbook_site_search.rb +6 -5
- data/lib/chef/knife/cookbook_site_share.rb +20 -19
- data/lib/chef/knife/cookbook_site_show.rb +6 -5
- data/lib/chef/knife/cookbook_site_unshare.rb +5 -5
- data/lib/chef/knife/cookbook_test.rb +8 -8
- data/lib/chef/knife/cookbook_upload.rb +32 -32
- data/lib/chef/knife/core/bootstrap_context.rb +7 -7
- data/lib/chef/knife/core/cookbook_scm_repo.rb +1 -1
- data/lib/chef/knife/core/generic_presenter.rb +7 -7
- data/lib/chef/knife/core/hashed_command_loader.rb +1 -1
- data/lib/chef/knife/core/node_presenter.rb +37 -37
- data/lib/chef/knife/core/status_presenter.rb +11 -11
- data/lib/chef/knife/data_bag_from_file.rb +4 -4
- data/lib/chef/knife/data_bag_list.rb +3 -3
- data/lib/chef/knife/data_bag_secret_options.rb +13 -13
- data/lib/chef/knife/delete.rb +29 -13
- data/lib/chef/knife/deps.rb +25 -9
- data/lib/chef/knife/diff.rb +30 -14
- data/lib/chef/knife/download.rb +39 -23
- data/lib/chef/knife/edit.rb +19 -3
- data/lib/chef/knife/environment_compare.rb +8 -8
- data/lib/chef/knife/environment_create.rb +3 -3
- data/lib/chef/knife/environment_from_file.rb +5 -3
- data/lib/chef/knife/environment_list.rb +3 -3
- data/lib/chef/knife/exec.rb +7 -7
- data/lib/chef/knife/key_create.rb +4 -4
- data/lib/chef/knife/key_create_base.rb +12 -12
- data/lib/chef/knife/key_edit.rb +5 -5
- data/lib/chef/knife/key_edit_base.rb +15 -15
- data/lib/chef/knife/key_list.rb +3 -3
- data/lib/chef/knife/key_list_base.rb +9 -9
- data/lib/chef/knife/list.rb +35 -19
- data/lib/chef/knife/node_edit.rb +4 -4
- data/lib/chef/knife/node_list.rb +3 -3
- data/lib/chef/knife/node_run_list_add.rb +6 -6
- data/lib/chef/knife/node_show.rb +6 -6
- data/lib/chef/knife/osc_user_create.rb +13 -13
- data/lib/chef/knife/osc_user_list.rb +3 -3
- data/lib/chef/knife/osc_user_reregister.rb +3 -3
- data/lib/chef/knife/raw.rb +32 -16
- data/lib/chef/knife/role_create.rb +3 -3
- data/lib/chef/knife/role_env_run_list_add.rb +4 -3
- data/lib/chef/knife/role_env_run_list_remove.rb +2 -2
- data/lib/chef/knife/role_env_run_list_replace.rb +1 -0
- data/lib/chef/knife/role_list.rb +3 -3
- data/lib/chef/knife/role_run_list_add.rb +4 -3
- data/lib/chef/knife/role_run_list_remove.rb +2 -2
- data/lib/chef/knife/role_run_list_replace.rb +1 -0
- data/lib/chef/knife/search.rb +23 -23
- data/lib/chef/knife/serve.rb +22 -6
- data/lib/chef/knife/show.rb +19 -3
- data/lib/chef/knife/ssh.rb +68 -68
- data/lib/chef/knife/ssl_check.rb +31 -31
- data/lib/chef/knife/ssl_fetch.rb +5 -5
- data/lib/chef/knife/status.rb +11 -11
- data/lib/chef/knife/upload.rb +41 -25
- data/lib/chef/knife/user_create.rb +28 -28
- data/lib/chef/knife/user_delete.rb +9 -9
- data/lib/chef/knife/user_edit.rb +9 -9
- data/lib/chef/knife/user_list.rb +3 -3
- data/lib/chef/knife/user_reregister.rb +12 -12
- data/lib/chef/knife/user_show.rb +9 -9
- data/lib/chef/knife/xargs.rb +52 -36
- data/lib/chef/log.rb +10 -8
- data/lib/chef/log/winevt.rb +21 -21
- data/lib/chef/mixin/api_version_request_handling.rb +6 -6
- data/lib/chef/mixin/deep_merge.rb +1 -1
- data/lib/chef/mixin/deprecation.rb +2 -2
- data/lib/chef/mixin/params_validate.rb +9 -9
- data/lib/chef/mixin/properties.rb +2 -2
- data/lib/chef/mixin/securable.rb +11 -11
- data/lib/chef/mixin/shell_out.rb +138 -82
- data/lib/chef/mixin/wide_string.rb +5 -23
- data/lib/chef/mixin/windows_env_helper.rb +1 -1
- data/lib/chef/mixin/xml_escape.rb +3 -3
- data/lib/chef/node.rb +15 -15
- data/lib/chef/node/attribute.rb +6 -6
- data/lib/chef/node/attribute_collections.rb +2 -2
- data/lib/chef/node/mixin/deep_merge_cache.rb +1 -1
- data/lib/chef/node/mixin/immutablize_array.rb +2 -2
- data/lib/chef/node/mixin/immutablize_hash.rb +2 -2
- data/lib/chef/node_map.rb +77 -3
- data/lib/chef/org.rb +8 -8
- data/lib/chef/policy_builder/expand_node_object.rb +1 -1
- data/lib/chef/powershell.rb +9 -7
- data/lib/chef/property.rb +14 -14
- data/lib/chef/provider/apt_update.rb +2 -2
- data/lib/chef/provider/cron.rb +3 -3
- data/lib/chef/provider/cron/unix.rb +2 -2
- data/lib/chef/provider/dsc_resource.rb +1 -1
- data/lib/chef/provider/dsc_script.rb +8 -8
- data/lib/chef/provider/execute.rb +1 -1
- data/lib/chef/provider/group/aix.rb +6 -6
- data/lib/chef/provider/group/dscl.rb +1 -1
- data/lib/chef/provider/group/gpasswd.rb +4 -4
- data/lib/chef/provider/group/groupadd.rb +3 -3
- data/lib/chef/provider/group/groupmod.rb +6 -6
- data/lib/chef/provider/group/pw.rb +4 -4
- data/lib/chef/provider/group/suse.rb +2 -2
- data/lib/chef/provider/group/usermod.rb +1 -1
- data/lib/chef/provider/http_request.rb +6 -6
- data/lib/chef/provider/ifconfig.rb +4 -4
- data/lib/chef/provider/ifconfig/aix.rb +1 -1
- data/lib/chef/provider/mdadm.rb +1 -1
- data/lib/chef/provider/mount/mount.rb +1 -1
- data/lib/chef/provider/mount/windows.rb +7 -7
- data/lib/chef/provider/package.rb +3 -18
- data/lib/chef/provider/package/apt.rb +4 -4
- data/lib/chef/provider/package/bff.rb +9 -9
- data/lib/chef/provider/package/chocolatey.rb +7 -7
- data/lib/chef/provider/package/dnf.rb +2 -2
- data/lib/chef/provider/package/dpkg.rb +6 -6
- data/lib/chef/provider/package/freebsd/base.rb +2 -2
- data/lib/chef/provider/package/freebsd/pkg.rb +6 -6
- data/lib/chef/provider/package/freebsd/pkgng.rb +5 -5
- data/lib/chef/provider/package/freebsd/port.rb +4 -4
- data/lib/chef/provider/package/homebrew.rb +1 -1
- data/lib/chef/provider/package/ips.rb +6 -6
- data/lib/chef/provider/package/macports.rb +6 -6
- data/lib/chef/provider/package/msu.rb +1 -1
- data/lib/chef/provider/package/openbsd.rb +5 -5
- data/lib/chef/provider/package/pacman.rb +4 -4
- data/lib/chef/provider/package/paludis.rb +3 -3
- data/lib/chef/provider/package/portage.rb +5 -5
- data/lib/chef/provider/package/powershell.rb +6 -2
- data/lib/chef/provider/package/rpm.rb +10 -10
- data/lib/chef/provider/package/rubygems.rb +4 -4
- data/lib/chef/provider/package/smartos.rb +4 -4
- data/lib/chef/provider/package/solaris.rb +9 -9
- data/lib/chef/provider/package/windows.rb +4 -3
- data/lib/chef/provider/package/yum.rb +2 -2
- data/lib/chef/provider/package/zypper.rb +4 -4
- data/lib/chef/provider/powershell_script.rb +73 -73
- data/lib/chef/provider/reboot.rb +4 -4
- data/lib/chef/provider/registry_key.rb +4 -4
- data/lib/chef/provider/remote_file/cache_control_data.rb +2 -2
- data/lib/chef/provider/remote_file/sftp.rb +1 -1
- data/lib/chef/provider/resource_update.rb +1 -1
- data/lib/chef/provider/route.rb +2 -2
- data/lib/chef/provider/service/openbsd.rb +3 -3
- data/lib/chef/provider/service/redhat.rb +1 -1
- data/lib/chef/provider/service/simple.rb +1 -0
- data/lib/chef/provider/service/solaris.rb +1 -1
- data/lib/chef/provider/service/systemd.rb +2 -2
- data/lib/chef/provider/service/windows.rb +17 -17
- data/lib/chef/provider/subversion.rb +3 -3
- data/lib/chef/provider/systemd_unit.rb +2 -2
- data/lib/chef/provider/template/content.rb +1 -1
- data/lib/chef/provider/user/aix.rb +6 -6
- data/lib/chef/provider/user/dscl.rb +6 -6
- data/lib/chef/provider/user/linux.rb +6 -6
- data/lib/chef/provider/user/pw.rb +5 -5
- data/lib/chef/provider/user/solaris.rb +6 -6
- data/lib/chef/provider/user/useradd.rb +7 -7
- data/lib/chef/provider/windows_env.rb +6 -6
- data/lib/chef/provider/windows_task.rb +22 -24
- data/lib/chef/resource.rb +26 -4
- data/lib/chef/resource/chef_handler.rb +2 -0
- data/lib/chef/resource/chocolatey_config.rb +83 -0
- data/lib/chef/resource/chocolatey_source.rb +95 -0
- data/lib/chef/resource/cron.rb +5 -5
- data/lib/chef/resource/dsc_script.rb +12 -11
- data/lib/chef/resource/execute.rb +1 -1
- data/lib/chef/resource/file/verification.rb +1 -1
- data/lib/chef/resource/freebsd_package.rb +3 -1
- data/lib/chef/resource/group.rb +2 -2
- data/lib/chef/resource/homebrew_package.rb +2 -1
- data/lib/chef/resource/homebrew_tap.rb +1 -1
- data/lib/chef/resource/hostname.rb +23 -7
- data/lib/chef/resource/http_request.rb +6 -3
- data/lib/chef/resource/ifconfig.rb +57 -17
- data/lib/chef/resource/ips_package.rb +3 -1
- data/lib/chef/resource/kernel_module.rb +129 -0
- data/lib/chef/resource/launchd.rb +205 -98
- data/lib/chef/resource/log.rb +7 -2
- data/lib/chef/resource/mdadm.rb +29 -8
- data/lib/chef/resource/ohai.rb +2 -0
- data/lib/chef/resource/ohai_hint.rb +5 -3
- data/lib/chef/resource/openssl_dhparam.rb +1 -1
- data/lib/chef/resource/openssl_rsa_private_key.rb +2 -0
- data/lib/chef/resource/paludis_package.rb +1 -1
- data/lib/chef/resource/portage_package.rb +2 -0
- data/lib/chef/resource/powershell_package.rb +2 -0
- data/lib/chef/resource/powershell_package_source.rb +165 -0
- data/lib/chef/resource/powershell_script.rb +2 -2
- data/lib/chef/resource/registry_key.rb +1 -1
- data/lib/chef/resource/remote_directory.rb +3 -3
- data/lib/chef/resource/remote_file.rb +2 -2
- data/lib/chef/resource/resource_notification.rb +16 -16
- data/lib/chef/resource/rhsm_errata.rb +1 -1
- data/lib/chef/resource/rhsm_errata_level.rb +1 -1
- data/lib/chef/resource/rhsm_register.rb +4 -4
- data/lib/chef/resource/rhsm_repo.rb +2 -2
- data/lib/chef/resource/rhsm_subscription.rb +2 -2
- data/lib/chef/resource/script.rb +1 -1
- data/lib/chef/resource/service.rb +18 -18
- data/lib/chef/resource/ssh_known_hosts_entry.rb +146 -0
- data/lib/chef/resource/sudo.rb +4 -4
- data/lib/chef/resource/support/ssh_known_hosts.erb +3 -0
- data/lib/chef/resource/sysctl.rb +9 -5
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/user.rb +15 -15
- data/lib/chef/resource/windows_feature_dism.rb +10 -9
- data/lib/chef/resource/windows_feature_powershell.rb +24 -13
- data/lib/chef/resource/windows_script.rb +1 -1
- data/lib/chef/resource/windows_service.rb +2 -2
- data/lib/chef/resource/windows_task.rb +3 -3
- data/lib/chef/resource_definition.rb +1 -1
- data/lib/chef/resource_inspector.rb +1 -0
- data/lib/chef/resource_reporter.rb +4 -4
- data/lib/chef/resources.rb +5 -0
- data/lib/chef/role.rb +8 -8
- data/lib/chef/run_context.rb +8 -8
- data/lib/chef/run_list/run_list_expansion.rb +6 -6
- data/lib/chef/run_list/run_list_item.rb +1 -1
- data/lib/chef/run_list/versioned_recipe_list.rb +3 -3
- data/lib/chef/run_status.rb +10 -10
- data/lib/chef/shell.rb +60 -60
- data/lib/chef/shell/ext.rb +151 -151
- data/lib/chef/shell/shell_session.rb +2 -2
- data/lib/chef/user.rb +11 -11
- data/lib/chef/user_v1.rb +26 -26
- data/lib/chef/util/backup.rb +2 -2
- data/lib/chef/util/diff.rb +1 -1
- data/lib/chef/util/dsc/configuration_generator.rb +11 -11
- data/lib/chef/util/dsc/lcm_output_parser.rb +1 -1
- data/lib/chef/util/file_edit.rb +14 -14
- data/lib/chef/util/powershell/cmdlet.rb +4 -4
- data/lib/chef/util/selinux.rb +2 -2
- data/lib/chef/util/windows/net_group.rb +1 -1
- data/lib/chef/util/windows/net_use.rb +3 -3
- data/lib/chef/util/windows/net_user.rb +12 -12
- data/lib/chef/util/windows/volume.rb +2 -2
- data/lib/chef/version.rb +3 -3
- data/lib/chef/version_constraint.rb +3 -3
- data/lib/chef/win32/api.rb +6 -6
- data/lib/chef/win32/api/error.rb +2 -2
- data/lib/chef/win32/api/file.rb +12 -12
- data/lib/chef/win32/api/net.rb +58 -58
- data/lib/chef/win32/registry.rb +8 -8
- data/lib/chef/win32/security.rb +6 -6
- data/lib/chef/win32/security/securable_object.rb +10 -10
- data/lib/chef/win32/unicode.rb +6 -0
- data/lib/chef/win32/version.rb +16 -16
- data/spec/functional/audit/rspec_formatter_spec.rb +1 -1
- data/spec/functional/audit/runner_spec.rb +1 -1
- data/spec/functional/dsl/reboot_pending_spec.rb +3 -3
- data/spec/functional/dsl/registry_helper_spec.rb +3 -3
- data/spec/functional/http/simple_spec.rb +1 -1
- data/spec/functional/knife/exec_spec.rb +1 -1
- data/spec/functional/knife/ssh_spec.rb +2 -2
- data/spec/functional/mixin/shell_out_spec.rb +8 -4
- data/spec/functional/rebooter_spec.rb +6 -6
- data/spec/functional/resource/aixinit_service_spec.rb +2 -2
- data/spec/functional/resource/apt_package_spec.rb +17 -17
- data/spec/functional/resource/bash_spec.rb +1 -1
- data/spec/functional/resource/bff_spec.rb +1 -1
- data/spec/functional/resource/cron_spec.rb +1 -1
- data/spec/functional/resource/dnf_package_spec.rb +7 -7
- data/spec/functional/resource/dsc_script_spec.rb +94 -94
- data/spec/functional/resource/execute_spec.rb +4 -4
- data/spec/functional/resource/file_spec.rb +1 -1
- data/spec/functional/resource/git_spec.rb +19 -19
- data/spec/functional/resource/ifconfig_spec.rb +5 -5
- data/spec/functional/resource/link_spec.rb +1 -1
- data/spec/functional/resource/mount_spec.rb +2 -2
- data/spec/functional/resource/powershell_script_spec.rb +13 -13
- data/spec/functional/resource/reboot_spec.rb +3 -3
- data/spec/functional/resource/registry_spec.rb +82 -82
- data/spec/functional/resource/remote_file_spec.rb +2 -2
- data/spec/functional/resource/rpm_spec.rb +1 -1
- data/spec/functional/resource/template_spec.rb +5 -5
- data/spec/functional/resource/user/dscl_spec.rb +3 -3
- data/spec/functional/resource/windows_env_spec.rb +1 -1
- data/spec/functional/resource/windows_service_spec.rb +1 -1
- data/spec/functional/resource/windows_task_spec.rb +92 -38
- data/spec/functional/resource/yum_package_spec.rb +8 -8
- data/spec/functional/run_lock_spec.rb +4 -4
- data/spec/functional/shell_spec.rb +1 -1
- data/spec/functional/util/powershell/cmdlet_spec.rb +7 -7
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/crypto_spec.rb +9 -9
- data/spec/functional/win32/registry_spec.rb +66 -66
- data/spec/integration/client/client_spec.rb +219 -219
- data/spec/integration/client/exit_code_spec.rb +19 -19
- data/spec/integration/client/ipv6_spec.rb +36 -36
- data/spec/integration/knife/chef_fs_data_store_spec.rb +130 -130
- data/spec/integration/knife/chef_repo_path_spec.rb +418 -418
- data/spec/integration/knife/chef_repository_file_system_spec.rb +35 -35
- data/spec/integration/knife/chefignore_spec.rb +88 -88
- data/spec/integration/knife/client_bulk_delete_spec.rb +49 -49
- data/spec/integration/knife/client_create_spec.rb +5 -5
- data/spec/integration/knife/client_delete_spec.rb +13 -13
- data/spec/integration/knife/client_key_delete_spec.rb +2 -2
- data/spec/integration/knife/client_key_list_spec.rb +4 -4
- data/spec/integration/knife/client_list_spec.rb +8 -8
- data/spec/integration/knife/common_options_spec.rb +31 -31
- data/spec/integration/knife/config_get_spec.rb +183 -0
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +38 -38
- data/spec/integration/knife/cookbook_bulk_delete_spec.rb +14 -14
- data/spec/integration/knife/cookbook_download_spec.rb +12 -12
- data/spec/integration/knife/cookbook_list_spec.rb +8 -8
- data/spec/integration/knife/cookbook_show_spec.rb +81 -81
- data/spec/integration/knife/cookbook_upload_spec.rb +24 -24
- data/spec/integration/knife/data_bag_delete_spec.rb +8 -8
- data/spec/integration/knife/data_bag_from_file_spec.rb +47 -47
- data/spec/integration/knife/data_bag_list_spec.rb +4 -4
- data/spec/integration/knife/data_bag_show_spec.rb +7 -7
- data/spec/integration/knife/delete_spec.rb +593 -593
- data/spec/integration/knife/deps_spec.rb +185 -185
- data/spec/integration/knife/diff_spec.rb +116 -116
- data/spec/integration/knife/download_spec.rb +510 -510
- data/spec/integration/knife/environment_compare_spec.rb +15 -15
- data/spec/integration/knife/environment_from_file_spec.rb +59 -59
- data/spec/integration/knife/environment_list_spec.rb +4 -4
- data/spec/integration/knife/environment_show_spec.rb +25 -25
- data/spec/integration/knife/list_spec.rb +731 -731
- data/spec/integration/knife/node_bulk_delete_spec.rb +8 -8
- data/spec/integration/knife/node_delete_spec.rb +6 -6
- data/spec/integration/knife/node_environment_set_spec.rb +3 -3
- data/spec/integration/knife/node_from_file_spec.rb +16 -16
- data/spec/integration/knife/node_list_spec.rb +5 -5
- data/spec/integration/knife/raw_spec.rb +117 -117
- data/spec/integration/knife/role_bulk_delete_spec.rb +8 -8
- data/spec/integration/knife/role_delete_spec.rb +6 -6
- data/spec/integration/knife/role_from_file_spec.rb +42 -42
- data/spec/integration/knife/role_list_spec.rb +5 -5
- data/spec/integration/knife/role_show_spec.rb +9 -9
- data/spec/integration/knife/show_spec.rb +57 -57
- data/spec/integration/knife/upload_spec.rb +396 -396
- data/spec/integration/recipes/accumulator_spec.rb +2 -2
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +8 -8
- data/spec/integration/recipes/lwrp_spec.rb +12 -12
- data/spec/integration/recipes/notifies_spec.rb +167 -167
- data/spec/integration/recipes/notifying_block_spec.rb +2 -2
- data/spec/integration/recipes/remote_directory.rb +1 -1
- data/spec/integration/recipes/resource_converge_if_changed_spec.rb +99 -99
- data/spec/integration/recipes/resource_load_spec.rb +8 -8
- data/spec/integration/solo/solo_spec.rb +40 -40
- data/spec/scripts/ssl-serve.rb +12 -12
- data/spec/spec_helper.rb +73 -73
- data/spec/stress/win32/file_spec.rb +2 -2
- data/spec/stress/win32/security_spec.rb +2 -2
- data/spec/support/platform_helpers.rb +1 -1
- data/spec/support/shared/context/client.rb +25 -25
- data/spec/support/shared/functional/securable_resource.rb +13 -13
- data/spec/support/shared/functional/securable_resource_with_reporting.rb +6 -6
- data/spec/support/shared/functional/win32_service.rb +5 -5
- data/spec/support/shared/functional/windows_script.rb +3 -3
- data/spec/support/shared/integration/app_server_support.rb +3 -3
- data/spec/support/shared/integration/integration_helper.rb +2 -2
- data/spec/support/shared/integration/knife_support.rb +9 -3
- data/spec/support/shared/unit/api_error_inspector.rb +6 -6
- data/spec/support/shared/unit/api_versioning.rb +2 -2
- data/spec/support/shared/unit/execute_resource.rb +2 -2
- data/spec/support/shared/unit/provider/file.rb +12 -12
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +34 -34
- data/spec/support/shared/unit/user_and_client_shared.rb +3 -3
- data/spec/tiny_server.rb +8 -8
- data/spec/unit/api_client/registration_spec.rb +30 -30
- data/spec/unit/api_client_spec.rb +6 -6
- data/spec/unit/api_client_v1_spec.rb +6 -6
- data/spec/unit/application/apply_spec.rb +4 -4
- data/spec/unit/application/client_spec.rb +11 -11
- data/spec/unit/application/knife_spec.rb +3 -3
- data/spec/unit/application/solo_spec.rb +5 -5
- data/spec/unit/application_spec.rb +11 -11
- data/spec/unit/audit/audit_event_proxy_spec.rb +48 -48
- data/spec/unit/audit/audit_reporter_spec.rb +51 -55
- data/spec/unit/audit/control_group_data_spec.rb +20 -20
- data/spec/unit/audit/runner_spec.rb +2 -2
- data/spec/unit/chef_class_spec.rb +120 -0
- data/spec/unit/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
- data/spec/unit/chef_fs/data_handler/data_handler_base_spec.rb +3 -3
- data/spec/unit/chef_fs/diff_spec.rb +45 -45
- data/spec/unit/chef_fs/file_pattern_spec.rb +2 -2
- data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +2 -2
- data/spec/unit/chef_fs/file_system_spec.rb +8 -8
- data/spec/unit/chef_fs/parallelizer.rb +12 -12
- data/spec/unit/client_spec.rb +15 -15
- data/spec/unit/config_fetcher_spec.rb +23 -23
- data/spec/unit/config_spec.rb +2 -2
- data/spec/unit/cookbook/metadata_spec.rb +81 -81
- data/spec/unit/cookbook/synchronizer_spec.rb +171 -171
- data/spec/unit/cookbook_loader_spec.rb +10 -5
- data/spec/unit/cookbook_site_streaming_uploader_spec.rb +6 -6
- data/spec/unit/cookbook_uploader_spec.rb +8 -8
- data/spec/unit/cookbook_version_file_specificity_spec.rb +135 -135
- data/spec/unit/daemon_spec.rb +4 -4
- data/spec/unit/data_bag_item_spec.rb +3 -3
- data/spec/unit/data_bag_spec.rb +1 -1
- data/spec/unit/data_collector/resource_report_spec.rb +1 -1
- data/spec/unit/data_collector_spec.rb +4 -3
- data/spec/unit/deprecated_spec.rb +18 -12
- data/spec/unit/dsl/audit_spec.rb +1 -1
- data/spec/unit/dsl/platform_introspection_spec.rb +16 -16
- data/spec/unit/dsl/reboot_pending_spec.rb +1 -1
- data/spec/unit/environment_spec.rb +16 -16
- data/spec/unit/file_access_control_spec.rb +8 -8
- data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +3 -3
- data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +26 -26
- data/spec/unit/formatters/error_description_spec.rb +39 -39
- data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +16 -16
- data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +5 -5
- data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +4 -4
- data/spec/unit/handler/json_file_spec.rb +1 -1
- data/spec/unit/http/api_versions_spec.rb +1 -1
- data/spec/unit/http/authenticator_spec.rb +17 -17
- data/spec/unit/http/ssl_policies_spec.rb +1 -1
- data/spec/unit/http/validate_content_length_spec.rb +2 -2
- data/spec/unit/key_spec.rb +12 -12
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +3 -3
- data/spec/unit/knife/client_bulk_delete_spec.rb +1 -1
- data/spec/unit/knife/client_delete_spec.rb +1 -1
- data/spec/unit/knife/client_reregister_spec.rb +1 -1
- data/spec/unit/knife/configure_client_spec.rb +4 -4
- data/spec/unit/knife/configure_spec.rb +1 -1
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +1 -1
- data/spec/unit/knife/cookbook_delete_spec.rb +4 -4
- data/spec/unit/knife/cookbook_download_spec.rb +21 -21
- data/spec/unit/knife/cookbook_list_spec.rb +7 -7
- data/spec/unit/knife/cookbook_show_spec.rb +24 -24
- data/spec/unit/knife/cookbook_site_download_spec.rb +23 -23
- data/spec/unit/knife/cookbook_site_install_spec.rb +4 -4
- data/spec/unit/knife/cookbook_site_share_spec.rb +10 -10
- data/spec/unit/knife/cookbook_site_unshare_spec.rb +2 -2
- data/spec/unit/knife/cookbook_upload_spec.rb +19 -19
- data/spec/unit/knife/core/bootstrap_context_spec.rb +37 -37
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +20 -20
- data/spec/unit/knife/core/object_loader_spec.rb +1 -1
- data/spec/unit/knife/core/ui_spec.rb +55 -55
- data/spec/unit/knife/data_bag_create_spec.rb +2 -2
- data/spec/unit/knife/data_bag_edit_spec.rb +1 -1
- data/spec/unit/knife/data_bag_secret_options_spec.rb +5 -5
- data/spec/unit/knife/environment_from_file_spec.rb +1 -1
- data/spec/unit/knife/key_create_spec.rb +4 -4
- data/spec/unit/knife/key_delete_spec.rb +3 -3
- data/spec/unit/knife/key_edit_spec.rb +3 -3
- data/spec/unit/knife/key_list_spec.rb +3 -3
- data/spec/unit/knife/key_show_spec.rb +3 -3
- data/spec/unit/knife/node_delete_spec.rb +1 -1
- data/spec/unit/knife/node_edit_spec.rb +7 -7
- data/spec/unit/knife/node_from_file_spec.rb +1 -1
- data/spec/unit/knife/node_run_list_add_spec.rb +1 -1
- data/spec/unit/knife/osc_user_edit_spec.rb +1 -1
- data/spec/unit/knife/osc_user_reregister_spec.rb +1 -1
- data/spec/unit/knife/role_bulk_delete_spec.rb +1 -1
- data/spec/unit/knife/role_create_spec.rb +1 -1
- data/spec/unit/knife/role_delete_spec.rb +1 -1
- data/spec/unit/knife/role_env_run_list_add_spec.rb +4 -4
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +1 -1
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +1 -1
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +1 -1
- data/spec/unit/knife/role_env_run_list_set_spec.rb +1 -1
- data/spec/unit/knife/role_from_file_spec.rb +1 -1
- data/spec/unit/knife/role_run_list_add_spec.rb +4 -4
- data/spec/unit/knife/role_run_list_clear_spec.rb +1 -1
- data/spec/unit/knife/role_run_list_remove_spec.rb +1 -1
- data/spec/unit/knife/role_run_list_replace_spec.rb +1 -1
- data/spec/unit/knife/role_run_list_set_spec.rb +1 -1
- data/spec/unit/knife/ssh_spec.rb +25 -25
- data/spec/unit/knife/ssl_check_spec.rb +23 -23
- data/spec/unit/knife/ssl_fetch_spec.rb +11 -11
- data/spec/unit/knife/user_delete_spec.rb +1 -1
- data/spec/unit/knife/user_reregister_spec.rb +1 -1
- data/spec/unit/knife_spec.rb +26 -26
- data/spec/unit/log/syslog_spec.rb +1 -1
- data/spec/unit/lwrp_spec.rb +4 -4
- data/spec/unit/mash_spec.rb +3 -3
- data/spec/unit/mixin/api_version_request_handling_spec.rb +16 -16
- data/spec/unit/mixin/checksum_spec.rb +1 -1
- data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +8 -8
- data/spec/unit/mixin/homebrew_user_spec.rb +1 -1
- data/spec/unit/mixin/params_validate_spec.rb +96 -96
- data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
- data/spec/unit/mixin/powershell_type_coercions_spec.rb +1 -1
- data/spec/unit/mixin/securable_spec.rb +27 -27
- data/spec/unit/mixin/shell_out_spec.rb +286 -132
- data/spec/unit/mixin/user_context_spec.rb +1 -1
- data/spec/unit/mixin/xml_escape_spec.rb +1 -1
- data/spec/unit/node/attribute_spec.rb +10 -10
- data/spec/unit/node/vivid_mash_spec.rb +3 -3
- data/spec/unit/node_map_spec.rb +71 -3
- data/spec/unit/node_spec.rb +15 -15
- data/spec/unit/org_spec.rb +2 -2
- data/spec/unit/platform/query_helpers_spec.rb +26 -26
- data/spec/unit/policy_builder/expand_node_object_spec.rb +4 -4
- data/spec/unit/policy_builder/policyfile_spec.rb +29 -29
- data/spec/unit/property_spec.rb +5 -5
- data/spec/unit/provider/apt_repository_spec.rb +19 -19
- data/spec/unit/provider/cookbook_file/content_spec.rb +1 -1
- data/spec/unit/provider/cookbook_file_spec.rb +1 -1
- data/spec/unit/provider/cron/unix_spec.rb +12 -12
- data/spec/unit/provider/cron_spec.rb +279 -279
- data/spec/unit/provider/dsc_resource_spec.rb +6 -6
- data/spec/unit/provider/execute_spec.rb +2 -2
- data/spec/unit/provider/file/content_spec.rb +1 -1
- data/spec/unit/provider/file_spec.rb +1 -1
- data/spec/unit/provider/git_spec.rb +123 -123
- data/spec/unit/provider/group/dscl_spec.rb +18 -18
- data/spec/unit/provider/group/gpasswd_spec.rb +7 -7
- data/spec/unit/provider/group/groupadd_spec.rb +7 -7
- data/spec/unit/provider/group/groupmod_spec.rb +13 -13
- data/spec/unit/provider/group/pw_spec.rb +4 -4
- data/spec/unit/provider/group/suse_spec.rb +2 -2
- data/spec/unit/provider/group/usermod_spec.rb +4 -4
- data/spec/unit/provider/group_spec.rb +3 -3
- data/spec/unit/provider/ifconfig/aix_spec.rb +17 -17
- data/spec/unit/provider/ifconfig/debian_spec.rb +16 -16
- data/spec/unit/provider/ifconfig_spec.rb +16 -16
- data/spec/unit/provider/launchd_spec.rb +52 -52
- data/spec/unit/provider/link_spec.rb +7 -7
- data/spec/unit/provider/mdadm_spec.rb +3 -3
- data/spec/unit/provider/mount/aix_spec.rb +39 -39
- data/spec/unit/provider/mount/mount_spec.rb +26 -26
- data/spec/unit/provider/mount/solaris_spec.rb +2 -2
- data/spec/unit/provider/mount/windows_spec.rb +6 -6
- data/spec/unit/provider/ohai_spec.rb +9 -9
- data/spec/unit/provider/osx_profile_spec.rb +1 -1
- data/spec/unit/provider/package/apt_spec.rb +186 -186
- data/spec/unit/provider/package/bff_spec.rb +36 -36
- data/spec/unit/provider/package/cab_spec.rb +58 -58
- data/spec/unit/provider/package/chocolatey_spec.rb +34 -34
- data/spec/unit/provider/package/dpkg_spec.rb +33 -33
- data/spec/unit/provider/package/freebsd/pkg_spec.rb +35 -35
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +22 -22
- data/spec/unit/provider/package/freebsd/port_spec.rb +21 -21
- data/spec/unit/provider/package/homebrew_spec.rb +4 -4
- data/spec/unit/provider/package/ips_spec.rb +94 -94
- data/spec/unit/provider/package/macports_spec.rb +23 -23
- data/spec/unit/provider/package/msu_spec.rb +44 -44
- data/spec/unit/provider/package/openbsd_spec.rb +19 -19
- data/spec/unit/provider/package/pacman_spec.rb +50 -50
- data/spec/unit/provider/package/paludis_spec.rb +33 -33
- data/spec/unit/provider/package/portage_spec.rb +25 -25
- data/spec/unit/provider/package/powershell_spec.rb +98 -85
- data/spec/unit/provider/package/rpm_spec.rb +21 -21
- data/spec/unit/provider/package/rubygems_spec.rb +71 -71
- data/spec/unit/provider/package/smartos_spec.rb +21 -21
- data/spec/unit/provider/package/solaris_spec.rb +38 -38
- data/spec/unit/provider/package/windows/exe_spec.rb +1 -1
- data/spec/unit/provider/package/windows/msi_spec.rb +1 -1
- data/spec/unit/provider/package/windows_spec.rb +11 -4
- data/spec/unit/provider/package/zypper_spec.rb +42 -46
- data/spec/unit/provider/package_spec.rb +2 -2
- data/spec/unit/provider/powershell_script_spec.rb +1 -1
- data/spec/unit/provider/registry_key_spec.rb +22 -22
- data/spec/unit/provider/remote_file/cache_control_data_spec.rb +7 -7
- data/spec/unit/provider/remote_file/content_spec.rb +4 -4
- data/spec/unit/provider/remote_file/fetcher_spec.rb +5 -5
- data/spec/unit/provider/remote_file/ftp_spec.rb +1 -1
- data/spec/unit/provider/remote_file/http_spec.rb +1 -1
- data/spec/unit/provider/remote_file/local_file_spec.rb +2 -2
- data/spec/unit/provider/remote_file/network_file_spec.rb +3 -3
- data/spec/unit/provider/remote_file/sftp_spec.rb +2 -2
- data/spec/unit/provider/remote_file_spec.rb +1 -1
- data/spec/unit/provider/script_spec.rb +1 -1
- data/spec/unit/provider/service/aix_service_spec.rb +8 -8
- data/spec/unit/provider/service/aixinit_service_spec.rb +3 -3
- data/spec/unit/provider/service/arch_service_spec.rb +21 -21
- data/spec/unit/provider/service/debian_service_spec.rb +2 -2
- data/spec/unit/provider/service/freebsd_service_spec.rb +30 -30
- data/spec/unit/provider/service/gentoo_service_spec.rb +1 -1
- data/spec/unit/provider/service/init_service_spec.rb +14 -14
- data/spec/unit/provider/service/insserv_service_spec.rb +2 -2
- data/spec/unit/provider/service/invokercd_service_spec.rb +17 -17
- data/spec/unit/provider/service/macosx_spec.rb +59 -59
- data/spec/unit/provider/service/openbsd_service_spec.rb +6 -6
- data/spec/unit/provider/service/redhat_spec.rb +27 -27
- data/spec/unit/provider/service/simple_service_spec.rb +14 -14
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +19 -19
- data/spec/unit/provider/service/systemd_service_spec.rb +13 -13
- data/spec/unit/provider/service/upstart_service_spec.rb +5 -5
- data/spec/unit/provider/service/windows_spec.rb +38 -38
- data/spec/unit/provider/service_spec.rb +3 -3
- data/spec/unit/provider/subversion_spec.rb +13 -13
- data/spec/unit/provider/systemd_unit_spec.rb +10 -10
- data/spec/unit/provider/template/content_spec.rb +44 -44
- data/spec/unit/provider/template_spec.rb +2 -2
- data/spec/unit/provider/user/aix_spec.rb +5 -5
- data/spec/unit/provider/user/dscl_spec.rb +12 -12
- data/spec/unit/provider/user/pw_spec.rb +12 -12
- data/spec/unit/provider/user/solaris_spec.rb +6 -6
- data/spec/unit/provider/windows_env_spec.rb +2 -2
- data/spec/unit/provider/windows_task_spec.rb +16 -16
- data/spec/unit/provider/zypper_repository_spec.rb +7 -7
- data/spec/unit/provider_resolver_spec.rb +3 -3
- data/spec/unit/recipe_spec.rb +13 -13
- data/spec/unit/resource/chocolatey_config_spec.rb +98 -0
- data/spec/unit/resource/chocolatey_source_spec.rb +102 -0
- data/spec/unit/resource/conditional_spec.rb +1 -1
- data/spec/unit/resource/cookbook_file_spec.rb +3 -3
- data/spec/unit/resource/dnf_package_spec.rb +3 -3
- data/spec/unit/resource/dsc_script_spec.rb +10 -10
- data/spec/unit/resource/execute_spec.rb +2 -2
- data/spec/unit/resource/file/verification/systemd_unit_spec.rb +1 -1
- data/spec/unit/resource/file/verification_spec.rb +1 -1
- data/spec/unit/resource/file_spec.rb +3 -3
- data/spec/unit/resource/freebsd_package_spec.rb +5 -4
- data/spec/unit/resource/group_spec.rb +4 -4
- data/spec/unit/resource/kernel_module_spec.rb +48 -0
- data/spec/unit/resource/mount_spec.rb +13 -3
- data/spec/unit/resource/package_spec.rb +2 -2
- data/spec/unit/resource/powershell_package_source_spec.rb +219 -0
- data/spec/unit/resource/powershell_package_spec.rb +10 -1
- data/spec/unit/resource/powershell_script_spec.rb +8 -8
- data/spec/unit/resource/registry_key_spec.rb +19 -19
- data/spec/unit/resource/remote_file_spec.rb +2 -2
- data/spec/unit/resource/resource_notification_spec.rb +8 -8
- data/spec/unit/resource/service_spec.rb +3 -3
- data/spec/unit/resource/ssh_known_hosts_entry_spec.rb +55 -0
- data/spec/unit/resource/template_spec.rb +2 -2
- data/spec/unit/resource/user_spec.rb +2 -2
- data/spec/unit/resource/windows_feature_dism.rb +5 -5
- data/spec/unit/resource/windows_feature_powershell.rb +27 -6
- data/spec/unit/resource/yum_package_spec.rb +3 -3
- data/spec/unit/resource_collection/resource_set_spec.rb +6 -6
- data/spec/unit/resource_collection_spec.rb +5 -5
- data/spec/unit/resource_definition_spec.rb +2 -2
- data/spec/unit/resource_inspector_spec.rb +3 -3
- data/spec/unit/resource_reporter_spec.rb +24 -24
- data/spec/unit/resource_spec.rb +65 -31
- data/spec/unit/role_spec.rb +22 -22
- data/spec/unit/run_context_spec.rb +1 -1
- data/spec/unit/run_list/run_list_item_spec.rb +3 -3
- data/spec/unit/run_list/versioned_recipe_list_spec.rb +12 -12
- data/spec/unit/run_list_spec.rb +6 -6
- data/spec/unit/runner_spec.rb +4 -4
- data/spec/unit/scan_access_control_spec.rb +3 -3
- data/spec/unit/shell/model_wrapper_spec.rb +4 -4
- data/spec/unit/shell/shell_ext_spec.rb +4 -4
- data/spec/unit/shell/shell_session_spec.rb +28 -28
- data/spec/unit/user_spec.rb +2 -2
- data/spec/unit/user_v1_spec.rb +25 -25
- data/spec/unit/util/diff_spec.rb +1 -1
- data/spec/unit/util/dsc/configuration_generator_spec.rb +4 -4
- data/spec/unit/util/dsc/lcm_output_parser_spec.rb +105 -105
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +16 -16
- data/spec/unit/util/file_edit_spec.rb +38 -38
- data/spec/unit/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/unit/util/selinux_spec.rb +10 -10
- data/spec/unit/win32/registry_spec.rb +3 -3
- data/spec/unit/windows_service_spec.rb +2 -2
- data/tasks/cbgb.rb +3 -3
- data/tasks/dependencies.rb +6 -8
- data/tasks/maintainers.rb +7 -7
- data/tasks/rspec.rb +2 -2
- metadata +20 -79
- data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +0 -33
- data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +0 -272
- data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +0 -57
- data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +0 -68
- data/acceptance/.shared/kitchen_acceptance/metadata.rb +0 -1
- data/acceptance/Gemfile +0 -19
- data/acceptance/Gemfile.lock +0 -266
- data/acceptance/README.md +0 -137
- data/acceptance/basics/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/basics/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/basics/.kitchen.yml +0 -4
- data/acceptance/basics/test/integration/chef-current-install/serverspec/chef_client_spec.rb +0 -19
- data/acceptance/basics/test/integration/chef-current-install/serverspec/spec_helper.rb +0 -6
- data/acceptance/basics/test/integration/helpers/serverspec/Gemfile +0 -8
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/.gitignore +0 -16
- data/acceptance/data-collector/.acceptance/data-collector-test/Berksfile +0 -3
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/api.rb +0 -101
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/apigemfile +0 -3
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-both-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-client-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-no-endpoint.rb +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-solo-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/config.ru +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/metadata.rb +0 -7
- data/acceptance/data-collector/.acceptance/data-collector-test/recipes/default.rb +0 -44
- data/acceptance/data-collector/.kitchen.yml +0 -9
- data/acceptance/data-collector/Berksfile +0 -3
- data/acceptance/data-collector/test/integration/default/serverspec/default_spec.rb +0 -208
- data/acceptance/data-collector/test/integration/helpers/serverspec/Gemfile +0 -8
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/metadata.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -61
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/cookbook_kitchen.rb +0 -43
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/top_cookbooks.rb +0 -41
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/top-cookbooks/.gitignore +0 -1
- data/acceptance/top-cookbooks/.kitchen.chocolatey.yml +0 -6
- data/acceptance/top-cookbooks/.kitchen.iis.yml +0 -4
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-rhel.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-ubuntu.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-windows.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.powershell.yml +0 -4
- data/acceptance/top-cookbooks/.kitchen.sql_server.yml +0 -5
- data/acceptance/top-cookbooks/.kitchen.winbox.yml +0 -8
- data/acceptance/top-cookbooks/.kitchen.windows.yml +0 -38
- data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +0 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/trivial/.kitchen.yml +0 -7
- data/acceptance/trivial/test/integration/chef-current-install/inspec/chef_client_spec.rb +0 -5
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/metadata.rb +0 -2
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/windows-service/.kitchen.yml +0 -7
- data/acceptance/windows-service/test/integration/chef-windows-service/inspec/chef_windows_service_spec.rb +0 -58
- data/distro/powershell/chef/Chef.PowerShell.dll +0 -0
@@ -221,9 +221,9 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
221
221
|
let(:error404) { Net::HTTPServerException.new("404 message", :body) }
|
222
222
|
|
223
223
|
before do
|
224
|
-
expect(api_service).to receive(:get)
|
225
|
-
with("data/policyfiles/example-policy-stage")
|
226
|
-
and_raise(error404)
|
224
|
+
expect(api_service).to receive(:get)
|
225
|
+
.with("data/policyfiles/example-policy-stage")
|
226
|
+
.and_raise(error404)
|
227
227
|
end
|
228
228
|
|
229
229
|
it "raises an error" do
|
@@ -393,10 +393,10 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
393
393
|
|
394
394
|
let(:run_list_for_data_collector) do
|
395
395
|
{
|
396
|
-
:
|
397
|
-
:
|
398
|
-
{ :
|
399
|
-
{ :
|
396
|
+
id: "_policy_node",
|
397
|
+
run_list: [
|
398
|
+
{ type: "recipe", name: "test::default", skipped: false, version: nil },
|
399
|
+
{ type: "recipe", name: "test::other", skipped: false, version: nil },
|
400
400
|
],
|
401
401
|
}
|
402
402
|
end
|
@@ -744,8 +744,8 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
744
744
|
policy_builder.finish_load_node(node)
|
745
745
|
policy_builder.build_node
|
746
746
|
|
747
|
-
expect(api_service).to receive(:get).with(cookbook1_url)
|
748
|
-
and_raise(error404)
|
747
|
+
expect(api_service).to receive(:get).with(cookbook1_url)
|
748
|
+
.and_raise(error404)
|
749
749
|
end
|
750
750
|
|
751
751
|
it "raises an error indicating which cookbook is missing" do
|
@@ -763,9 +763,9 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
763
763
|
policy_builder.finish_load_node(node)
|
764
764
|
policy_builder.build_node
|
765
765
|
|
766
|
-
allow(Chef::CookbookSynchronizer).to receive(:new)
|
767
|
-
with(expected_cookbook_hash, events)
|
768
|
-
and_return(cookbook_synchronizer)
|
766
|
+
allow(Chef::CookbookSynchronizer).to receive(:new)
|
767
|
+
.with(expected_cookbook_hash, events)
|
768
|
+
.and_return(cookbook_synchronizer)
|
769
769
|
end
|
770
770
|
|
771
771
|
after do
|
@@ -814,15 +814,15 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
814
814
|
context "when the cookbooks exist on the server" do
|
815
815
|
|
816
816
|
before do
|
817
|
-
expect(api_service).to receive(:get).with(cookbook1_url)
|
818
|
-
and_return(example1_cookbook_data)
|
819
|
-
expect(api_service).to receive(:get).with(cookbook2_url)
|
820
|
-
and_return(example2_cookbook_data)
|
817
|
+
expect(api_service).to receive(:get).with(cookbook1_url)
|
818
|
+
.and_return(example1_cookbook_data)
|
819
|
+
expect(api_service).to receive(:get).with(cookbook2_url)
|
820
|
+
.and_return(example2_cookbook_data)
|
821
821
|
|
822
|
-
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example1_cookbook_data)
|
823
|
-
and_return(example1_cookbook_object)
|
824
|
-
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example2_cookbook_data)
|
825
|
-
and_return(example2_cookbook_object)
|
822
|
+
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example1_cookbook_data)
|
823
|
+
.and_return(example1_cookbook_object)
|
824
|
+
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example2_cookbook_data)
|
825
|
+
.and_return(example2_cookbook_object)
|
826
826
|
end
|
827
827
|
|
828
828
|
include_examples "fetching cookbooks when they exist"
|
@@ -847,15 +847,15 @@ describe Chef::PolicyBuilder::Policyfile do
|
|
847
847
|
context "when the cookbooks exist on the server" do
|
848
848
|
|
849
849
|
before do
|
850
|
-
expect(api_service).to receive(:get).with(cookbook1_url)
|
851
|
-
and_return(example1_cookbook_data)
|
852
|
-
expect(api_service).to receive(:get).with(cookbook2_url)
|
853
|
-
and_return(example2_cookbook_data)
|
854
|
-
|
855
|
-
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example1_cookbook_data)
|
856
|
-
and_return(example1_cookbook_object)
|
857
|
-
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example2_cookbook_data)
|
858
|
-
and_return(example2_cookbook_object)
|
850
|
+
expect(api_service).to receive(:get).with(cookbook1_url)
|
851
|
+
.and_return(example1_cookbook_data)
|
852
|
+
expect(api_service).to receive(:get).with(cookbook2_url)
|
853
|
+
.and_return(example2_cookbook_data)
|
854
|
+
|
855
|
+
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example1_cookbook_data)
|
856
|
+
.and_return(example1_cookbook_object)
|
857
|
+
expect(Chef::CookbookVersion).to receive(:from_cb_artifact_data).with(example2_cookbook_data)
|
858
|
+
.and_return(example2_cookbook_object)
|
859
859
|
end
|
860
860
|
|
861
861
|
include_examples "fetching cookbooks when they exist"
|
data/spec/unit/property_spec.rb
CHANGED
@@ -64,7 +64,7 @@ describe "Chef::Resource.property" do
|
|
64
64
|
if properties.size == 1
|
65
65
|
description = "With property #{properties.first}"
|
66
66
|
else
|
67
|
-
description = "With properties #{english_join(properties.map { |property|
|
67
|
+
description = "With properties #{english_join(properties.map { |property| (property.inspect).to_s })}"
|
68
68
|
end
|
69
69
|
context description, *tags do
|
70
70
|
before do
|
@@ -1070,13 +1070,13 @@ describe "Chef::Resource.property" do
|
|
1070
1070
|
end
|
1071
1071
|
|
1072
1072
|
it "raises an error if both name_property and name_attribute are specified" do
|
1073
|
-
expect { resource_class.property :x, :
|
1073
|
+
expect { resource_class.property :x, name_property: false, name_attribute: 1 }.to raise_error ArgumentError,
|
1074
1074
|
/name_attribute and name_property are functionally identical and both cannot be specified on a property at once. Use just one on property x of resource chef_resource_property_spec_(\d+)./
|
1075
|
-
expect { resource_class.property :x, :
|
1075
|
+
expect { resource_class.property :x, name_property: false, name_attribute: nil }.to raise_error ArgumentError,
|
1076
1076
|
/name_attribute and name_property are functionally identical and both cannot be specified on a property at once. Use just one on property x of resource chef_resource_property_spec_(\d+)./
|
1077
|
-
expect { resource_class.property :x, :
|
1077
|
+
expect { resource_class.property :x, name_property: false, name_attribute: false }.to raise_error ArgumentError,
|
1078
1078
|
/name_attribute and name_property are functionally identical and both cannot be specified on a property at once. Use just one on property x of resource chef_resource_property_spec_(\d+)./
|
1079
|
-
expect { resource_class.property :x, :
|
1079
|
+
expect { resource_class.property :x, name_property: true, name_attribute: true }.to raise_error ArgumentError,
|
1080
1080
|
/name_attribute and name_property are functionally identical and both cannot be specified on a property at once. Use just one on property x of resource chef_resource_property_spec_(\d+)./
|
1081
1081
|
end
|
1082
1082
|
|
@@ -23,25 +23,25 @@ require "spec_helper"
|
|
23
23
|
#
|
24
24
|
# Output of the command:
|
25
25
|
# => apt-key adv --list-public-keys --with-fingerprint --with-colons
|
26
|
-
APT_KEY_FINGER =
|
27
|
-
tru:t:1:1488924856:0:3:1:5
|
28
|
-
pub:-:1024:17:40976EAF437D05B5:2004-09-12:::-:Ubuntu Archive Automatic Signing Key <ftpmaster@ubuntu.com>::scESC:
|
29
|
-
fpr:::::::::630239CC130E1A7FD81A27B140976EAF437D05B5:
|
30
|
-
sub:-:2048:16:251BEFF479164387:2004-09-12::::::e:
|
31
|
-
pub:-:1024:17:46181433FBB75451:2004-12-30:::-:Ubuntu CD Image Automatic Signing Key <cdimage@ubuntu.com>::scSC:
|
32
|
-
fpr:::::::::C5986B4F1257FFA86632CBA746181433FBB75451:
|
33
|
-
pub:-:4096:1:3B4FE6ACC0B21F32:2012-05-11:::-:Ubuntu Archive Automatic Signing Key (2012) <ftpmaster@ubuntu.com>::scSC:
|
34
|
-
fpr:::::::::790BC7277767219C42C86F933B4FE6ACC0B21F32:
|
35
|
-
pub:-:4096:1:D94AA3F0EFE21092:2012-05-11:::-:Ubuntu CD Image Automatic Signing Key (2012) <cdimage@ubuntu.com>::scSC:
|
36
|
-
fpr:::::::::843938DF228D22F7B3742BC0D94AA3F0EFE21092:
|
26
|
+
APT_KEY_FINGER = <<~EOF.freeze
|
27
|
+
tru:t:1:1488924856:0:3:1:5
|
28
|
+
pub:-:1024:17:40976EAF437D05B5:2004-09-12:::-:Ubuntu Archive Automatic Signing Key <ftpmaster@ubuntu.com>::scESC:
|
29
|
+
fpr:::::::::630239CC130E1A7FD81A27B140976EAF437D05B5:
|
30
|
+
sub:-:2048:16:251BEFF479164387:2004-09-12::::::e:
|
31
|
+
pub:-:1024:17:46181433FBB75451:2004-12-30:::-:Ubuntu CD Image Automatic Signing Key <cdimage@ubuntu.com>::scSC:
|
32
|
+
fpr:::::::::C5986B4F1257FFA86632CBA746181433FBB75451:
|
33
|
+
pub:-:4096:1:3B4FE6ACC0B21F32:2012-05-11:::-:Ubuntu Archive Automatic Signing Key (2012) <ftpmaster@ubuntu.com>::scSC:
|
34
|
+
fpr:::::::::790BC7277767219C42C86F933B4FE6ACC0B21F32:
|
35
|
+
pub:-:4096:1:D94AA3F0EFE21092:2012-05-11:::-:Ubuntu CD Image Automatic Signing Key (2012) <cdimage@ubuntu.com>::scSC:
|
36
|
+
fpr:::::::::843938DF228D22F7B3742BC0D94AA3F0EFE21092:
|
37
37
|
EOF
|
38
38
|
|
39
39
|
# Output of the command:
|
40
40
|
# => gpg --with-fingerprint --with-colons [FILE]
|
41
|
-
GPG_FINGER =
|
42
|
-
pub:-:1024:17:327574EE02A818DD:2009-04-22:::-:Cloudera Apt Repository:
|
43
|
-
fpr:::::::::F36A89E33CC1BD0F71079007327574EE02A818DD:
|
44
|
-
sub:-:2048:16:84080586D1CA74A1:2009-04-22::::
|
41
|
+
GPG_FINGER = <<~EOF.freeze
|
42
|
+
pub:-:1024:17:327574EE02A818DD:2009-04-22:::-:Cloudera Apt Repository:
|
43
|
+
fpr:::::::::F36A89E33CC1BD0F71079007327574EE02A818DD:
|
44
|
+
sub:-:2048:16:84080586D1CA74A1:2009-04-22::::
|
45
45
|
EOF
|
46
46
|
|
47
47
|
describe Chef::Provider::AptRepository do
|
@@ -67,14 +67,14 @@ describe Chef::Provider::AptRepository do
|
|
67
67
|
end
|
68
68
|
|
69
69
|
let(:gpg_shell_out_success) do
|
70
|
-
double("shell_out", :
|
71
|
-
:
|
70
|
+
double("shell_out", stdout: "pub 2048R/7BD9BF62 2011-08-19 nginx signing key <signing-key@nginx.com>",
|
71
|
+
exitstatus: 0, error?: false)
|
72
72
|
end
|
73
73
|
|
74
74
|
let(:gpg_shell_out_failure) do
|
75
|
-
double("shell_out", :
|
75
|
+
double("shell_out", stderr: "gpg: no valid OpenPGP data found.\n
|
76
76
|
gpg: processing message failed: eof",
|
77
|
-
:
|
77
|
+
exitstatus: 1, error?: true)
|
78
78
|
end
|
79
79
|
|
80
80
|
let(:apt_fingerprints) do
|
@@ -20,7 +20,7 @@ require "spec_helper"
|
|
20
20
|
|
21
21
|
describe Chef::Provider::CookbookFile::Content do
|
22
22
|
|
23
|
-
let(:new_resource) { double("Chef::Resource::CookbookFile (new)", :
|
23
|
+
let(:new_resource) { double("Chef::Resource::CookbookFile (new)", cookbook_name: "apache2", cookbook: "apache2") }
|
24
24
|
let(:content) do
|
25
25
|
@run_context = double("Chef::RunContext")
|
26
26
|
@current_resource = double("Chef::Resource::CookbookFile (current)")
|
@@ -26,7 +26,7 @@ describe Chef::Provider::CookbookFile do
|
|
26
26
|
let(:node) { double("Chef::Node") }
|
27
27
|
let(:events) { double("Chef::Events").as_null_object } # mock all the methods
|
28
28
|
let(:logger) { double("Mixlib::Log::Child").as_null_object }
|
29
|
-
let(:run_context) { double("Chef::RunContext", :
|
29
|
+
let(:run_context) { double("Chef::RunContext", node: node, events: events, logger: logger) }
|
30
30
|
let(:enclosing_directory) do
|
31
31
|
canonicalize_path(File.expand_path(File.join(CHEF_SPEC_DATA, "templates")))
|
32
32
|
end
|
@@ -37,9 +37,9 @@ describe Chef::Provider::Cron::Unix do
|
|
37
37
|
end
|
38
38
|
end
|
39
39
|
|
40
|
-
let(:status) { double("Process::Status", :
|
40
|
+
let(:status) { double("Process::Status", exitstatus: exitstatus) }
|
41
41
|
let(:exitstatus) { 0 }
|
42
|
-
let(:shell_out) { double("Mixlib::ShellOut", :
|
42
|
+
let(:shell_out) { double("Mixlib::ShellOut", status: status, stdout: stdout, stderr: stderr) }
|
43
43
|
|
44
44
|
let(:logger) { double("Mixlib::Log::Child").as_null_object }
|
45
45
|
|
@@ -53,25 +53,25 @@ describe Chef::Provider::Cron::Unix do
|
|
53
53
|
describe "read_crontab" do
|
54
54
|
let(:stderr) { "" }
|
55
55
|
let(:stdout) do
|
56
|
-
String.new(
|
57
|
-
0 2 * * * /some/other/command
|
56
|
+
String.new(<<~CRONTAB)
|
57
|
+
0 2 * * * /some/other/command
|
58
58
|
|
59
|
-
# Chef Name: something else
|
60
|
-
* 5 * * * /bin/true
|
59
|
+
# Chef Name: something else
|
60
|
+
* 5 * * * /bin/true
|
61
61
|
|
62
|
-
# Another comment
|
62
|
+
# Another comment
|
63
63
|
CRONTAB
|
64
64
|
end
|
65
65
|
|
66
66
|
before do
|
67
67
|
allow(logger).to receive(:trace)
|
68
68
|
allow(shell_out).to receive(:format_for_exception).and_return("formatted command output")
|
69
|
-
allow(provider).to receive(:shell_out).with("/usr/bin/crontab -l", :
|
69
|
+
allow(provider).to receive(:shell_out).with("/usr/bin/crontab -l", user: username).and_return(shell_out)
|
70
70
|
end
|
71
71
|
|
72
72
|
it "should call crontab -l with the user" do
|
73
73
|
provider.send(:read_crontab)
|
74
|
-
expect(provider).to have_received(:shell_out).with("/usr/bin/crontab -l", :
|
74
|
+
expect(provider).to have_received(:shell_out).with("/usr/bin/crontab -l", user: username)
|
75
75
|
end
|
76
76
|
|
77
77
|
it "should return the contents of the crontab" do
|
@@ -111,7 +111,7 @@ describe Chef::Provider::Cron::Unix do
|
|
111
111
|
describe "write_crontab" do
|
112
112
|
let(:stdout) { "" }
|
113
113
|
let(:stderr) { "" }
|
114
|
-
let(:tempfile) { double("foo", :
|
114
|
+
let(:tempfile) { double("foo", path: "/tmp/foo", close: true) }
|
115
115
|
|
116
116
|
before do
|
117
117
|
expect(Tempfile).to receive(:new).and_return(tempfile)
|
@@ -119,12 +119,12 @@ describe Chef::Provider::Cron::Unix do
|
|
119
119
|
expect(tempfile).to receive(:chmod).with(420)
|
120
120
|
expect(tempfile).to receive(:close!)
|
121
121
|
allow(tempfile).to receive(:<<)
|
122
|
-
allow(provider).to receive(:shell_out).with("/usr/bin/crontab #{tempfile.path}", :
|
122
|
+
allow(provider).to receive(:shell_out).with("/usr/bin/crontab #{tempfile.path}", user: username).and_return(shell_out)
|
123
123
|
end
|
124
124
|
|
125
125
|
it "should call crontab for the user" do
|
126
126
|
provider.send(:write_crontab, "Foo")
|
127
|
-
expect(provider).to have_received(:shell_out).with("/usr/bin/crontab #{tempfile.path}", :
|
127
|
+
expect(provider).to have_received(:shell_out).with("/usr/bin/crontab #{tempfile.path}", user: username)
|
128
128
|
end
|
129
129
|
|
130
130
|
it "should call crontab with a file containing the crontab" do
|
@@ -42,15 +42,15 @@ describe Chef::Provider::Cron do
|
|
42
42
|
|
43
43
|
context "with a matching entry in the user's crontab" do
|
44
44
|
before :each do
|
45
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
46
|
-
0 2 * * * /some/other/command
|
45
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
46
|
+
0 2 * * * /some/other/command
|
47
47
|
|
48
|
-
# Chef Name: cronhole some stuff
|
49
|
-
@reboot /bin/true param1 param2
|
50
|
-
# Chef Name: something else
|
51
|
-
2 * 1 * * /bin/false
|
48
|
+
# Chef Name: cronhole some stuff
|
49
|
+
@reboot /bin/true param1 param2
|
50
|
+
# Chef Name: something else
|
51
|
+
2 * 1 * * /bin/false
|
52
52
|
|
53
|
-
# Another comment
|
53
|
+
# Another comment
|
54
54
|
CRONTAB
|
55
55
|
end
|
56
56
|
|
@@ -67,19 +67,19 @@ CRONTAB
|
|
67
67
|
end
|
68
68
|
|
69
69
|
it "should pull env vars out" do
|
70
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
71
|
-
0 2 * * * /some/other/command
|
72
|
-
|
73
|
-
# Chef Name: cronhole some stuff
|
74
|
-
MAILTO=foo@example.com
|
75
|
-
SHELL=/bin/foosh
|
76
|
-
PATH=/bin:/foo
|
77
|
-
HOME=/home/foo
|
78
|
-
@reboot /bin/true param1 param2
|
79
|
-
# Chef Name: something else
|
80
|
-
2 * 1 * * /bin/false
|
81
|
-
|
82
|
-
# Another comment
|
70
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
71
|
+
0 2 * * * /some/other/command
|
72
|
+
|
73
|
+
# Chef Name: cronhole some stuff
|
74
|
+
MAILTO=foo@example.com
|
75
|
+
SHELL=/bin/foosh
|
76
|
+
PATH=/bin:/foo
|
77
|
+
HOME=/home/foo
|
78
|
+
@reboot /bin/true param1 param2
|
79
|
+
# Chef Name: something else
|
80
|
+
2 * 1 * * /bin/false
|
81
|
+
|
82
|
+
# Another comment
|
83
83
|
CRONTAB
|
84
84
|
cron = @provider.load_current_resource
|
85
85
|
expect(cron.mailto).to eq("foo@example.com")
|
@@ -91,12 +91,12 @@ CRONTAB
|
|
91
91
|
end
|
92
92
|
|
93
93
|
it "should parse and load generic and standard environment variables from cron entry" do
|
94
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
95
|
-
# Chef Name: cronhole some stuff
|
96
|
-
MAILTO=warn@example.com
|
97
|
-
TEST=lol
|
98
|
-
FLAG=1
|
99
|
-
@reboot /bin/true
|
94
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
95
|
+
# Chef Name: cronhole some stuff
|
96
|
+
MAILTO=warn@example.com
|
97
|
+
TEST=lol
|
98
|
+
FLAG=1
|
99
|
+
@reboot /bin/true
|
100
100
|
CRONTAB
|
101
101
|
cron = @provider.load_current_resource
|
102
102
|
|
@@ -105,13 +105,13 @@ CRONTAB
|
|
105
105
|
end
|
106
106
|
|
107
107
|
it "should not break with variables that match the cron resource internals" do
|
108
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
109
|
-
# Chef Name: cronhole some stuff
|
110
|
-
MINUTE=40
|
111
|
-
REBOOT=midnight
|
112
|
-
TEST=lol
|
113
|
-
ENVIRONMENT=production
|
114
|
-
@reboot /bin/true
|
108
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
109
|
+
# Chef Name: cronhole some stuff
|
110
|
+
MINUTE=40
|
111
|
+
REBOOT=midnight
|
112
|
+
TEST=lol
|
113
|
+
ENVIRONMENT=production
|
114
|
+
@reboot /bin/true
|
115
115
|
CRONTAB
|
116
116
|
cron = @provider.load_current_resource
|
117
117
|
|
@@ -137,9 +137,9 @@ CRONTAB
|
|
137
137
|
end
|
138
138
|
|
139
139
|
it "should create a crontab with the entry" do
|
140
|
-
expect(@provider).to receive(:write_crontab).with(
|
141
|
-
# Chef Name: cronhole some stuff
|
142
|
-
@reboot /bin/true
|
140
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
141
|
+
# Chef Name: cronhole some stuff
|
142
|
+
@reboot /bin/true
|
143
143
|
ENDCRON
|
144
144
|
@provider.run_action(:create)
|
145
145
|
end
|
@@ -168,13 +168,13 @@ CRONTAB
|
|
168
168
|
|
169
169
|
context "with no matching entry in the user's crontab" do
|
170
170
|
before :each do
|
171
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
172
|
-
0 2 * * * /some/other/command
|
171
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
172
|
+
0 2 * * * /some/other/command
|
173
173
|
|
174
|
-
# Chef Name: something else
|
175
|
-
* 5 * * * /bin/true
|
174
|
+
# Chef Name: something else
|
175
|
+
* 5 * * * /bin/true
|
176
176
|
|
177
|
-
# Another comment
|
177
|
+
# Another comment
|
178
178
|
CRONTAB
|
179
179
|
end
|
180
180
|
|
@@ -190,9 +190,9 @@ CRONTAB
|
|
190
190
|
end
|
191
191
|
|
192
192
|
it "should not fail if there's an existing cron with a numerical argument" do
|
193
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
194
|
-
# Chef Name: foo[bar] (baz)
|
195
|
-
21 */4 * * * some_prog 1234567
|
193
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
194
|
+
# Chef Name: foo[bar] (baz)
|
195
|
+
21 */4 * * * some_prog 1234567
|
196
196
|
CRONTAB
|
197
197
|
expect do
|
198
198
|
@provider.load_current_resource
|
@@ -202,15 +202,15 @@ CRONTAB
|
|
202
202
|
|
203
203
|
context "with a matching entry in the user's crontab" do
|
204
204
|
before :each do
|
205
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
206
|
-
0 2 * * * /some/other/command
|
205
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
206
|
+
0 2 * * * /some/other/command
|
207
207
|
|
208
|
-
# Chef Name: cronhole some stuff
|
209
|
-
* 5 * 1 * /bin/true param1 param2
|
210
|
-
# Chef Name: something else
|
211
|
-
2 * 1 * * /bin/false
|
208
|
+
# Chef Name: cronhole some stuff
|
209
|
+
* 5 * 1 * /bin/true param1 param2
|
210
|
+
# Chef Name: something else
|
211
|
+
2 * 1 * * /bin/false
|
212
212
|
|
213
|
-
# Another comment
|
213
|
+
# Another comment
|
214
214
|
CRONTAB
|
215
215
|
end
|
216
216
|
|
@@ -232,19 +232,19 @@ CRONTAB
|
|
232
232
|
end
|
233
233
|
|
234
234
|
it "should pull env vars out" do
|
235
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
236
|
-
0 2 * * * /some/other/command
|
237
|
-
|
238
|
-
# Chef Name: cronhole some stuff
|
239
|
-
MAILTO=foo@example.com
|
240
|
-
SHELL=/bin/foosh
|
241
|
-
PATH=/bin:/foo
|
242
|
-
HOME=/home/foo
|
243
|
-
* 5 * 1 * /bin/true param1 param2
|
244
|
-
# Chef Name: something else
|
245
|
-
2 * 1 * * /bin/false
|
246
|
-
|
247
|
-
# Another comment
|
235
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
236
|
+
0 2 * * * /some/other/command
|
237
|
+
|
238
|
+
# Chef Name: cronhole some stuff
|
239
|
+
MAILTO=foo@example.com
|
240
|
+
SHELL=/bin/foosh
|
241
|
+
PATH=/bin:/foo
|
242
|
+
HOME=/home/foo
|
243
|
+
* 5 * 1 * /bin/true param1 param2
|
244
|
+
# Chef Name: something else
|
245
|
+
2 * 1 * * /bin/false
|
246
|
+
|
247
|
+
# Another comment
|
248
248
|
CRONTAB
|
249
249
|
cron = @provider.load_current_resource
|
250
250
|
expect(cron.mailto).to eq("foo@example.com")
|
@@ -261,12 +261,12 @@ CRONTAB
|
|
261
261
|
end
|
262
262
|
|
263
263
|
it "should parse and load generic and standard environment variables from cron entry" do
|
264
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
265
|
-
# Chef Name: cronhole some stuff
|
266
|
-
MAILTO=warn@example.com
|
267
|
-
TEST=lol
|
268
|
-
FLAG=1
|
269
|
-
* 5 * * * /bin/true
|
264
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
265
|
+
# Chef Name: cronhole some stuff
|
266
|
+
MAILTO=warn@example.com
|
267
|
+
TEST=lol
|
268
|
+
FLAG=1
|
269
|
+
* 5 * * * /bin/true
|
270
270
|
CRONTAB
|
271
271
|
cron = @provider.load_current_resource
|
272
272
|
|
@@ -275,13 +275,13 @@ CRONTAB
|
|
275
275
|
end
|
276
276
|
|
277
277
|
it "should not break with variabels that match the cron resource internals" do
|
278
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
279
|
-
# Chef Name: cronhole some stuff
|
280
|
-
MINUTE=40
|
281
|
-
HOUR=midnight
|
282
|
-
TEST=lol
|
283
|
-
ENVIRONMENT=production
|
284
|
-
* 5 * * * /bin/true
|
278
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
279
|
+
# Chef Name: cronhole some stuff
|
280
|
+
MINUTE=40
|
281
|
+
HOUR=midnight
|
282
|
+
TEST=lol
|
283
|
+
ENVIRONMENT=production
|
284
|
+
* 5 * * * /bin/true
|
285
285
|
CRONTAB
|
286
286
|
cron = @provider.load_current_resource
|
287
287
|
|
@@ -298,15 +298,15 @@ CRONTAB
|
|
298
298
|
|
299
299
|
context "with a matching entry in the user's crontab using month names and weekday names (#CHEF-3178)" do
|
300
300
|
before :each do
|
301
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
302
|
-
0 2 * * * /some/other/command
|
301
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
302
|
+
0 2 * * * /some/other/command
|
303
303
|
|
304
|
-
# Chef Name: cronhole some stuff
|
305
|
-
* 5 * Jan Mon /bin/true param1 param2
|
306
|
-
# Chef Name: something else
|
307
|
-
2 * 1 * * /bin/false
|
304
|
+
# Chef Name: cronhole some stuff
|
305
|
+
* 5 * Jan Mon /bin/true param1 param2
|
306
|
+
# Chef Name: something else
|
307
|
+
2 * 1 * * /bin/false
|
308
308
|
|
309
|
-
# Another comment
|
309
|
+
# Another comment
|
310
310
|
CRONTAB
|
311
311
|
end
|
312
312
|
|
@@ -334,10 +334,10 @@ CRONTAB
|
|
334
334
|
|
335
335
|
context "with a matching entry without a crontab line" do
|
336
336
|
it "should set cron_exists and leave current_resource values at defaults" do
|
337
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
338
|
-
0 2 * * * /some/other/command
|
337
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
338
|
+
0 2 * * * /some/other/command
|
339
339
|
|
340
|
-
# Chef Name: cronhole some stuff
|
340
|
+
# Chef Name: cronhole some stuff
|
341
341
|
CRONTAB
|
342
342
|
cron = @provider.load_current_resource
|
343
343
|
expect(@provider.cron_exists).to eq(true)
|
@@ -351,11 +351,11 @@ CRONTAB
|
|
351
351
|
end
|
352
352
|
|
353
353
|
it "should not pick up a commented out crontab line" do
|
354
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
355
|
-
0 2 * * * /some/other/command
|
354
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
355
|
+
0 2 * * * /some/other/command
|
356
356
|
|
357
|
-
# Chef Name: cronhole some stuff
|
358
|
-
#* 5 * 1 * /bin/true param1 param2
|
357
|
+
# Chef Name: cronhole some stuff
|
358
|
+
#* 5 * 1 * /bin/true param1 param2
|
359
359
|
CRONTAB
|
360
360
|
cron = @provider.load_current_resource
|
361
361
|
expect(@provider.cron_exists).to eq(true)
|
@@ -369,15 +369,15 @@ CRONTAB
|
|
369
369
|
end
|
370
370
|
|
371
371
|
it "should not pick up a later crontab entry" do
|
372
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
373
|
-
0 2 * * * /some/other/command
|
372
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
373
|
+
0 2 * * * /some/other/command
|
374
374
|
|
375
|
-
# Chef Name: cronhole some stuff
|
376
|
-
#* 5 * 1 * /bin/true param1 param2
|
377
|
-
# Chef Name: something else
|
378
|
-
2 * 1 * * /bin/false
|
375
|
+
# Chef Name: cronhole some stuff
|
376
|
+
#* 5 * 1 * /bin/true param1 param2
|
377
|
+
# Chef Name: something else
|
378
|
+
2 * 1 * * /bin/false
|
379
379
|
|
380
|
-
# Another comment
|
380
|
+
# Another comment
|
381
381
|
CRONTAB
|
382
382
|
cron = @provider.load_current_resource
|
383
383
|
expect(@provider.cron_exists).to eq(true)
|
@@ -442,9 +442,9 @@ CRONTAB
|
|
442
442
|
end
|
443
443
|
|
444
444
|
it "should create a crontab with the entry" do
|
445
|
-
expect(@provider).to receive(:write_crontab).with(
|
446
|
-
# Chef Name: cronhole some stuff
|
447
|
-
30 * * * * /bin/true
|
445
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
446
|
+
# Chef Name: cronhole some stuff
|
447
|
+
30 * * * * /bin/true
|
448
448
|
ENDCRON
|
449
449
|
@provider.run_action(:create)
|
450
450
|
end
|
@@ -455,14 +455,14 @@ CRONTAB
|
|
455
455
|
@new_resource.shell "/bin/foosh"
|
456
456
|
@new_resource.home "/home/foo"
|
457
457
|
@new_resource.environment "TEST" => "LOL"
|
458
|
-
expect(@provider).to receive(:write_crontab).with(
|
459
|
-
# Chef Name: cronhole some stuff
|
460
|
-
MAILTO="foo@example.com"
|
461
|
-
PATH="/usr/bin:/my/custom/path"
|
462
|
-
SHELL="/bin/foosh"
|
463
|
-
HOME="/home/foo"
|
464
|
-
TEST=LOL
|
465
|
-
30 * * * * /bin/true
|
458
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
459
|
+
# Chef Name: cronhole some stuff
|
460
|
+
MAILTO="foo@example.com"
|
461
|
+
PATH="/usr/bin:/my/custom/path"
|
462
|
+
SHELL="/bin/foosh"
|
463
|
+
HOME="/home/foo"
|
464
|
+
TEST=LOL
|
465
|
+
30 * * * * /bin/true
|
466
466
|
ENDCRON
|
467
467
|
@provider.run_action(:create)
|
468
468
|
end
|
@@ -481,26 +481,26 @@ TEST=LOL
|
|
481
481
|
context "when there is a crontab with no matching section" do
|
482
482
|
before :each do
|
483
483
|
@provider.cron_exists = false
|
484
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
485
|
-
0 2 * * * /some/other/command
|
484
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
485
|
+
0 2 * * * /some/other/command
|
486
486
|
|
487
|
-
# Chef Name: something else
|
488
|
-
2 * 1 * * /bin/false
|
487
|
+
# Chef Name: something else
|
488
|
+
2 * 1 * * /bin/false
|
489
489
|
|
490
|
-
# Another comment
|
490
|
+
# Another comment
|
491
491
|
CRONTAB
|
492
492
|
end
|
493
493
|
|
494
494
|
it "should add the entry to the crontab" do
|
495
|
-
expect(@provider).to receive(:write_crontab).with(
|
496
|
-
0 2 * * * /some/other/command
|
495
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
496
|
+
0 2 * * * /some/other/command
|
497
497
|
|
498
|
-
# Chef Name: something else
|
499
|
-
2 * 1 * * /bin/false
|
498
|
+
# Chef Name: something else
|
499
|
+
2 * 1 * * /bin/false
|
500
500
|
|
501
|
-
# Another comment
|
502
|
-
# Chef Name: cronhole some stuff
|
503
|
-
30 * * * * /bin/true
|
501
|
+
# Another comment
|
502
|
+
# Chef Name: cronhole some stuff
|
503
|
+
30 * * * * /bin/true
|
504
504
|
ENDCRON
|
505
505
|
@provider.run_action(:create)
|
506
506
|
end
|
@@ -511,20 +511,20 @@ TEST=LOL
|
|
511
511
|
@new_resource.shell "/bin/foosh"
|
512
512
|
@new_resource.home "/home/foo"
|
513
513
|
@new_resource.environment "TEST" => "LOL"
|
514
|
-
expect(@provider).to receive(:write_crontab).with(
|
515
|
-
0 2 * * * /some/other/command
|
516
|
-
|
517
|
-
# Chef Name: something else
|
518
|
-
2 * 1 * * /bin/false
|
519
|
-
|
520
|
-
# Another comment
|
521
|
-
# Chef Name: cronhole some stuff
|
522
|
-
MAILTO="foo@example.com"
|
523
|
-
PATH="/usr/bin:/my/custom/path"
|
524
|
-
SHELL="/bin/foosh"
|
525
|
-
HOME="/home/foo"
|
526
|
-
TEST=LOL
|
527
|
-
30 * * * * /bin/true
|
514
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
515
|
+
0 2 * * * /some/other/command
|
516
|
+
|
517
|
+
# Chef Name: something else
|
518
|
+
2 * 1 * * /bin/false
|
519
|
+
|
520
|
+
# Another comment
|
521
|
+
# Chef Name: cronhole some stuff
|
522
|
+
MAILTO="foo@example.com"
|
523
|
+
PATH="/usr/bin:/my/custom/path"
|
524
|
+
SHELL="/bin/foosh"
|
525
|
+
HOME="/home/foo"
|
526
|
+
TEST=LOL
|
527
|
+
30 * * * * /bin/true
|
528
528
|
ENDCRON
|
529
529
|
@provider.run_action(:create)
|
530
530
|
end
|
@@ -544,28 +544,28 @@ TEST=LOL
|
|
544
544
|
before :each do
|
545
545
|
@provider.cron_exists = true
|
546
546
|
allow(@provider).to receive(:cron_different?).and_return(true)
|
547
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
548
|
-
0 2 * * * /some/other/command
|
547
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
548
|
+
0 2 * * * /some/other/command
|
549
549
|
|
550
|
-
# Chef Name: cronhole some stuff
|
551
|
-
30 * * 3 * /bin/true
|
552
|
-
# Chef Name: something else
|
553
|
-
2 * 1 * * /bin/false
|
550
|
+
# Chef Name: cronhole some stuff
|
551
|
+
30 * * 3 * /bin/true
|
552
|
+
# Chef Name: something else
|
553
|
+
2 * 1 * * /bin/false
|
554
554
|
|
555
|
-
# Another comment
|
555
|
+
# Another comment
|
556
556
|
CRONTAB
|
557
557
|
end
|
558
558
|
|
559
559
|
it "should update the crontab entry" do
|
560
|
-
expect(@provider).to receive(:write_crontab).with(
|
561
|
-
0 2 * * * /some/other/command
|
560
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
561
|
+
0 2 * * * /some/other/command
|
562
562
|
|
563
|
-
# Chef Name: cronhole some stuff
|
564
|
-
30 * * * * /bin/true
|
565
|
-
# Chef Name: something else
|
566
|
-
2 * 1 * * /bin/false
|
563
|
+
# Chef Name: cronhole some stuff
|
564
|
+
30 * * * * /bin/true
|
565
|
+
# Chef Name: something else
|
566
|
+
2 * 1 * * /bin/false
|
567
567
|
|
568
|
-
# Another comment
|
568
|
+
# Another comment
|
569
569
|
ENDCRON
|
570
570
|
@provider.run_action(:create)
|
571
571
|
end
|
@@ -576,20 +576,20 @@ TEST=LOL
|
|
576
576
|
@new_resource.shell "/bin/foosh"
|
577
577
|
@new_resource.home "/home/foo"
|
578
578
|
@new_resource.environment "TEST" => "LOL"
|
579
|
-
expect(@provider).to receive(:write_crontab).with(
|
580
|
-
0 2 * * * /some/other/command
|
581
|
-
|
582
|
-
# Chef Name: cronhole some stuff
|
583
|
-
MAILTO="foo@example.com"
|
584
|
-
PATH="/usr/bin:/my/custom/path"
|
585
|
-
SHELL="/bin/foosh"
|
586
|
-
HOME="/home/foo"
|
587
|
-
TEST=LOL
|
588
|
-
30 * * * * /bin/true
|
589
|
-
# Chef Name: something else
|
590
|
-
2 * 1 * * /bin/false
|
591
|
-
|
592
|
-
# Another comment
|
579
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
580
|
+
0 2 * * * /some/other/command
|
581
|
+
|
582
|
+
# Chef Name: cronhole some stuff
|
583
|
+
MAILTO="foo@example.com"
|
584
|
+
PATH="/usr/bin:/my/custom/path"
|
585
|
+
SHELL="/bin/foosh"
|
586
|
+
HOME="/home/foo"
|
587
|
+
TEST=LOL
|
588
|
+
30 * * * * /bin/true
|
589
|
+
# Chef Name: something else
|
590
|
+
2 * 1 * * /bin/false
|
591
|
+
|
592
|
+
# Another comment
|
593
593
|
ENDCRON
|
594
594
|
@provider.run_action(:create)
|
595
595
|
end
|
@@ -612,78 +612,78 @@ TEST=LOL
|
|
612
612
|
end
|
613
613
|
|
614
614
|
it "should add the crontab to the entry" do
|
615
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
616
|
-
0 2 * * * /some/other/command
|
615
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
616
|
+
0 2 * * * /some/other/command
|
617
617
|
|
618
|
-
# Chef Name: cronhole some stuff
|
618
|
+
# Chef Name: cronhole some stuff
|
619
619
|
CRONTAB
|
620
|
-
expect(@provider).to receive(:write_crontab).with(
|
621
|
-
0 2 * * * /some/other/command
|
620
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
621
|
+
0 2 * * * /some/other/command
|
622
622
|
|
623
|
-
# Chef Name: cronhole some stuff
|
624
|
-
30 * * * * /bin/true
|
623
|
+
# Chef Name: cronhole some stuff
|
624
|
+
30 * * * * /bin/true
|
625
625
|
ENDCRON
|
626
626
|
@provider.run_action(:create)
|
627
627
|
end
|
628
628
|
|
629
629
|
it "should not blat any following entries" do
|
630
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
631
|
-
0 2 * * * /some/other/command
|
630
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
631
|
+
0 2 * * * /some/other/command
|
632
632
|
|
633
|
-
# Chef Name: cronhole some stuff
|
634
|
-
#30 * * * * /bin/true
|
635
|
-
# Chef Name: something else
|
636
|
-
2 * 1 * * /bin/false
|
633
|
+
# Chef Name: cronhole some stuff
|
634
|
+
#30 * * * * /bin/true
|
635
|
+
# Chef Name: something else
|
636
|
+
2 * 1 * * /bin/false
|
637
637
|
|
638
|
-
# Another comment
|
638
|
+
# Another comment
|
639
639
|
CRONTAB
|
640
|
-
expect(@provider).to receive(:write_crontab).with(
|
641
|
-
0 2 * * * /some/other/command
|
640
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
641
|
+
0 2 * * * /some/other/command
|
642
642
|
|
643
|
-
# Chef Name: cronhole some stuff
|
644
|
-
30 * * * * /bin/true
|
645
|
-
#30 * * * * /bin/true
|
646
|
-
# Chef Name: something else
|
647
|
-
2 * 1 * * /bin/false
|
643
|
+
# Chef Name: cronhole some stuff
|
644
|
+
30 * * * * /bin/true
|
645
|
+
#30 * * * * /bin/true
|
646
|
+
# Chef Name: something else
|
647
|
+
2 * 1 * * /bin/false
|
648
648
|
|
649
|
-
# Another comment
|
649
|
+
# Another comment
|
650
650
|
ENDCRON
|
651
651
|
@provider.run_action(:create)
|
652
652
|
end
|
653
653
|
|
654
654
|
it "should handle env vars with no crontab" do
|
655
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
656
|
-
0 2 * * * /some/other/command
|
655
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
656
|
+
0 2 * * * /some/other/command
|
657
657
|
|
658
|
-
# Chef Name: cronhole some stuff
|
659
|
-
MAILTO=bar@example.com
|
660
|
-
PATH=/usr/bin:/my/custom/path
|
661
|
-
SHELL=/bin/barsh
|
662
|
-
HOME=/home/foo
|
658
|
+
# Chef Name: cronhole some stuff
|
659
|
+
MAILTO=bar@example.com
|
660
|
+
PATH=/usr/bin:/my/custom/path
|
661
|
+
SHELL=/bin/barsh
|
662
|
+
HOME=/home/foo
|
663
663
|
|
664
|
-
# Chef Name: something else
|
665
|
-
2 * 1 * * /bin/false
|
664
|
+
# Chef Name: something else
|
665
|
+
2 * 1 * * /bin/false
|
666
666
|
|
667
|
-
# Another comment
|
667
|
+
# Another comment
|
668
668
|
CRONTAB
|
669
669
|
@new_resource.mailto "foo@example.com"
|
670
670
|
@new_resource.path "/usr/bin:/my/custom/path"
|
671
671
|
@new_resource.shell "/bin/foosh"
|
672
672
|
@new_resource.home "/home/foo"
|
673
|
-
expect(@provider).to receive(:write_crontab).with(
|
674
|
-
0 2 * * * /some/other/command
|
673
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
674
|
+
0 2 * * * /some/other/command
|
675
675
|
|
676
|
-
# Chef Name: cronhole some stuff
|
677
|
-
MAILTO="foo@example.com"
|
678
|
-
PATH="/usr/bin:/my/custom/path"
|
679
|
-
SHELL="/bin/foosh"
|
680
|
-
HOME="/home/foo"
|
681
|
-
30 * * * * /bin/true
|
676
|
+
# Chef Name: cronhole some stuff
|
677
|
+
MAILTO="foo@example.com"
|
678
|
+
PATH="/usr/bin:/my/custom/path"
|
679
|
+
SHELL="/bin/foosh"
|
680
|
+
HOME="/home/foo"
|
681
|
+
30 * * * * /bin/true
|
682
682
|
|
683
|
-
# Chef Name: something else
|
684
|
-
2 * 1 * * /bin/false
|
683
|
+
# Chef Name: something else
|
684
|
+
2 * 1 * * /bin/false
|
685
685
|
|
686
|
-
# Another comment
|
686
|
+
# Another comment
|
687
687
|
ENDCRON
|
688
688
|
@provider.run_action(:create)
|
689
689
|
end
|
@@ -693,13 +693,13 @@ HOME="/home/foo"
|
|
693
693
|
before :each do
|
694
694
|
@provider.cron_exists = true
|
695
695
|
allow(@provider).to receive(:cron_different?).and_return(false)
|
696
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
697
|
-
0 2 * * * /some/other/command
|
696
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
697
|
+
0 2 * * * /some/other/command
|
698
698
|
|
699
|
-
# Chef Name: cronhole some stuff
|
700
|
-
* 5 * * * /bin/true
|
699
|
+
# Chef Name: cronhole some stuff
|
700
|
+
* 5 * * * /bin/true
|
701
701
|
|
702
|
-
# Another comment
|
702
|
+
# Another comment
|
703
703
|
CRONTAB
|
704
704
|
end
|
705
705
|
|
@@ -747,50 +747,50 @@ CRONTAB
|
|
747
747
|
context "when the user has a crontab with a matching section" do
|
748
748
|
before :each do
|
749
749
|
@provider.cron_exists = true
|
750
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
751
|
-
0 2 * * * /some/other/command
|
750
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
751
|
+
0 2 * * * /some/other/command
|
752
752
|
|
753
|
-
# Chef Name: cronhole some stuff
|
754
|
-
30 * * 3 * /bin/true
|
755
|
-
# Chef Name: something else
|
756
|
-
2 * 1 * * /bin/false
|
753
|
+
# Chef Name: cronhole some stuff
|
754
|
+
30 * * 3 * /bin/true
|
755
|
+
# Chef Name: something else
|
756
|
+
2 * 1 * * /bin/false
|
757
757
|
|
758
|
-
# Another comment
|
758
|
+
# Another comment
|
759
759
|
CRONTAB
|
760
760
|
end
|
761
761
|
|
762
762
|
it "should remove the entry" do
|
763
|
-
expect(@provider).to receive(:write_crontab).with(
|
764
|
-
0 2 * * * /some/other/command
|
763
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
764
|
+
0 2 * * * /some/other/command
|
765
765
|
|
766
|
-
# Chef Name: something else
|
767
|
-
2 * 1 * * /bin/false
|
766
|
+
# Chef Name: something else
|
767
|
+
2 * 1 * * /bin/false
|
768
768
|
|
769
|
-
# Another comment
|
769
|
+
# Another comment
|
770
770
|
ENDCRON
|
771
771
|
@provider.run_action(:delete)
|
772
772
|
end
|
773
773
|
|
774
774
|
it "should remove any env vars with the entry" do
|
775
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
776
|
-
0 2 * * * /some/other/command
|
775
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
776
|
+
0 2 * * * /some/other/command
|
777
777
|
|
778
|
-
# Chef Name: cronhole some stuff
|
779
|
-
MAILTO=foo@example.com
|
780
|
-
FOO=test
|
781
|
-
30 * * 3 * /bin/true
|
782
|
-
# Chef Name: something else
|
783
|
-
2 * 1 * * /bin/false
|
778
|
+
# Chef Name: cronhole some stuff
|
779
|
+
MAILTO=foo@example.com
|
780
|
+
FOO=test
|
781
|
+
30 * * 3 * /bin/true
|
782
|
+
# Chef Name: something else
|
783
|
+
2 * 1 * * /bin/false
|
784
784
|
|
785
|
-
# Another comment
|
785
|
+
# Another comment
|
786
786
|
CRONTAB
|
787
|
-
expect(@provider).to receive(:write_crontab).with(
|
788
|
-
0 2 * * * /some/other/command
|
787
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
788
|
+
0 2 * * * /some/other/command
|
789
789
|
|
790
|
-
# Chef Name: something else
|
791
|
-
2 * 1 * * /bin/false
|
790
|
+
# Chef Name: something else
|
791
|
+
2 * 1 * * /bin/false
|
792
792
|
|
793
|
-
# Another comment
|
793
|
+
# Another comment
|
794
794
|
ENDCRON
|
795
795
|
@provider.run_action(:delete)
|
796
796
|
end
|
@@ -812,61 +812,61 @@ FOO=test
|
|
812
812
|
end
|
813
813
|
|
814
814
|
it "should remove the section" do
|
815
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
816
|
-
0 2 * * * /some/other/command
|
815
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
816
|
+
0 2 * * * /some/other/command
|
817
817
|
|
818
|
-
# Chef Name: cronhole some stuff
|
818
|
+
# Chef Name: cronhole some stuff
|
819
819
|
CRONTAB
|
820
|
-
expect(@provider).to receive(:write_crontab).with(
|
821
|
-
0 2 * * * /some/other/command
|
820
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
821
|
+
0 2 * * * /some/other/command
|
822
822
|
|
823
823
|
ENDCRON
|
824
824
|
@provider.run_action(:delete)
|
825
825
|
end
|
826
826
|
|
827
827
|
it "should not blat following sections" do
|
828
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
829
|
-
0 2 * * * /some/other/command
|
828
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
829
|
+
0 2 * * * /some/other/command
|
830
830
|
|
831
|
-
# Chef Name: cronhole some stuff
|
832
|
-
#30 * * 3 * /bin/true
|
833
|
-
# Chef Name: something else
|
834
|
-
2 * 1 * * /bin/false
|
831
|
+
# Chef Name: cronhole some stuff
|
832
|
+
#30 * * 3 * /bin/true
|
833
|
+
# Chef Name: something else
|
834
|
+
2 * 1 * * /bin/false
|
835
835
|
|
836
|
-
# Another comment
|
836
|
+
# Another comment
|
837
837
|
CRONTAB
|
838
|
-
expect(@provider).to receive(:write_crontab).with(
|
839
|
-
0 2 * * * /some/other/command
|
838
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
839
|
+
0 2 * * * /some/other/command
|
840
840
|
|
841
|
-
#30 * * 3 * /bin/true
|
842
|
-
# Chef Name: something else
|
843
|
-
2 * 1 * * /bin/false
|
841
|
+
#30 * * 3 * /bin/true
|
842
|
+
# Chef Name: something else
|
843
|
+
2 * 1 * * /bin/false
|
844
844
|
|
845
|
-
# Another comment
|
845
|
+
# Another comment
|
846
846
|
ENDCRON
|
847
847
|
@provider.run_action(:delete)
|
848
848
|
end
|
849
849
|
|
850
850
|
it "should remove any envvars with the section" do
|
851
|
-
allow(@provider).to receive(:read_crontab).and_return(
|
852
|
-
0 2 * * * /some/other/command
|
851
|
+
allow(@provider).to receive(:read_crontab).and_return(<<~CRONTAB)
|
852
|
+
0 2 * * * /some/other/command
|
853
853
|
|
854
|
-
# Chef Name: cronhole some stuff
|
855
|
-
MAILTO=foo@example.com
|
856
|
-
#30 * * 3 * /bin/true
|
857
|
-
# Chef Name: something else
|
858
|
-
2 * 1 * * /bin/false
|
854
|
+
# Chef Name: cronhole some stuff
|
855
|
+
MAILTO=foo@example.com
|
856
|
+
#30 * * 3 * /bin/true
|
857
|
+
# Chef Name: something else
|
858
|
+
2 * 1 * * /bin/false
|
859
859
|
|
860
|
-
# Another comment
|
860
|
+
# Another comment
|
861
861
|
CRONTAB
|
862
|
-
expect(@provider).to receive(:write_crontab).with(
|
863
|
-
0 2 * * * /some/other/command
|
862
|
+
expect(@provider).to receive(:write_crontab).with(<<~ENDCRON)
|
863
|
+
0 2 * * * /some/other/command
|
864
864
|
|
865
|
-
#30 * * 3 * /bin/true
|
866
|
-
# Chef Name: something else
|
867
|
-
2 * 1 * * /bin/false
|
865
|
+
#30 * * 3 * /bin/true
|
866
|
+
# Chef Name: something else
|
867
|
+
2 * 1 * * /bin/false
|
868
868
|
|
869
|
-
# Another comment
|
869
|
+
# Another comment
|
870
870
|
ENDCRON
|
871
871
|
@provider.run_action(:delete)
|
872
872
|
end
|
@@ -875,13 +875,13 @@ MAILTO=foo@example.com
|
|
875
875
|
|
876
876
|
describe "read_crontab" do
|
877
877
|
before :each do
|
878
|
-
@stdout =
|
879
|
-
0 2 * * * /some/other/command
|
878
|
+
@stdout = <<~CRONTAB
|
879
|
+
0 2 * * * /some/other/command
|
880
880
|
|
881
|
-
# Chef Name: something else
|
882
|
-
* 5 * * * /bin/true
|
881
|
+
# Chef Name: something else
|
882
|
+
* 5 * * * /bin/true
|
883
883
|
|
884
|
-
# Another comment
|
884
|
+
# Another comment
|
885
885
|
CRONTAB
|
886
886
|
@status = double("Status", exitstatus: 0, stdout: @stdout)
|
887
887
|
allow(@provider).to receive(:shell_out!).and_return(@status)
|
@@ -894,13 +894,13 @@ MAILTO=foo@example.com
|
|
894
894
|
|
895
895
|
it "should return the contents of the crontab" do
|
896
896
|
crontab = @provider.send(:read_crontab)
|
897
|
-
expect(crontab).to eq
|
898
|
-
0 2 * * * /some/other/command
|
897
|
+
expect(crontab).to eq <<~CRONTAB
|
898
|
+
0 2 * * * /some/other/command
|
899
899
|
|
900
|
-
# Chef Name: something else
|
901
|
-
* 5 * * * /bin/true
|
900
|
+
# Chef Name: something else
|
901
|
+
* 5 * * * /bin/true
|
902
902
|
|
903
|
-
# Another comment
|
903
|
+
# Another comment
|
904
904
|
CRONTAB
|
905
905
|
end
|
906
906
|
|