chef 12.0.3-x86-mingw32 → 12.1.0.rc.0-x86-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/CONTRIBUTING.md +4 -1
- data/README.md +42 -18
- data/distro/common/html/_sources/ctl_chef_client.txt +1 -1
- data/distro/common/html/_sources/ctl_chef_server.txt +53 -35
- data/distro/common/html/_sources/ctl_chef_solo.txt +1 -1
- data/distro/common/html/_sources/knife_bootstrap.txt +1 -1
- data/distro/common/html/_sources/knife_cookbook_site.txt +1 -1
- data/distro/common/html/_sources/knife_data_bag.txt +4 -4
- data/distro/common/html/_sources/knife_status.txt +1 -1
- data/distro/common/html/_static/searchtools.js +1 -1
- data/distro/common/html/ctl_chef_client.html +55 -7
- data/distro/common/html/ctl_chef_server.html +84 -41
- data/distro/common/html/ctl_chef_shell.html +45 -1
- data/distro/common/html/ctl_chef_solo.html +51 -5
- data/distro/common/html/index.html +2 -2
- data/distro/common/html/knife.html +1 -1
- data/distro/common/html/knife_bootstrap.html +30 -10
- data/distro/common/html/knife_cookbook_site.html +2 -0
- data/distro/common/html/knife_data_bag.html +4 -4
- data/distro/common/html/knife_node.html +2 -2
- data/distro/common/html/knife_raw.html +1 -1
- data/distro/common/html/knife_role.html +1 -1
- data/distro/common/html/knife_search.html +3 -3
- data/distro/common/html/knife_status.html +4 -0
- data/distro/common/html/searchindex.js +1 -1
- data/distro/common/man/man1/chef-shell.1 +72 -1
- data/distro/common/man/man1/knife-bootstrap.1 +71 -63
- data/distro/common/man/man1/knife-client.1 +1 -1
- data/distro/common/man/man1/knife-configure.1 +1 -1
- data/distro/common/man/man1/knife-cookbook-site.1 +4 -1
- data/distro/common/man/man1/knife-cookbook.1 +1 -1
- data/distro/common/man/man1/knife-data-bag.1 +5 -5
- data/distro/common/man/man1/knife-delete.1 +1 -1
- data/distro/common/man/man1/knife-deps.1 +1 -1
- data/distro/common/man/man1/knife-diff.1 +1 -1
- data/distro/common/man/man1/knife-download.1 +1 -1
- data/distro/common/man/man1/knife-edit.1 +1 -1
- data/distro/common/man/man1/knife-environment.1 +1 -1
- data/distro/common/man/man1/knife-exec.1 +1 -1
- data/distro/common/man/man1/knife-index-rebuild.1 +1 -1
- data/distro/common/man/man1/knife-list.1 +1 -1
- data/distro/common/man/man1/knife-node.1 +3 -3
- data/distro/common/man/man1/knife-raw.1 +2 -2
- data/distro/common/man/man1/knife-recipe-list.1 +1 -1
- data/distro/common/man/man1/knife-role.1 +2 -2
- data/distro/common/man/man1/knife-search.1 +4 -4
- data/distro/common/man/man1/knife-serve.1 +1 -1
- data/distro/common/man/man1/knife-show.1 +1 -1
- data/distro/common/man/man1/knife-ssh.1 +1 -1
- data/distro/common/man/man1/knife-ssl-check.1 +1 -1
- data/distro/common/man/man1/knife-ssl-fetch.1 +1 -1
- data/distro/common/man/man1/knife-status.1 +1 -1
- data/distro/common/man/man1/knife-tag.1 +1 -1
- data/distro/common/man/man1/knife-upload.1 +1 -1
- data/distro/common/man/man1/knife-user.1 +1 -1
- data/distro/common/man/man1/knife-xargs.1 +1 -1
- data/distro/common/man/man1/knife.1 +1 -1
- data/distro/common/man/man8/chef-apply.8 +86 -0
- data/distro/common/man/man8/chef-client.8 +76 -5
- data/distro/common/man/man8/chef-solo.8 +79 -6
- data/distro/common/markdown/man1/knife-bootstrap.mkd +1 -1
- data/distro/common/markdown/man1/knife-cookbook-site.mkd +1 -1
- data/distro/common/markdown/man1/knife-data-bag.mkd +1 -1
- data/distro/common/markdown/man1/knife-environment.mkd +1 -1
- data/distro/common/markdown/man1/knife.mkd +1 -1
- data/lib/chef.rb +0 -7
- data/lib/chef/api_client.rb +10 -2
- data/lib/chef/api_client/registration.rb +7 -9
- data/lib/chef/application.rb +28 -12
- data/lib/chef/application/apply.rb +17 -1
- data/lib/chef/application/client.rb +74 -6
- data/lib/chef/application/knife.rb +1 -2
- data/lib/chef/application/solo.rb +30 -0
- data/lib/chef/application/windows_service.rb +1 -0
- data/lib/chef/application/windows_service_manager.rb +8 -2
- data/lib/chef/applications.rb +0 -1
- data/lib/chef/audit/audit_event_proxy.rb +93 -0
- data/lib/chef/audit/audit_reporter.rb +169 -0
- data/lib/chef/audit/control_group_data.rb +140 -0
- data/lib/chef/audit/rspec_formatter.rb +37 -0
- data/lib/chef/audit/runner.rb +178 -0
- data/lib/chef/chef_fs/chef_fs_data_store.rb +11 -2
- data/lib/chef/chef_fs/config.rb +25 -4
- data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +15 -0
- data/lib/chef/chef_fs/data_handler/user_data_handler.rb +1 -0
- data/lib/chef/chef_fs/file_system.rb +1 -1
- data/lib/chef/chef_fs/file_system/base_fs_dir.rb +5 -0
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbook_entry.rb +3 -2
- data/lib/chef/{shef/ext.rb → chef_fs/file_system/chef_repository_file_system_policies_dir.rb} +22 -3
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +4 -0
- data/lib/chef/client.rb +81 -52
- data/lib/chef/config.rb +35 -3
- data/lib/chef/cookbook/metadata.rb +3 -3
- data/lib/chef/cookbook_manifest.rb +275 -0
- data/lib/chef/cookbook_site_streaming_uploader.rb +24 -23
- data/lib/chef/cookbook_uploader.rb +11 -2
- data/lib/chef/cookbook_version.rb +71 -194
- data/lib/chef/data_bag.rb +5 -2
- data/lib/chef/data_bag_item.rb +6 -3
- data/lib/chef/deprecation/warnings.rb +5 -4
- data/lib/chef/dsl/audit.rb +51 -0
- data/lib/chef/dsl/include_recipe.rb +2 -3
- data/lib/chef/dsl/reboot_pending.rb +1 -1
- data/lib/chef/dsl/recipe.rb +49 -31
- data/lib/chef/encrypted_data_bag_item/assertions.rb +0 -3
- data/lib/chef/environment.rb +5 -2
- data/lib/chef/event_dispatch/base.rb +36 -1
- data/lib/chef/event_dispatch/dispatcher.rb +3 -5
- data/lib/chef/exceptions.rb +61 -2
- data/lib/chef/file_access_control/unix.rb +12 -0
- data/lib/chef/file_access_control/windows.rb +14 -0
- data/lib/chef/formatters/doc.rb +47 -1
- data/{spec/unit/monkey_patches/string_spec.rb → lib/chef/guard_interpreter.rb} +11 -16
- data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +3 -2
- data/lib/chef/http.rb +1 -2
- data/lib/chef/knife.rb +5 -3
- data/lib/chef/knife/bootstrap.rb +84 -15
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +165 -0
- data/lib/chef/knife/bootstrap/client_builder.rb +190 -0
- data/lib/chef/knife/bootstrap/{README.md → templates/README.md} +0 -0
- data/lib/chef/knife/bootstrap/{archlinux-gems.erb → templates/archlinux-gems.erb} +9 -0
- data/lib/chef/knife/bootstrap/{chef-aix.erb → templates/chef-aix.erb} +9 -0
- data/lib/chef/knife/bootstrap/{chef-full.erb → templates/chef-full.erb} +10 -1
- data/lib/chef/knife/client_create.rb +8 -7
- data/lib/chef/knife/cookbook_site_download.rb +1 -1
- data/lib/chef/knife/cookbook_site_install.rb +1 -1
- data/lib/chef/knife/cookbook_site_list.rb +1 -1
- data/lib/chef/knife/cookbook_site_search.rb +1 -1
- data/lib/chef/knife/cookbook_site_share.rb +39 -28
- data/lib/chef/knife/cookbook_site_show.rb +3 -3
- data/lib/chef/knife/cookbook_site_unshare.rb +1 -1
- data/lib/chef/knife/cookbook_test.rb +1 -0
- data/lib/chef/knife/cookbook_upload.rb +13 -8
- data/lib/chef/knife/core/bootstrap_context.rb +14 -3
- data/lib/chef/knife/core/generic_presenter.rb +5 -2
- data/lib/chef/knife/core/object_loader.rb +1 -1
- data/lib/chef/knife/core/subcommand_loader.rb +24 -0
- data/lib/chef/knife/core/ui.rb +9 -1
- data/lib/chef/knife/node_run_list_remove.rb +11 -3
- data/lib/chef/knife/raw.rb +14 -3
- data/lib/chef/knife/role_env_run_list_add.rb +86 -0
- data/lib/chef/knife/role_env_run_list_clear.rb +55 -0
- data/lib/chef/knife/role_env_run_list_remove.rb +57 -0
- data/lib/chef/knife/role_env_run_list_replace.rb +59 -0
- data/lib/chef/knife/role_env_run_list_set.rb +70 -0
- data/lib/chef/knife/role_run_list_add.rb +86 -0
- data/lib/chef/knife/role_run_list_clear.rb +55 -0
- data/lib/chef/knife/role_run_list_remove.rb +57 -0
- data/lib/chef/knife/role_run_list_replace.rb +59 -0
- data/lib/chef/knife/role_run_list_set.rb +70 -0
- data/lib/chef/knife/search.rb +4 -4
- data/lib/chef/knife/serve.rb +3 -0
- data/lib/chef/knife/ssh.rb +1 -1
- data/lib/chef/knife/ssl_check.rb +2 -2
- data/lib/chef/knife/ssl_fetch.rb +14 -1
- data/lib/chef/log.rb +10 -1
- data/lib/chef/mixin/command.rb +1 -1
- data/lib/chef/mixin/command/windows.rb +1 -5
- data/lib/chef/mixin/get_source_from_package.rb +1 -0
- data/lib/chef/mixin/params_validate.rb +2 -2
- data/lib/chef/mixin/securable.rb +1 -7
- data/lib/chef/mixin/shell_out.rb +7 -1
- data/lib/chef/mixin/template.rb +2 -14
- data/lib/chef/mixin/why_run.rb +1 -1
- data/lib/chef/monkey_patches/net_http.rb +4 -0
- data/lib/chef/monologger.rb +0 -2
- data/lib/chef/node.rb +5 -2
- data/lib/chef/node/attribute.rb +11 -9
- data/lib/chef/node/attribute_collections.rb +8 -12
- data/lib/chef/node/immutable_collections.rb +4 -10
- data/lib/chef/org.rb +148 -0
- data/lib/chef/platform/provider_mapping.rb +3 -2
- data/lib/chef/platform/provider_priority_map.rb +2 -0
- data/lib/chef/platform/query_helpers.rb +0 -3
- data/lib/chef/policy_builder/policyfile.rb +51 -8
- data/lib/chef/provider/deploy.rb +1 -2
- data/lib/chef/provider/directory.rb +3 -3
- data/lib/chef/provider/dsc_script.rb +13 -7
- data/lib/chef/provider/env.rb +8 -8
- data/lib/chef/provider/execute.rb +55 -36
- data/lib/chef/provider/file.rb +8 -0
- data/lib/chef/provider/group.rb +2 -0
- data/lib/chef/provider/group/dscl.rb +3 -4
- data/lib/chef/provider/ifconfig.rb +25 -25
- data/lib/chef/provider/ifconfig/aix.rb +25 -27
- data/lib/chef/provider/lwrp_base.rb +1 -1
- data/lib/chef/provider/mount.rb +2 -2
- data/lib/chef/provider/mount/mount.rb +3 -4
- data/lib/chef/provider/mount/solaris.rb +1 -1
- data/lib/chef/provider/package.rb +297 -48
- data/lib/chef/provider/package/aix.rb +25 -30
- data/lib/chef/provider/package/apt.rb +63 -19
- data/lib/chef/provider/package/dpkg.rb +15 -16
- data/lib/chef/provider/package/macports.rb +7 -7
- data/lib/chef/provider/package/openbsd.rb +107 -0
- data/lib/chef/provider/package/pacman.rb +13 -15
- data/lib/chef/provider/package/portage.rb +3 -4
- data/lib/chef/provider/package/rpm.rb +28 -17
- data/lib/chef/provider/package/rubygems.rb +9 -9
- data/lib/chef/provider/package/solaris.rb +17 -21
- data/lib/chef/provider/package/windows/msi.rb +1 -1
- data/lib/chef/provider/package/yum-dump.py +2 -2
- data/lib/chef/provider/package/yum.rb +117 -51
- data/lib/chef/provider/package/zypper.rb +17 -18
- data/lib/chef/provider/powershell_script.rb +4 -4
- data/lib/chef/provider/registry_key.rb +2 -2
- data/lib/chef/provider/remote_directory.rb +1 -1
- data/lib/chef/provider/script.rb +25 -16
- data/lib/chef/provider/service.rb +1 -1
- data/lib/chef/provider/service/freebsd.rb +1 -1
- data/lib/chef/provider/service/openbsd.rb +216 -0
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +99 -1
- data/lib/chef/provider/user.rb +1 -1
- data/lib/chef/provider/user/dscl.rb +19 -4
- data/lib/chef/providers.rb +2 -0
- data/lib/chef/recipe.rb +11 -5
- data/lib/chef/request_id.rb +1 -1
- data/lib/chef/resource.rb +839 -444
- data/lib/chef/resource/chef_gem.rb +20 -3
- data/lib/chef/resource/conditional.rb +3 -14
- data/lib/chef/resource/dsc_script.rb +14 -0
- data/lib/chef/resource/execute.rb +14 -7
- data/lib/chef/resource/file.rb +14 -0
- data/lib/chef/resource/file/verification.rb +122 -0
- data/lib/chef/resource/ips_package.rb +1 -1
- data/lib/chef/resource/lwrp_base.rb +2 -11
- data/lib/chef/resource/macports_package.rb +2 -1
- data/lib/chef/resource/openbsd_package.rb +51 -0
- data/lib/chef/resource/package.rb +2 -2
- data/lib/chef/resource/paludis_package.rb +1 -1
- data/lib/chef/resource/reboot.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -0
- data/lib/chef/resource/rpm_package.rb +9 -0
- data/lib/chef/resource/script.rb +11 -0
- data/lib/chef/resource/template.rb +2 -3
- data/lib/chef/resource/windows_package.rb +1 -1
- data/lib/chef/resource/windows_service.rb +18 -0
- data/lib/chef/resource_builder.rb +137 -0
- data/lib/chef/resource_definition.rb +1 -1
- data/lib/chef/resource_reporter.rb +1 -1
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/role.rb +17 -4
- data/lib/chef/run_context.rb +10 -6
- data/lib/chef/search/query.rb +66 -87
- data/lib/chef/shell/ext.rb +2 -2
- data/lib/chef/util/diff.rb +1 -4
- data/lib/chef/util/dsc/configuration_generator.rb +30 -6
- data/lib/chef/util/dsc/lcm_output_parser.rb +7 -3
- data/lib/chef/util/dsc/local_configuration_manager.rb +8 -8
- data/lib/chef/util/file_edit.rb +2 -2
- data/lib/chef/util/path_helper.rb +1 -4
- data/lib/chef/util/windows/net_use.rb +3 -3
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +1 -0
- data/lib/chef/win32/api/security.rb +26 -0
- data/lib/chef/win32/file.rb +21 -0
- data/lib/chef/win32/security.rb +46 -0
- data/lib/chef/win32/security/token.rb +8 -0
- data/lib/chef/win32/version.rb +0 -4
- data/spec/data/recipes.tgz +0 -0
- data/spec/functional/application_spec.rb +1 -1
- data/spec/functional/audit/rspec_formatter_spec.rb +54 -0
- data/spec/functional/audit/runner_spec.rb +137 -0
- data/spec/functional/dsl/reboot_pending_spec.rb +10 -10
- data/spec/functional/dsl/registry_helper_spec.rb +6 -6
- data/spec/functional/event_loggers/windows_eventlog_spec.rb +5 -5
- data/spec/functional/file_content_management/deploy_strategies_spec.rb +12 -21
- data/spec/functional/http/simple_spec.rb +1 -1
- data/spec/functional/knife/cookbook_delete_spec.rb +24 -24
- data/spec/functional/knife/exec_spec.rb +2 -4
- data/spec/functional/knife/smoke_test.rb +1 -1
- data/spec/functional/knife/ssh_spec.rb +23 -23
- data/spec/functional/provider/remote_file/cache_control_data_spec.rb +8 -8
- data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +2 -2
- data/spec/functional/rebooter_spec.rb +1 -1
- data/spec/functional/resource/aix_service_spec.rb +3 -0
- data/spec/functional/resource/aixinit_service_spec.rb +3 -3
- data/spec/functional/resource/bash_spec.rb +88 -0
- data/spec/functional/resource/deploy_revision_spec.rb +99 -100
- data/spec/functional/resource/env_spec.rb +3 -3
- data/spec/functional/resource/execute_spec.rb +97 -63
- data/spec/functional/resource/file_spec.rb +7 -7
- data/spec/functional/resource/git_spec.rb +13 -13
- data/spec/functional/resource/group_spec.rb +28 -25
- data/spec/functional/resource/ifconfig_spec.rb +2 -2
- data/spec/functional/resource/link_spec.rb +77 -78
- data/spec/functional/resource/mount_spec.rb +5 -5
- data/spec/functional/resource/ohai_spec.rb +1 -1
- data/spec/functional/resource/package_spec.rb +22 -22
- data/spec/functional/resource/powershell_spec.rb +57 -42
- data/spec/functional/resource/reboot_spec.rb +2 -2
- data/spec/functional/resource/registry_spec.rb +91 -91
- data/spec/functional/resource/remote_directory_spec.rb +19 -19
- data/spec/functional/resource/remote_file_spec.rb +18 -18
- data/spec/functional/resource/template_spec.rb +4 -4
- data/spec/functional/resource/user/dscl_spec.rb +4 -4
- data/spec/functional/resource/user/useradd_spec.rb +64 -51
- data/spec/functional/resource/windows_service_spec.rb +98 -0
- data/spec/functional/run_lock_spec.rb +9 -9
- data/spec/functional/shell_spec.rb +3 -3
- data/spec/functional/tiny_server_spec.rb +12 -12
- data/spec/functional/util/path_helper_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/registry_helper_spec.rb +125 -125
- data/spec/functional/win32/security_spec.rb +65 -2
- data/spec/functional/win32/service_manager_spec.rb +30 -84
- data/spec/functional/win32/versions_spec.rb +6 -6
- data/spec/integration/client/client_spec.rb +102 -9
- data/spec/integration/knife/chef_fs_data_store_spec.rb +12 -8
- data/spec/integration/knife/common_options_spec.rb +3 -3
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +2 -2
- data/spec/integration/knife/deps_spec.rb +4 -4
- data/spec/integration/knife/diff_spec.rb +6 -6
- data/spec/integration/knife/download_spec.rb +6 -6
- data/spec/integration/knife/list_spec.rb +2 -2
- data/spec/integration/knife/raw_spec.rb +5 -5
- data/spec/integration/knife/serve_spec.rb +3 -3
- data/spec/integration/knife/show_spec.rb +3 -3
- data/spec/integration/knife/upload_spec.rb +18 -18
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/solo/solo_spec.rb +11 -12
- data/spec/spec_helper.rb +27 -15
- data/spec/stress/win32/file_spec.rb +4 -4
- data/spec/stress/win32/security_spec.rb +4 -4
- data/spec/support/chef_helpers.rb +3 -3
- data/spec/support/matchers/leak.rb +2 -2
- data/spec/support/mock/platform.rb +1 -1
- data/spec/support/pedant/Gemfile +3 -0
- data/spec/support/pedant/pedant_config.rb +9 -2
- data/spec/support/pedant/run_pedant.rb +15 -16
- data/spec/support/platform_helpers.rb +8 -12
- data/spec/support/shared/functional/directory_resource.rb +13 -13
- data/spec/support/shared/functional/file_resource.rb +83 -83
- data/spec/support/shared/functional/http.rb +1 -1
- data/spec/support/shared/functional/securable_resource.rb +64 -64
- data/spec/support/shared/functional/securable_resource_with_reporting.rb +43 -41
- data/spec/support/shared/functional/win32_service.rb +60 -0
- data/spec/support/shared/functional/windows_script.rb +8 -8
- data/spec/support/shared/integration/knife_support.rb +8 -5
- data/spec/support/shared/matchers/exit_with_code.rb +6 -2
- data/spec/support/shared/unit/api_error_inspector.rb +8 -8
- data/spec/support/shared/unit/execute_resource.rb +24 -20
- data/spec/support/shared/unit/file_system_support.rb +2 -2
- data/spec/support/shared/unit/platform_introspector.rb +21 -21
- data/spec/support/shared/unit/provider/file.rb +239 -210
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +69 -69
- data/spec/support/shared/unit/script_resource.rb +40 -32
- data/spec/support/shared/unit/windows_script_resource.rb +8 -8
- data/spec/unit/api_client/registration_spec.rb +47 -47
- data/spec/unit/api_client_spec.rb +107 -69
- data/spec/unit/application/apply_spec.rb +31 -15
- data/spec/unit/application/client_spec.rb +146 -45
- data/spec/unit/application/knife_spec.rb +31 -31
- data/spec/unit/application/solo_spec.rb +59 -43
- data/spec/unit/application_spec.rb +109 -74
- data/spec/unit/audit/audit_event_proxy_spec.rb +311 -0
- data/spec/unit/audit/audit_reporter_spec.rb +393 -0
- data/spec/unit/audit/control_group_data_spec.rb +478 -0
- data/{lib/chef/monkey_patches/file.rb → spec/unit/audit/rspec_formatter_spec.rb} +11 -8
- data/spec/unit/audit/runner_spec.rb +135 -0
- data/spec/unit/chef_fs/config_spec.rb +52 -0
- data/spec/unit/chef_fs/diff_spec.rb +12 -12
- data/spec/unit/chef_fs/file_pattern_spec.rb +276 -277
- data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +6 -6
- data/spec/unit/chef_fs/file_system_spec.rb +26 -13
- data/spec/unit/chef_fs/parallelizer.rb +87 -87
- data/spec/unit/chef_spec.rb +1 -1
- data/spec/unit/client_spec.rb +263 -97
- data/spec/unit/config_fetcher_spec.rb +13 -13
- data/spec/unit/config_spec.rb +105 -66
- data/spec/unit/cookbook/chefignore_spec.rb +6 -6
- data/spec/unit/cookbook/cookbook_version_loader_spec.rb +3 -3
- data/spec/unit/cookbook/metadata_spec.rb +149 -149
- data/spec/unit/cookbook/syntax_check_spec.rb +36 -31
- data/spec/unit/cookbook_loader_spec.rb +62 -58
- data/spec/unit/cookbook_manifest_spec.rb +141 -468
- data/spec/unit/cookbook_site_streaming_uploader_spec.rb +27 -27
- data/spec/unit/cookbook_spec.rb +15 -15
- data/spec/unit/cookbook_uploader_spec.rb +37 -3
- data/spec/unit/cookbook_version_file_specificity_spec.rb +554 -0
- data/spec/unit/cookbook_version_spec.rb +98 -240
- data/spec/unit/daemon_spec.rb +31 -31
- data/spec/unit/data_bag_item_spec.rb +121 -89
- data/spec/unit/data_bag_spec.rb +35 -35
- data/spec/unit/deprecation_spec.rb +27 -14
- data/spec/unit/digester_spec.rb +3 -3
- data/spec/unit/dsl/audit_spec.rb +43 -0
- data/spec/unit/dsl/data_query_spec.rb +1 -1
- data/spec/unit/dsl/platform_introspection_spec.rb +14 -14
- data/spec/unit/dsl/reboot_pending_spec.rb +18 -18
- data/spec/unit/dsl/regsitry_helper_spec.rb +6 -6
- data/spec/unit/encrypted_data_bag_item_spec.rb +58 -82
- data/spec/unit/environment_spec.rb +105 -105
- data/spec/unit/exceptions_spec.rb +47 -1
- data/spec/unit/file_access_control_spec.rb +62 -56
- data/spec/unit/file_cache_spec.rb +11 -11
- data/spec/unit/file_content_management/deploy/cp_spec.rb +2 -2
- data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +10 -10
- data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +23 -23
- data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +14 -14
- data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +12 -12
- data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +16 -16
- data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +4 -4
- data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +103 -13
- data/spec/unit/guard_interpreter_spec.rb +41 -0
- data/spec/unit/handler/json_file_spec.rb +10 -10
- data/spec/unit/handler_spec.rb +39 -39
- data/spec/unit/http/basic_client_spec.rb +3 -3
- data/spec/unit/http/http_request_spec.rb +10 -10
- data/spec/unit/http/simple_spec.rb +3 -3
- data/spec/unit/http/ssl_policies_spec.rb +15 -15
- data/spec/unit/http/validate_content_length_spec.rb +18 -13
- data/spec/unit/http_spec.rb +16 -9
- data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +153 -0
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +178 -0
- data/spec/unit/knife/bootstrap_spec.rb +144 -91
- data/spec/unit/knife/client_bulk_delete_spec.rb +24 -24
- data/spec/unit/knife/client_create_spec.rb +57 -43
- data/spec/unit/knife/client_delete_spec.rb +15 -15
- data/spec/unit/knife/client_edit_spec.rb +4 -4
- data/spec/unit/knife/client_list_spec.rb +2 -2
- data/spec/unit/knife/client_reregister_spec.rb +9 -9
- data/spec/unit/knife/configure_client_spec.rb +20 -20
- data/spec/unit/knife/configure_spec.rb +85 -85
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +15 -15
- data/spec/unit/knife/cookbook_create_spec.rb +59 -59
- data/spec/unit/knife/cookbook_delete_spec.rb +49 -49
- data/spec/unit/knife/cookbook_download_spec.rb +56 -56
- data/spec/unit/knife/cookbook_list_spec.rb +9 -9
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +8 -8
- data/spec/unit/knife/cookbook_metadata_spec.rb +44 -44
- data/spec/unit/knife/cookbook_show_spec.rb +29 -29
- data/spec/unit/knife/cookbook_site_download_spec.rb +26 -26
- data/spec/unit/knife/cookbook_site_install_spec.rb +5 -1
- data/spec/unit/knife/cookbook_site_share_spec.rb +68 -59
- data/spec/unit/knife/cookbook_site_unshare_spec.rb +15 -15
- data/spec/unit/knife/cookbook_test_spec.rb +16 -16
- data/spec/unit/knife/cookbook_upload_spec.rb +105 -71
- data/spec/unit/knife/core/bootstrap_context_spec.rb +37 -22
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +36 -36
- data/spec/unit/knife/core/object_loader_spec.rb +3 -3
- data/spec/unit/knife/core/subcommand_loader_spec.rb +107 -33
- data/spec/unit/knife/core/ui_spec.rb +84 -72
- data/spec/unit/knife/data_bag_from_file_spec.rb +1 -1
- data/spec/unit/knife/environment_compare_spec.rb +12 -12
- data/spec/unit/knife/environment_create_spec.rb +16 -16
- data/spec/unit/knife/environment_delete_spec.rb +14 -14
- data/spec/unit/knife/environment_edit_spec.rb +15 -15
- data/spec/unit/knife/environment_from_file_spec.rb +17 -17
- data/spec/unit/knife/environment_list_spec.rb +7 -7
- data/spec/unit/knife/environment_show_spec.rb +10 -10
- data/spec/unit/knife/index_rebuild_spec.rb +17 -17
- data/spec/unit/knife/knife_help.rb +24 -24
- data/spec/unit/knife/node_bulk_delete_spec.rb +14 -14
- data/spec/unit/knife/node_delete_spec.rb +11 -11
- data/spec/unit/knife/node_edit_spec.rb +17 -17
- data/spec/unit/knife/node_environment_set_spec.rb +12 -12
- data/spec/unit/knife/node_from_file_spec.rb +8 -8
- data/spec/unit/knife/node_list_spec.rb +9 -9
- data/spec/unit/knife/node_run_list_add_spec.rb +29 -29
- data/spec/unit/knife/node_run_list_remove_spec.rb +28 -13
- data/spec/unit/knife/node_run_list_set_spec.rb +27 -27
- data/spec/unit/knife/raw_spec.rb +43 -0
- data/spec/unit/knife/role_bulk_delete_spec.rb +12 -12
- data/spec/unit/knife/role_create_spec.rb +12 -12
- data/spec/unit/knife/role_delete_spec.rb +10 -10
- data/spec/unit/knife/role_edit_spec.rb +13 -13
- data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -0
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +100 -0
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +108 -0
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +108 -0
- data/spec/unit/knife/role_env_run_list_set_spec.rb +102 -0
- data/spec/unit/knife/role_from_file_spec.rb +10 -10
- data/spec/unit/knife/role_list_spec.rb +7 -7
- data/spec/unit/knife/role_run_list_add_spec.rb +179 -0
- data/spec/unit/knife/role_run_list_clear_spec.rb +90 -0
- data/spec/unit/knife/role_run_list_remove_spec.rb +98 -0
- data/spec/unit/knife/role_run_list_replace_spec.rb +101 -0
- data/spec/unit/knife/role_run_list_set_spec.rb +92 -0
- data/spec/unit/knife/ssh_spec.rb +66 -66
- data/spec/unit/knife/ssl_check_spec.rb +27 -27
- data/spec/unit/knife/ssl_fetch_spec.rb +45 -12
- data/spec/unit/knife/status_spec.rb +5 -5
- data/spec/unit/knife/tag_create_spec.rb +5 -5
- data/spec/unit/knife/tag_delete_spec.rb +6 -6
- data/spec/unit/knife/tag_list_spec.rb +4 -4
- data/spec/unit/knife/user_create_spec.rb +18 -18
- data/spec/unit/knife/user_delete_spec.rb +4 -4
- data/spec/unit/knife/user_edit_spec.rb +7 -7
- data/spec/unit/knife/user_list_spec.rb +2 -2
- data/spec/unit/knife/user_reregister_spec.rb +10 -10
- data/spec/unit/knife/user_show_spec.rb +5 -5
- data/spec/unit/knife_spec.rb +36 -36
- data/spec/unit/lwrp_spec.rb +63 -39
- data/spec/unit/mash_spec.rb +6 -6
- data/spec/unit/mixin/checksum_spec.rb +2 -2
- data/spec/unit/mixin/command_spec.rb +13 -13
- data/spec/unit/mixin/convert_to_class_name_spec.rb +6 -6
- data/spec/unit/mixin/deep_merge_spec.rb +49 -49
- data/spec/unit/mixin/deprecation_spec.rb +5 -5
- data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +14 -14
- data/spec/unit/mixin/homebrew_user_spec.rb +3 -3
- data/spec/unit/mixin/params_validate_spec.rb +71 -71
- data/spec/unit/mixin/path_sanity_spec.rb +14 -14
- data/spec/unit/mixin/securable_spec.rb +177 -177
- data/spec/unit/mixin/shell_out_spec.rb +56 -27
- data/spec/unit/mixin/template_spec.rb +31 -31
- data/spec/unit/mixin/windows_architecture_helper_spec.rb +5 -5
- data/spec/unit/mixin/xml_escape_spec.rb +7 -7
- data/spec/unit/monkey_patches/uri_spec.rb +1 -1
- data/spec/unit/monologger_spec.rb +3 -3
- data/spec/unit/node/attribute_spec.rb +185 -136
- data/spec/unit/node/immutable_collections_spec.rb +22 -22
- data/spec/unit/node_spec.rb +210 -179
- data/spec/unit/org_spec.rb +196 -0
- data/spec/unit/platform/query_helpers_spec.rb +5 -5
- data/spec/unit/platform_spec.rb +46 -46
- data/spec/unit/policy_builder/expand_node_object_spec.rb +17 -18
- data/spec/unit/policy_builder/policyfile_spec.rb +159 -71
- data/spec/unit/provider/directory_spec.rb +5 -5
- data/spec/unit/provider/dsc_script_spec.rb +6 -6
- data/spec/unit/provider/env_spec.rb +27 -14
- data/spec/unit/provider/execute_spec.rb +139 -68
- data/spec/unit/provider/file/content_spec.rb +8 -8
- data/spec/unit/provider/git_spec.rb +10 -5
- data/spec/unit/provider/group/dscl_spec.rb +8 -11
- data/spec/unit/provider/group_spec.rb +13 -13
- data/spec/unit/provider/ifconfig/aix_spec.rb +3 -2
- data/spec/unit/provider/ifconfig/debian_spec.rb +19 -19
- data/spec/unit/provider/ifconfig_spec.rb +2 -2
- data/spec/unit/provider/mdadm_spec.rb +2 -2
- data/spec/unit/provider/mount/aix_spec.rb +5 -5
- data/spec/unit/provider/mount/mount_spec.rb +22 -22
- data/spec/unit/provider/mount/solaris_spec.rb +20 -20
- data/spec/unit/provider/package/aix_spec.rb +23 -22
- data/spec/unit/provider/package/apt_spec.rb +23 -4
- data/spec/unit/provider/package/dpkg_spec.rb +14 -15
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +1 -1
- data/spec/unit/provider/package/freebsd/port_spec.rb +1 -1
- data/spec/unit/provider/package/ips_spec.rb +1 -2
- data/spec/unit/provider/package/macports_spec.rb +14 -14
- data/spec/unit/provider/package/openbsd_spec.rb +66 -0
- data/spec/unit/provider/package/pacman_spec.rb +15 -14
- data/spec/unit/provider/package/portage_spec.rb +11 -11
- data/spec/unit/provider/package/rpm_spec.rb +132 -84
- data/spec/unit/provider/package/rubygems_spec.rb +54 -25
- data/spec/unit/provider/package/solaris_spec.rb +22 -25
- data/spec/unit/provider/package/yum_spec.rb +237 -36
- data/spec/unit/provider/package/zypper_spec.rb +9 -12
- data/spec/unit/provider/package_spec.rb +276 -2
- data/spec/unit/provider/package_spec.rbe +0 -0
- data/spec/unit/provider/remote_directory_spec.rb +25 -25
- data/spec/unit/provider/remote_file/ftp_spec.rb +3 -3
- data/spec/unit/provider/route_spec.rb +3 -3
- data/spec/unit/provider/script_spec.rb +61 -43
- data/spec/unit/provider/service/aix_service_spec.rb +5 -5
- data/spec/unit/provider/service/arch_service_spec.rb +5 -5
- data/spec/unit/provider/service/debian_service_spec.rb +8 -8
- data/spec/unit/provider/service/freebsd_service_spec.rb +16 -2
- data/spec/unit/provider/service/gentoo_service_spec.rb +8 -8
- data/spec/unit/provider/service/init_service_spec.rb +5 -5
- data/spec/unit/provider/service/insserv_service_spec.rb +2 -2
- data/spec/unit/provider/service/invokercd_service_spec.rb +5 -5
- data/spec/unit/provider/service/macosx_spec.rb +7 -7
- data/spec/unit/provider/service/openbsd_service_spec.rb +543 -0
- data/spec/unit/provider/service/redhat_spec.rb +4 -4
- data/spec/unit/provider/service/simple_service_spec.rb +2 -2
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +14 -14
- data/spec/unit/provider/service/systemd_service_spec.rb +15 -7
- data/spec/unit/provider/service/upstart_service_spec.rb +4 -4
- data/spec/unit/provider/service/windows_spec.rb +119 -25
- data/spec/unit/provider/service_spec.rb +1 -1
- data/spec/unit/provider/user/dscl_spec.rb +38 -30
- data/spec/unit/provider/user_spec.rb +1 -1
- data/spec/unit/provider_resolver_spec.rb +7 -7
- data/spec/unit/provider_spec.rb +23 -23
- data/spec/unit/recipe_spec.rb +194 -83
- data/spec/unit/registry_helper_spec.rb +143 -143
- data/spec/unit/resource/chef_gem_spec.rb +117 -3
- data/spec/unit/resource/conditional_action_not_nothing_spec.rb +2 -2
- data/spec/unit/resource/conditional_spec.rb +56 -15
- data/spec/unit/resource/deploy_spec.rb +2 -2
- data/spec/unit/resource/dsc_script_spec.rb +32 -0
- data/spec/unit/resource/execute_spec.rb +4 -0
- data/spec/unit/resource/file/verification_spec.rb +111 -0
- data/spec/unit/resource/file_spec.rb +14 -0
- data/spec/unit/resource/openbsd_package_spec.rb +49 -0
- data/spec/unit/resource/remote_file_spec.rb +12 -12
- data/spec/unit/resource/resource_notification_spec.rb +18 -18
- data/spec/unit/resource/rpm_package_spec.rb +12 -0
- data/spec/unit/resource/scm_spec.rb +4 -4
- data/spec/unit/resource/script_spec.rb +3 -5
- data/spec/unit/resource/subversion_spec.rb +1 -1
- data/spec/unit/resource_builder_spec.rb +1 -0
- data/spec/unit/resource_collection/resource_list_spec.rb +2 -2
- data/spec/unit/resource_collection/resource_set_spec.rb +3 -3
- data/spec/unit/resource_collection/stepable_iterator_spec.rb +24 -24
- data/spec/unit/resource_collection_spec.rb +52 -52
- data/spec/unit/resource_definition_spec.rb +1 -1
- data/spec/unit/resource_reporter_spec.rb +118 -118
- data/spec/unit/resource_spec.rb +131 -125
- data/spec/unit/rest/auth_credentials_spec.rb +73 -73
- data/spec/unit/rest_spec.rb +12 -12
- data/spec/unit/role_spec.rb +85 -84
- data/spec/unit/run_context/cookbook_compiler_spec.rb +18 -18
- data/spec/unit/run_context_spec.rb +39 -68
- data/spec/unit/run_list/run_list_expansion_spec.rb +21 -21
- data/spec/unit/run_list/run_list_item_spec.rb +28 -28
- data/spec/unit/run_list/versioned_recipe_list_spec.rb +14 -14
- data/spec/unit/run_list_spec.rb +55 -55
- data/spec/unit/run_lock_spec.rb +14 -14
- data/spec/unit/run_status_spec.rb +24 -24
- data/spec/unit/scan_access_control_spec.rb +23 -23
- data/spec/unit/search/query_spec.rb +54 -66
- data/spec/unit/shell/model_wrapper_spec.rb +13 -13
- data/spec/unit/shell/shell_ext_spec.rb +32 -32
- data/spec/unit/shell/shell_session_spec.rb +24 -24
- data/spec/unit/shell_out_spec.rb +4 -4
- data/spec/unit/shell_spec.rb +27 -27
- data/spec/unit/user_spec.rb +50 -50
- data/spec/unit/util/backup_spec.rb +32 -32
- data/spec/unit/util/diff_spec.rb +31 -31
- data/spec/unit/util/dsc/configuration_generator_spec.rb +38 -16
- data/spec/unit/util/dsc/lcm_output_parser_spec.rb +21 -26
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +10 -10
- data/spec/unit/util/editor_spec.rb +10 -10
- data/spec/unit/util/file_edit_spec.rb +10 -10
- data/spec/unit/util/path_helper_spec.rb +38 -46
- data/spec/unit/util/powershell/cmdlet_spec.rb +9 -9
- data/spec/unit/util/selinux_spec.rb +30 -30
- data/spec/unit/util/threaded_job_queue_spec.rb +6 -6
- data/spec/unit/version/platform_spec.rb +5 -5
- data/spec/unit/version_class_spec.rb +15 -15
- data/spec/unit/version_constraint/platform_spec.rb +7 -7
- data/spec/unit/version_constraint_spec.rb +43 -43
- data/spec/unit/windows_service_spec.rb +15 -15
- data/spec/unit/workstation_config_loader_spec.rb +2 -2
- data/tasks/rspec.rb +16 -18
- metadata +126 -49
- data/bin/shef +0 -35
- data/lib/chef/application/agent.rb +0 -18
- data/lib/chef/monkey_patches/fileutils.rb +0 -65
- data/lib/chef/monkey_patches/numeric.rb +0 -15
- data/lib/chef/monkey_patches/object.rb +0 -9
- data/lib/chef/monkey_patches/pathname.rb +0 -32
- data/lib/chef/monkey_patches/regexp.rb +0 -34
- data/lib/chef/monkey_patches/securerandom.rb +0 -44
- data/lib/chef/monkey_patches/string.rb +0 -49
- data/lib/chef/monkey_patches/tempfile.rb +0 -64
- data/lib/chef/monkey_patches/uri.rb +0 -70
data/spec/unit/resource_spec.rb
CHANGED
@@ -39,33 +39,33 @@ describe Chef::Resource do
|
|
39
39
|
|
40
40
|
it "adds an entry to a list of subclasses" do
|
41
41
|
subclass = Class.new(Chef::Resource)
|
42
|
-
Chef::Resource.resource_classes.
|
42
|
+
expect(Chef::Resource.resource_classes).to include(subclass)
|
43
43
|
end
|
44
44
|
|
45
45
|
it "keeps track of subclasses of subclasses" do
|
46
46
|
subclass = Class.new(Chef::Resource)
|
47
47
|
subclass_of_subclass = Class.new(subclass)
|
48
|
-
Chef::Resource.resource_classes.
|
48
|
+
expect(Chef::Resource.resource_classes).to include(subclass_of_subclass)
|
49
49
|
end
|
50
50
|
|
51
51
|
end
|
52
52
|
|
53
53
|
describe "when declaring the identity attribute" do
|
54
54
|
it "has no identity attribute by default" do
|
55
|
-
Chef::Resource.identity_attr.
|
55
|
+
expect(Chef::Resource.identity_attr).to be_nil
|
56
56
|
end
|
57
57
|
|
58
58
|
it "sets an identity attribute" do
|
59
59
|
resource_class = Class.new(Chef::Resource)
|
60
60
|
resource_class.identity_attr(:path)
|
61
|
-
resource_class.identity_attr.
|
61
|
+
expect(resource_class.identity_attr).to eq(:path)
|
62
62
|
end
|
63
63
|
|
64
64
|
it "inherits an identity attribute from a superclass" do
|
65
65
|
resource_class = Class.new(Chef::Resource)
|
66
66
|
resource_subclass = Class.new(resource_class)
|
67
67
|
resource_class.identity_attr(:package_name)
|
68
|
-
resource_subclass.identity_attr.
|
68
|
+
expect(resource_subclass.identity_attr).to eq(:package_name)
|
69
69
|
end
|
70
70
|
|
71
71
|
it "overrides the identity attribute from a superclass when the identity attr is set" do
|
@@ -73,7 +73,7 @@ describe Chef::Resource do
|
|
73
73
|
resource_subclass = Class.new(resource_class)
|
74
74
|
resource_class.identity_attr(:package_name)
|
75
75
|
resource_subclass.identity_attr(:something_else)
|
76
|
-
resource_subclass.identity_attr.
|
76
|
+
expect(resource_subclass.identity_attr).to eq(:something_else)
|
77
77
|
end
|
78
78
|
end
|
79
79
|
|
@@ -85,7 +85,7 @@ describe Chef::Resource do
|
|
85
85
|
# Would rather force identity attributes to be set for everything,
|
86
86
|
# but that's not plausible for back compat reasons.
|
87
87
|
it "uses the name as the identity" do
|
88
|
-
@resource_sans_id.identity.
|
88
|
+
expect(@resource_sans_id.identity).to eq("my-name")
|
89
89
|
end
|
90
90
|
end
|
91
91
|
|
@@ -101,26 +101,26 @@ describe Chef::Resource do
|
|
101
101
|
end
|
102
102
|
|
103
103
|
it "gives the value of its identity attribute" do
|
104
|
-
@file_resource.identity.
|
104
|
+
expect(@file_resource.identity).to eq("/tmp/foo.txt")
|
105
105
|
end
|
106
106
|
end
|
107
107
|
|
108
108
|
describe "when declaring state attributes" do
|
109
109
|
it "has no state_attrs by default" do
|
110
|
-
Chef::Resource.state_attrs.
|
110
|
+
expect(Chef::Resource.state_attrs).to be_empty
|
111
111
|
end
|
112
112
|
|
113
113
|
it "sets a list of state attributes" do
|
114
114
|
resource_class = Class.new(Chef::Resource)
|
115
115
|
resource_class.state_attrs(:checksum, :owner, :group, :mode)
|
116
|
-
resource_class.state_attrs.
|
116
|
+
expect(resource_class.state_attrs).to match_array([:checksum, :owner, :group, :mode])
|
117
117
|
end
|
118
118
|
|
119
119
|
it "inherits state attributes from the superclass" do
|
120
120
|
resource_class = Class.new(Chef::Resource)
|
121
121
|
resource_subclass = Class.new(resource_class)
|
122
122
|
resource_class.state_attrs(:checksum, :owner, :group, :mode)
|
123
|
-
resource_subclass.state_attrs.
|
123
|
+
expect(resource_subclass.state_attrs).to match_array([:checksum, :owner, :group, :mode])
|
124
124
|
end
|
125
125
|
|
126
126
|
it "combines inherited state attributes with non-inherited state attributes" do
|
@@ -128,7 +128,7 @@ describe Chef::Resource do
|
|
128
128
|
resource_subclass = Class.new(resource_class)
|
129
129
|
resource_class.state_attrs(:checksum, :owner)
|
130
130
|
resource_subclass.state_attrs(:group, :mode)
|
131
|
-
resource_subclass.state_attrs.
|
131
|
+
expect(resource_subclass.state_attrs).to match_array([:checksum, :owner, :group, :mode])
|
132
132
|
end
|
133
133
|
|
134
134
|
end
|
@@ -154,15 +154,15 @@ describe Chef::Resource do
|
|
154
154
|
|
155
155
|
it "describes its state" do
|
156
156
|
resource_state = @file_resource.state
|
157
|
-
resource_state.keys.
|
158
|
-
resource_state[:checksum].
|
159
|
-
resource_state[:owner].
|
160
|
-
resource_state[:group].
|
161
|
-
resource_state[:mode].
|
157
|
+
expect(resource_state.keys).to match_array([:checksum, :owner, :group, :mode])
|
158
|
+
expect(resource_state[:checksum]).to eq("abc123")
|
159
|
+
expect(resource_state[:owner]).to eq("root")
|
160
|
+
expect(resource_state[:group]).to eq("wheel")
|
161
|
+
expect(resource_state[:mode]).to eq("0644")
|
162
162
|
end
|
163
163
|
end
|
164
164
|
|
165
|
-
describe "
|
165
|
+
describe "load_from" do
|
166
166
|
before(:each) do
|
167
167
|
@prior_resource = Chef::Resource.new("funk")
|
168
168
|
@prior_resource.supports(:funky => true)
|
@@ -174,40 +174,40 @@ describe Chef::Resource do
|
|
174
174
|
end
|
175
175
|
|
176
176
|
it "should load the attributes of a prior resource" do
|
177
|
-
@resource.
|
178
|
-
@resource.supports.
|
177
|
+
@resource.load_from(@prior_resource)
|
178
|
+
expect(@resource.supports).to eq({ :funky => true })
|
179
179
|
end
|
180
180
|
|
181
181
|
it "should not inherit the action from the prior resource" do
|
182
|
-
@resource.
|
183
|
-
@resource.action.
|
182
|
+
@resource.load_from(@prior_resource)
|
183
|
+
expect(@resource.action).not_to eq(@prior_resource.action)
|
184
184
|
end
|
185
185
|
end
|
186
186
|
|
187
187
|
describe "name" do
|
188
188
|
it "should have a name" do
|
189
|
-
@resource.name.
|
189
|
+
expect(@resource.name).to eql("funk")
|
190
190
|
end
|
191
191
|
|
192
192
|
it "should let you set a new name" do
|
193
193
|
@resource.name "monkey"
|
194
|
-
@resource.name.
|
194
|
+
expect(@resource.name).to eql("monkey")
|
195
195
|
end
|
196
196
|
|
197
|
-
it "
|
198
|
-
|
197
|
+
it "coerces arrays to names" do
|
198
|
+
expect(@resource.name ['a', 'b']).to eql('a, b')
|
199
199
|
end
|
200
200
|
|
201
|
-
it "should
|
202
|
-
|
201
|
+
it "should coerce objects to a string" do
|
202
|
+
expect(@resource.name Object.new).to be_a(String)
|
203
203
|
end
|
204
204
|
end
|
205
205
|
|
206
206
|
describe "noop" do
|
207
207
|
it "should accept true or false for noop" do
|
208
|
-
|
209
|
-
|
210
|
-
|
208
|
+
expect { @resource.noop true }.not_to raise_error
|
209
|
+
expect { @resource.noop false }.not_to raise_error
|
210
|
+
expect { @resource.noop "eat it" }.to raise_error(ArgumentError)
|
211
211
|
end
|
212
212
|
end
|
213
213
|
|
@@ -215,48 +215,54 @@ describe Chef::Resource do
|
|
215
215
|
it "should make notified resources appear in the actions hash" do
|
216
216
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
217
217
|
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "coffee")
|
218
|
-
@resource.delayed_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}.
|
218
|
+
expect(@resource.delayed_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}).not_to be_nil
|
219
219
|
end
|
220
220
|
|
221
221
|
it "should make notified resources be capable of acting immediately" do
|
222
222
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
223
223
|
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "coffee"), :immediate
|
224
|
-
@resource.immediate_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}.
|
224
|
+
expect(@resource.immediate_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}).not_to be_nil
|
225
225
|
end
|
226
226
|
|
227
227
|
it "should raise an exception if told to act in other than :delay or :immediate(ly)" do
|
228
228
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
229
|
-
|
229
|
+
expect {
|
230
230
|
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "coffee"), :someday
|
231
|
-
}.
|
231
|
+
}.to raise_error(ArgumentError)
|
232
232
|
end
|
233
233
|
|
234
234
|
it "should allow multiple notified resources appear in the actions hash" do
|
235
235
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
236
236
|
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "coffee")
|
237
|
-
@resource.delayed_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}.
|
237
|
+
expect(@resource.delayed_notifications.detect{|e| e.resource.name == "coffee" && e.action == :reload}).not_to be_nil
|
238
238
|
|
239
239
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("beans")
|
240
240
|
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "beans")
|
241
|
-
@resource.delayed_notifications.detect{|e| e.resource.name == "beans" && e.action == :reload}.
|
241
|
+
expect(@resource.delayed_notifications.detect{|e| e.resource.name == "beans" && e.action == :reload}).not_to be_nil
|
242
242
|
end
|
243
243
|
|
244
244
|
it "creates a notification for a resource that is not yet in the resource collection" do
|
245
245
|
@resource.notifies(:restart, :service => 'apache')
|
246
246
|
expected_notification = Chef::Resource::Notification.new({:service => "apache"}, :restart, @resource)
|
247
|
-
@resource.delayed_notifications.
|
247
|
+
expect(@resource.delayed_notifications).to include(expected_notification)
|
248
248
|
end
|
249
249
|
|
250
250
|
it "notifies another resource immediately" do
|
251
251
|
@resource.notifies_immediately(:restart, :service => 'apache')
|
252
252
|
expected_notification = Chef::Resource::Notification.new({:service => "apache"}, :restart, @resource)
|
253
|
-
@resource.immediate_notifications.
|
253
|
+
expect(@resource.immediate_notifications).to include(expected_notification)
|
254
254
|
end
|
255
255
|
|
256
256
|
it "notifies a resource to take action at the end of the chef run" do
|
257
257
|
@resource.notifies_delayed(:restart, :service => "apache")
|
258
258
|
expected_notification = Chef::Resource::Notification.new({:service => "apache"}, :restart, @resource)
|
259
|
-
@resource.delayed_notifications.
|
259
|
+
expect(@resource.delayed_notifications).to include(expected_notification)
|
260
|
+
end
|
261
|
+
|
262
|
+
it "notifies a resource with an array for its name via its prettified string name" do
|
263
|
+
@run_context.resource_collection << Chef::Resource::ZenMaster.new(["coffee", "tea"])
|
264
|
+
@resource.notifies :reload, @run_context.resource_collection.find(:zen_master => "coffee, tea")
|
265
|
+
expect(@resource.delayed_notifications.detect{|e| e.resource.name == "coffee, tea" && e.action == :reload}).not_to be_nil
|
260
266
|
end
|
261
267
|
end
|
262
268
|
|
@@ -265,76 +271,76 @@ describe Chef::Resource do
|
|
265
271
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
266
272
|
zr = @run_context.resource_collection.find(:zen_master => "coffee")
|
267
273
|
@resource.subscribes :reload, zr
|
268
|
-
zr.delayed_notifications.detect{|e| e.resource.name == "funk" && e.action == :reload}.
|
274
|
+
expect(zr.delayed_notifications.detect{|e| e.resource.name == "funk" && e.action == :reload}).not_to be_nil
|
269
275
|
end
|
270
276
|
|
271
277
|
it "should make resources appear in the actions hash of subscribed nodes" do
|
272
278
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
273
279
|
zr = @run_context.resource_collection.find(:zen_master => "coffee")
|
274
280
|
@resource.subscribes :reload, zr
|
275
|
-
zr.delayed_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}.
|
281
|
+
expect(zr.delayed_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}).not_to be_nil
|
276
282
|
|
277
283
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("bean")
|
278
284
|
zrb = @run_context.resource_collection.find(:zen_master => "bean")
|
279
285
|
zrb.subscribes :reload, zr
|
280
|
-
zr.delayed_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}.
|
286
|
+
expect(zr.delayed_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}).not_to be_nil
|
281
287
|
end
|
282
288
|
|
283
289
|
it "should make subscribed resources be capable of acting immediately" do
|
284
290
|
@run_context.resource_collection << Chef::Resource::ZenMaster.new("coffee")
|
285
291
|
zr = @run_context.resource_collection.find(:zen_master => "coffee")
|
286
292
|
@resource.subscribes :reload, zr, :immediately
|
287
|
-
zr.immediate_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}.
|
293
|
+
expect(zr.immediate_notifications.detect{|e| e.resource.name == @resource.name && e.action == :reload}).not_to be_nil
|
288
294
|
end
|
289
295
|
end
|
290
296
|
|
291
297
|
describe "defined_at" do
|
292
298
|
it "should correctly parse source_line on unix-like operating systems" do
|
293
299
|
@resource.source_line = "/some/path/to/file.rb:80:in `wombat_tears'"
|
294
|
-
@resource.defined_at.
|
300
|
+
expect(@resource.defined_at).to eq("/some/path/to/file.rb line 80")
|
295
301
|
end
|
296
302
|
|
297
303
|
it "should correctly parse source_line on Windows" do
|
298
304
|
@resource.source_line = "C:/some/path/to/file.rb:80 in 1`wombat_tears'"
|
299
|
-
@resource.defined_at.
|
305
|
+
expect(@resource.defined_at).to eq("C:/some/path/to/file.rb line 80")
|
300
306
|
end
|
301
307
|
|
302
308
|
it "should include the cookbook and recipe when it knows it" do
|
303
309
|
@resource.source_line = "/some/path/to/file.rb:80:in `wombat_tears'"
|
304
310
|
@resource.recipe_name = "wombats"
|
305
311
|
@resource.cookbook_name = "animals"
|
306
|
-
@resource.defined_at.
|
312
|
+
expect(@resource.defined_at).to eq("animals::wombats line 80")
|
307
313
|
end
|
308
314
|
|
309
315
|
it "should recognize dynamically defined resources" do
|
310
|
-
@resource.defined_at.
|
316
|
+
expect(@resource.defined_at).to eq("dynamically defined")
|
311
317
|
end
|
312
318
|
end
|
313
319
|
|
314
320
|
describe "to_s" do
|
315
321
|
it "should become a string like resource_name[name]" do
|
316
322
|
zm = Chef::Resource::ZenMaster.new("coffee")
|
317
|
-
zm.to_s.
|
323
|
+
expect(zm.to_s).to eql("zen_master[coffee]")
|
318
324
|
end
|
319
325
|
end
|
320
326
|
|
321
327
|
describe "is" do
|
322
328
|
it "should return the arguments passed with 'is'" do
|
323
329
|
zm = Chef::Resource::ZenMaster.new("coffee")
|
324
|
-
zm.is("one", "two", "three").
|
330
|
+
expect(zm.is("one", "two", "three")).to eq(%w|one two three|)
|
325
331
|
end
|
326
332
|
|
327
|
-
it "should allow arguments
|
333
|
+
it "should allow arguments preceded by is to methods" do
|
328
334
|
@resource.noop(@resource.is(true))
|
329
|
-
@resource.noop.
|
335
|
+
expect(@resource.noop).to eql(true)
|
330
336
|
end
|
331
337
|
end
|
332
338
|
|
333
339
|
describe "to_json" do
|
334
340
|
it "should serialize to json" do
|
335
341
|
json = @resource.to_json
|
336
|
-
json.
|
337
|
-
json.
|
342
|
+
expect(json).to match(/json_class/)
|
343
|
+
expect(json).to match(/instance_vars/)
|
338
344
|
end
|
339
345
|
|
340
346
|
include_examples "to_json equalivent to Chef::JSONCompat.to_json" do
|
@@ -350,9 +356,9 @@ describe Chef::Resource do
|
|
350
356
|
:noop, :ignore_failure, :name, :source_line,
|
351
357
|
:action, :retries, :retry_delay, :elapsed_time,
|
352
358
|
:default_guard_interpreter, :guard_interpreter, :sensitive ]
|
353
|
-
(hash.keys - expected_keys).
|
354
|
-
(expected_keys - hash.keys).
|
355
|
-
hash[:name].
|
359
|
+
expect(hash.keys - expected_keys).to eq([])
|
360
|
+
expect(expected_keys - hash.keys).to eq([])
|
361
|
+
expect(hash[:name]).to eql("funk")
|
356
362
|
end
|
357
363
|
end
|
358
364
|
|
@@ -360,8 +366,8 @@ describe Chef::Resource do
|
|
360
366
|
it "should deserialize itself from json" do
|
361
367
|
json = Chef::JSONCompat.to_json(@resource)
|
362
368
|
serialized_node = Chef::JSONCompat.from_json(json)
|
363
|
-
serialized_node.
|
364
|
-
serialized_node.name.
|
369
|
+
expect(serialized_node).to be_a_kind_of(Chef::Resource)
|
370
|
+
expect(serialized_node.name).to eql(@resource.name)
|
365
371
|
end
|
366
372
|
end
|
367
373
|
|
@@ -369,27 +375,27 @@ describe Chef::Resource do
|
|
369
375
|
it "should allow you to set what features this resource supports" do
|
370
376
|
support_hash = { :one => :two }
|
371
377
|
@resource.supports(support_hash)
|
372
|
-
@resource.supports.
|
378
|
+
expect(@resource.supports).to eql(support_hash)
|
373
379
|
end
|
374
380
|
|
375
381
|
it "should return the current value of supports" do
|
376
|
-
@resource.supports.
|
382
|
+
expect(@resource.supports).to eq({})
|
377
383
|
end
|
378
384
|
end
|
379
385
|
|
380
386
|
describe "ignore_failure" do
|
381
387
|
it "should default to throwing an error if a provider fails for a resource" do
|
382
|
-
@resource.ignore_failure.
|
388
|
+
expect(@resource.ignore_failure).to eq(false)
|
383
389
|
end
|
384
390
|
|
385
391
|
it "should allow you to set whether a provider should throw exceptions with ignore_failure" do
|
386
392
|
@resource.ignore_failure(true)
|
387
|
-
@resource.ignore_failure.
|
393
|
+
expect(@resource.ignore_failure).to eq(true)
|
388
394
|
end
|
389
395
|
|
390
396
|
it "should allow you to epic_fail" do
|
391
397
|
@resource.epic_fail(true)
|
392
|
-
@resource.epic_fail.
|
398
|
+
expect(@resource.epic_fail).to eq(true)
|
393
399
|
end
|
394
400
|
end
|
395
401
|
|
@@ -404,21 +410,21 @@ describe Chef::Resource do
|
|
404
410
|
end
|
405
411
|
|
406
412
|
it "should default to not retrying if a provider fails for a resource" do
|
407
|
-
@retriable_resource.retries.
|
413
|
+
expect(@retriable_resource.retries).to eq(0)
|
408
414
|
end
|
409
415
|
|
410
416
|
it "should allow you to set how many retries a provider should attempt after a failure" do
|
411
417
|
@retriable_resource.retries(2)
|
412
|
-
@retriable_resource.retries.
|
418
|
+
expect(@retriable_resource.retries).to eq(2)
|
413
419
|
end
|
414
420
|
|
415
421
|
it "should default to a retry delay of 2 seconds" do
|
416
|
-
@retriable_resource.retry_delay.
|
422
|
+
expect(@retriable_resource.retry_delay).to eq(2)
|
417
423
|
end
|
418
424
|
|
419
425
|
it "should allow you to set the retry delay" do
|
420
426
|
@retriable_resource.retry_delay(10)
|
421
|
-
@retriable_resource.retry_delay.
|
427
|
+
expect(@retriable_resource.retry_delay).to eq(10)
|
422
428
|
end
|
423
429
|
|
424
430
|
it "should keep given value of retries intact after the provider fails for a resource" do
|
@@ -426,29 +432,29 @@ describe Chef::Resource do
|
|
426
432
|
@retriable_resource.retry_delay(0) # No need to wait.
|
427
433
|
|
428
434
|
provider = Chef::Provider::SnakeOil.new(@retriable_resource, @run_context)
|
429
|
-
Chef::Provider::SnakeOil.
|
430
|
-
provider.
|
435
|
+
allow(Chef::Provider::SnakeOil).to receive(:new).and_return(provider)
|
436
|
+
allow(provider).to receive(:action_purr).and_raise
|
431
437
|
|
432
|
-
@retriable_resource.
|
438
|
+
expect(@retriable_resource).to receive(:sleep).exactly(3).times
|
433
439
|
expect { @retriable_resource.run_action(:purr) }.to raise_error
|
434
|
-
@retriable_resource.retries.
|
440
|
+
expect(@retriable_resource.retries).to eq(3)
|
435
441
|
end
|
436
442
|
end
|
437
443
|
|
438
444
|
describe "setting the base provider class for the resource" do
|
439
445
|
|
440
446
|
it "defaults to Chef::Provider for the base class" do
|
441
|
-
Chef::Resource.provider_base.
|
447
|
+
expect(Chef::Resource.provider_base).to eq(Chef::Provider)
|
442
448
|
end
|
443
449
|
|
444
450
|
it "allows the base provider to be overriden by a " do
|
445
|
-
ResourceTestHarness.provider_base.
|
451
|
+
expect(ResourceTestHarness.provider_base).to eq(Chef::Provider::Package)
|
446
452
|
end
|
447
453
|
|
448
454
|
end
|
449
455
|
|
450
456
|
it "runs an action by finding its provider, loading the current resource and then running the action" do
|
451
|
-
|
457
|
+
skip
|
452
458
|
end
|
453
459
|
|
454
460
|
describe "when updated by a provider" do
|
@@ -457,11 +463,11 @@ describe Chef::Resource do
|
|
457
463
|
end
|
458
464
|
|
459
465
|
it "records that it was updated" do
|
460
|
-
@resource.
|
466
|
+
expect(@resource).to be_updated
|
461
467
|
end
|
462
468
|
|
463
469
|
it "records that the last action updated the resource" do
|
464
|
-
@resource.
|
470
|
+
expect(@resource).to be_updated_by_last_action
|
465
471
|
end
|
466
472
|
|
467
473
|
describe "and then run again without being updated" do
|
@@ -470,11 +476,11 @@ describe Chef::Resource do
|
|
470
476
|
end
|
471
477
|
|
472
478
|
it "reports that it is updated" do
|
473
|
-
@resource.
|
479
|
+
expect(@resource).to be_updated
|
474
480
|
end
|
475
481
|
|
476
482
|
it "reports that it was not updated by the last action" do
|
477
|
-
@resource.
|
483
|
+
expect(@resource).not_to be_updated_by_last_action
|
478
484
|
end
|
479
485
|
|
480
486
|
end
|
@@ -498,10 +504,10 @@ describe Chef::Resource do
|
|
498
504
|
it "runs runs an only_if when one is given" do
|
499
505
|
snitch_variable = nil
|
500
506
|
@resource.only_if { snitch_variable = true }
|
501
|
-
@resource.only_if.first.positivity.
|
507
|
+
expect(@resource.only_if.first.positivity).to eq(:only_if)
|
502
508
|
#Chef::Mixin::Command.should_receive(:only_if).with(true, {}).and_return(false)
|
503
509
|
@resource.run_action(:purr)
|
504
|
-
snitch_variable.
|
510
|
+
expect(snitch_variable).to be_truthy
|
505
511
|
end
|
506
512
|
|
507
513
|
it "runs multiple only_if conditionals" do
|
@@ -509,25 +515,25 @@ describe Chef::Resource do
|
|
509
515
|
@resource.only_if { snitch_var1 = 1 }
|
510
516
|
@resource.only_if { snitch_var2 = 2 }
|
511
517
|
@resource.run_action(:purr)
|
512
|
-
snitch_var1.
|
513
|
-
snitch_var2.
|
518
|
+
expect(snitch_var1).to eq(1)
|
519
|
+
expect(snitch_var2).to eq(2)
|
514
520
|
end
|
515
521
|
|
516
522
|
it "accepts command options for only_if conditionals" do
|
517
|
-
Chef::Resource::Conditional.
|
523
|
+
expect_any_instance_of(Chef::Resource::Conditional).to receive(:evaluate_command).at_least(1).times
|
518
524
|
@resource.only_if("true", :cwd => '/tmp')
|
519
|
-
@resource.only_if.first.command_opts.
|
525
|
+
expect(@resource.only_if.first.command_opts).to eq({:cwd => '/tmp'})
|
520
526
|
@resource.run_action(:purr)
|
521
527
|
end
|
522
528
|
|
523
529
|
it "runs not_if as a command when it is a string" do
|
524
|
-
Chef::Resource::Conditional.
|
530
|
+
expect_any_instance_of(Chef::Resource::Conditional).to receive(:evaluate_command).at_least(1).times
|
525
531
|
@resource.not_if "pwd"
|
526
532
|
@resource.run_action(:purr)
|
527
533
|
end
|
528
534
|
|
529
535
|
it "runs not_if as a block when it is a ruby block" do
|
530
|
-
Chef::Resource::Conditional.
|
536
|
+
expect_any_instance_of(Chef::Resource::Conditional).to receive(:evaluate_block).at_least(1).times
|
531
537
|
@resource.not_if { puts 'foo' }
|
532
538
|
@resource.run_action(:purr)
|
533
539
|
end
|
@@ -540,7 +546,7 @@ describe Chef::Resource do
|
|
540
546
|
|
541
547
|
it "accepts command options for not_if conditionals" do
|
542
548
|
@resource.not_if("pwd" , :cwd => '/tmp')
|
543
|
-
@resource.not_if.first.command_opts.
|
549
|
+
expect(@resource.not_if.first.command_opts).to eq({:cwd => '/tmp'})
|
544
550
|
end
|
545
551
|
|
546
552
|
it "accepts multiple not_if conditionals" do
|
@@ -548,27 +554,27 @@ describe Chef::Resource do
|
|
548
554
|
@resource.not_if {snitch_var1 = nil}
|
549
555
|
@resource.not_if {snitch_var2 = false}
|
550
556
|
@resource.run_action(:purr)
|
551
|
-
snitch_var1.
|
552
|
-
snitch_var2.
|
557
|
+
expect(snitch_var1).to be_nil
|
558
|
+
expect(snitch_var2).to be_falsey
|
553
559
|
end
|
554
560
|
|
555
561
|
it "reports 0 elapsed time if actual elapsed time is < 0" do
|
556
562
|
expected = Time.now
|
557
|
-
Time.
|
563
|
+
allow(Time).to receive(:now).and_return(expected, expected - 1)
|
558
564
|
@resource.run_action(:purr)
|
559
|
-
@resource.elapsed_time.
|
565
|
+
expect(@resource.elapsed_time).to eq(0)
|
560
566
|
end
|
561
567
|
|
562
568
|
describe "guard_interpreter attribute" do
|
563
569
|
let(:resource) { @resource }
|
564
570
|
|
565
571
|
it "should be set to :default by default" do
|
566
|
-
resource.guard_interpreter.
|
572
|
+
expect(resource.guard_interpreter).to eq(:default)
|
567
573
|
end
|
568
574
|
|
569
575
|
it "if set to :default should return :default when read" do
|
570
576
|
resource.guard_interpreter(:default)
|
571
|
-
resource.guard_interpreter.
|
577
|
+
expect(resource.guard_interpreter).to eq(:default)
|
572
578
|
end
|
573
579
|
|
574
580
|
it "should raise Chef::Exceptions::ValidationFailed on an attempt to set the guard_interpreter attribute to something other than a Symbol" do
|
@@ -576,7 +582,7 @@ describe Chef::Resource do
|
|
576
582
|
end
|
577
583
|
|
578
584
|
it "should not raise an exception when setting the guard interpreter attribute to a Symbol" do
|
579
|
-
Chef::GuardInterpreter::ResourceGuardInterpreter.
|
585
|
+
allow(Chef::GuardInterpreter::ResourceGuardInterpreter).to receive(:new).and_return(nil)
|
580
586
|
expect { resource.guard_interpreter(:command_dot_com) }.not_to raise_error
|
581
587
|
end
|
582
588
|
end
|
@@ -588,63 +594,63 @@ describe Chef::Resource do
|
|
588
594
|
end
|
589
595
|
|
590
596
|
it "should return false by default" do
|
591
|
-
@resource.should_skip?(:purr).
|
597
|
+
expect(@resource.should_skip?(:purr)).to be_falsey
|
592
598
|
end
|
593
599
|
|
594
600
|
it "should return false when only_if is met" do
|
595
601
|
@resource.only_if { true }
|
596
|
-
@resource.should_skip?(:purr).
|
602
|
+
expect(@resource.should_skip?(:purr)).to be_falsey
|
597
603
|
end
|
598
604
|
|
599
605
|
it "should return true when only_if is not met" do
|
600
606
|
@resource.only_if { false }
|
601
|
-
@resource.should_skip?(:purr).
|
607
|
+
expect(@resource.should_skip?(:purr)).to be_truthy
|
602
608
|
end
|
603
609
|
|
604
610
|
it "should return true when not_if is met" do
|
605
611
|
@resource.not_if { true }
|
606
|
-
@resource.should_skip?(:purr).
|
612
|
+
expect(@resource.should_skip?(:purr)).to be_truthy
|
607
613
|
end
|
608
614
|
|
609
615
|
it "should return false when not_if is not met" do
|
610
616
|
@resource.not_if { false }
|
611
|
-
@resource.should_skip?(:purr).
|
617
|
+
expect(@resource.should_skip?(:purr)).to be_falsey
|
612
618
|
end
|
613
619
|
|
614
620
|
it "should return true when only_if is met but also not_if is met" do
|
615
621
|
@resource.only_if { true }
|
616
622
|
@resource.not_if { true }
|
617
|
-
@resource.should_skip?(:purr).
|
623
|
+
expect(@resource.should_skip?(:purr)).to be_truthy
|
618
624
|
end
|
619
625
|
|
620
626
|
it "should return true when one of multiple only_if's is not met" do
|
621
627
|
@resource.only_if { true }
|
622
628
|
@resource.only_if { false }
|
623
629
|
@resource.only_if { true }
|
624
|
-
@resource.should_skip?(:purr).
|
630
|
+
expect(@resource.should_skip?(:purr)).to be_truthy
|
625
631
|
end
|
626
632
|
|
627
633
|
it "should return true when one of multiple not_if's is met" do
|
628
634
|
@resource.not_if { false }
|
629
635
|
@resource.not_if { true }
|
630
636
|
@resource.not_if { false }
|
631
|
-
@resource.should_skip?(:purr).
|
637
|
+
expect(@resource.should_skip?(:purr)).to be_truthy
|
632
638
|
end
|
633
639
|
|
634
640
|
it "should return true when action is :nothing" do
|
635
|
-
@resource.should_skip?(:nothing).
|
641
|
+
expect(@resource.should_skip?(:nothing)).to be_truthy
|
636
642
|
end
|
637
643
|
|
638
644
|
it "should return true when action is :nothing ignoring only_if/not_if conditionals" do
|
639
645
|
@resource.only_if { true }
|
640
646
|
@resource.not_if { false }
|
641
|
-
@resource.should_skip?(:nothing).
|
647
|
+
expect(@resource.should_skip?(:nothing)).to be_truthy
|
642
648
|
end
|
643
649
|
|
644
650
|
it "should print \"skipped due to action :nothing\" message for doc formatter when action is :nothing" do
|
645
651
|
fdoc = Chef::Formatters.new(:doc, STDOUT, STDERR)
|
646
|
-
@run_context.
|
647
|
-
fdoc.
|
652
|
+
allow(@run_context).to receive(:events).and_return(fdoc)
|
653
|
+
expect(fdoc).to receive(:puts).with(" (skipped due to action :nothing)", anything())
|
648
654
|
@resource.should_skip?(:nothing)
|
649
655
|
end
|
650
656
|
|
@@ -664,7 +670,7 @@ describe Chef::Resource do
|
|
664
670
|
@resource1.only_if { snitch_var1 = 1 }
|
665
671
|
@resource1.not_if { snitch_var1 = 2 }
|
666
672
|
@resource1.run_action(:nothing)
|
667
|
-
snitch_var1.
|
673
|
+
expect(snitch_var1).to eq(0)
|
668
674
|
end
|
669
675
|
|
670
676
|
it "should run only_if/not_if conditionals when notified to run another action (CHEF-972)" do
|
@@ -685,8 +691,8 @@ describe Chef::Resource do
|
|
685
691
|
@run_context.resource_collection << @resource2
|
686
692
|
@runner.converge
|
687
693
|
|
688
|
-
snitch_var1.
|
689
|
-
snitch_var2.
|
694
|
+
expect(snitch_var1).to eq(1)
|
695
|
+
expect(snitch_var2).to eq(2)
|
690
696
|
end
|
691
697
|
end
|
692
698
|
|
@@ -750,10 +756,10 @@ describe Chef::Resource do
|
|
750
756
|
|
751
757
|
describe "resource_for_node" do
|
752
758
|
it "returns a resource by short_name and node" do
|
753
|
-
Chef::Resource.resource_for_node(:dinobot, @node).
|
759
|
+
expect(Chef::Resource.resource_for_node(:dinobot, @node)).to eql(Grimlock)
|
754
760
|
end
|
755
761
|
it "returns a resource by short_name if nothing else matches" do
|
756
|
-
Chef::Resource.resource_for_node(:soundwave, @node).
|
762
|
+
expect(Chef::Resource.resource_for_node(:soundwave, @node)).to eql(Soundwave)
|
757
763
|
end
|
758
764
|
end
|
759
765
|
|
@@ -765,30 +771,30 @@ describe Chef::Resource do
|
|
765
771
|
|
766
772
|
it "creates a delayed notification when timing is not specified" do
|
767
773
|
@resource.notifies(:run, "execute[foo]")
|
768
|
-
@run_context.delayed_notification_collection.
|
774
|
+
expect(@run_context.delayed_notification_collection.size).to eq(1)
|
769
775
|
end
|
770
776
|
|
771
777
|
it "creates a delayed notification when :delayed is not specified" do
|
772
778
|
@resource.notifies(:run, "execute[foo]", :delayed)
|
773
|
-
@run_context.delayed_notification_collection.
|
779
|
+
expect(@run_context.delayed_notification_collection.size).to eq(1)
|
774
780
|
end
|
775
781
|
|
776
782
|
it "creates an immediate notification when :immediate is specified" do
|
777
783
|
@resource.notifies(:run, "execute[foo]", :immediate)
|
778
|
-
@run_context.immediate_notification_collection.
|
784
|
+
expect(@run_context.immediate_notification_collection.size).to eq(1)
|
779
785
|
end
|
780
786
|
|
781
787
|
it "creates an immediate notification when :immediately is specified" do
|
782
788
|
@resource.notifies(:run, "execute[foo]", :immediately)
|
783
|
-
@run_context.immediate_notification_collection.
|
789
|
+
expect(@run_context.immediate_notification_collection.size).to eq(1)
|
784
790
|
end
|
785
791
|
|
786
792
|
describe "with a syntax error in the resource spec" do
|
787
793
|
|
788
794
|
it "raises an exception immmediately" do
|
789
|
-
|
795
|
+
expect do
|
790
796
|
@resource.notifies(:run, "typo[missing-closing-bracket")
|
791
|
-
end.
|
797
|
+
end.to raise_error(Chef::Exceptions::InvalidResourceSpecification)
|
792
798
|
end
|
793
799
|
end
|
794
800
|
end
|
@@ -800,22 +806,22 @@ describe Chef::Resource do
|
|
800
806
|
|
801
807
|
it "creates a delayed notification when timing is not specified" do
|
802
808
|
@resource.notifies(:run, @notified_resource)
|
803
|
-
@run_context.delayed_notification_collection.
|
809
|
+
expect(@run_context.delayed_notification_collection.size).to eq(1)
|
804
810
|
end
|
805
811
|
|
806
812
|
it "creates a delayed notification when :delayed is not specified" do
|
807
813
|
@resource.notifies(:run, @notified_resource, :delayed)
|
808
|
-
@run_context.delayed_notification_collection.
|
814
|
+
expect(@run_context.delayed_notification_collection.size).to eq(1)
|
809
815
|
end
|
810
816
|
|
811
817
|
it "creates an immediate notification when :immediate is specified" do
|
812
818
|
@resource.notifies(:run, @notified_resource, :immediate)
|
813
|
-
@run_context.immediate_notification_collection.
|
819
|
+
expect(@run_context.immediate_notification_collection.size).to eq(1)
|
814
820
|
end
|
815
821
|
|
816
822
|
it "creates an immediate notification when :immediately is specified" do
|
817
823
|
@resource.notifies(:run, @notified_resource, :immediately)
|
818
|
-
@run_context.immediate_notification_collection.
|
824
|
+
expect(@run_context.immediate_notification_collection.size).to eq(1)
|
819
825
|
end
|
820
826
|
end
|
821
827
|
|
@@ -837,19 +843,19 @@ describe Chef::Resource do
|
|
837
843
|
end
|
838
844
|
|
839
845
|
it "set to false by default" do
|
840
|
-
@resource.sensitive.
|
846
|
+
expect(@resource.sensitive).to be_falsey
|
841
847
|
end
|
842
848
|
|
843
849
|
it "when set to false should show compiled resource for failed resource" do
|
844
850
|
expect { @resource_file.run_action(@action) }.to raise_error { |err|
|
845
|
-
compiled_resource_data(@resource_file, @action, err).
|
851
|
+
expect(compiled_resource_data(@resource_file, @action, err)).to match 'path "/nonexistent/CHEF-5098/file"'
|
846
852
|
}
|
847
853
|
end
|
848
854
|
|
849
855
|
it "when set to true should show compiled resource for failed resource" do
|
850
856
|
@resource_file.sensitive true
|
851
857
|
expect { @resource_file.run_action(@action) }.to raise_error { |err|
|
852
|
-
compiled_resource_data(@resource_file, @action, err).
|
858
|
+
expect(compiled_resource_data(@resource_file, @action, err)).to eql("suppressed sensitive resource output")
|
853
859
|
}
|
854
860
|
end
|
855
861
|
|