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
@@ -29,39 +29,39 @@ describe Chef::ResourceCollection do
|
|
29
29
|
|
30
30
|
describe "initialize" do
|
31
31
|
it "should return a Chef::ResourceCollection" do
|
32
|
-
rc.
|
32
|
+
expect(rc).to be_kind_of(Chef::ResourceCollection)
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
36
|
describe "[]" do
|
37
37
|
it "should accept Chef::Resources through [index]" do
|
38
|
-
|
39
|
-
|
38
|
+
expect { rc[0] = resource }.not_to raise_error
|
39
|
+
expect { rc[0] = "string" }.to raise_error(ArgumentError)
|
40
40
|
end
|
41
41
|
|
42
42
|
it "should allow you to fetch Chef::Resources by position" do
|
43
43
|
rc[0] = resource
|
44
|
-
rc[0].
|
44
|
+
expect(rc[0]).to eql(resource)
|
45
45
|
end
|
46
46
|
end
|
47
47
|
|
48
48
|
describe "push" do
|
49
49
|
it "should accept Chef::Resources through pushing" do
|
50
|
-
|
51
|
-
|
50
|
+
expect { rc.push(resource) }.not_to raise_error
|
51
|
+
expect { rc.push("string") }.to raise_error(ArgumentError)
|
52
52
|
end
|
53
53
|
end
|
54
54
|
|
55
55
|
describe "<<" do
|
56
56
|
it "should accept the << operator" do
|
57
|
-
|
57
|
+
expect { rc << resource }.not_to raise_error
|
58
58
|
end
|
59
59
|
end
|
60
60
|
|
61
61
|
describe "insert" do
|
62
62
|
it "should accept only Chef::Resources" do
|
63
|
-
|
64
|
-
|
63
|
+
expect { rc.insert(resource) }.not_to raise_error
|
64
|
+
expect { rc.insert("string") }.to raise_error(ArgumentError)
|
65
65
|
end
|
66
66
|
|
67
67
|
it "should accept named arguments in any order" do
|
@@ -73,8 +73,8 @@ describe Chef::ResourceCollection do
|
|
73
73
|
zmr = Chef::Resource::ZenMaster.new("there is no spoon")
|
74
74
|
rc.insert(resource)
|
75
75
|
rc.insert(zmr)
|
76
|
-
rc[0].
|
77
|
-
rc[1].
|
76
|
+
expect(rc[0]).to eql(resource)
|
77
|
+
expect(rc[1]).to eql(zmr)
|
78
78
|
end
|
79
79
|
|
80
80
|
it "should insert resources to the middle of the collection if called while executing a run" do
|
@@ -88,9 +88,9 @@ describe Chef::ResourceCollection do
|
|
88
88
|
rc.insert(resource_to_inject) if resource == zmr
|
89
89
|
end
|
90
90
|
|
91
|
-
rc[0].
|
92
|
-
rc[1].
|
93
|
-
rc[2].
|
91
|
+
expect(rc[0]).to eql(zmr)
|
92
|
+
expect(rc[1]).to eql(resource_to_inject)
|
93
|
+
expect(rc[2]).to eql(dummy)
|
94
94
|
end
|
95
95
|
end
|
96
96
|
|
@@ -98,19 +98,19 @@ describe Chef::ResourceCollection do
|
|
98
98
|
it "should allow you to iterate over every resource in the collection" do
|
99
99
|
load_up_resources
|
100
100
|
results = Array.new
|
101
|
-
|
101
|
+
expect {
|
102
102
|
rc.each do |r|
|
103
103
|
results << r.name
|
104
104
|
end
|
105
|
-
}.
|
105
|
+
}.not_to raise_error
|
106
106
|
results.each_index do |i|
|
107
107
|
case i
|
108
108
|
when 0
|
109
|
-
results[i].
|
109
|
+
expect(results[i]).to eql("dog")
|
110
110
|
when 1
|
111
|
-
results[i].
|
111
|
+
expect(results[i]).to eql("cat")
|
112
112
|
when 2
|
113
|
-
results[i].
|
113
|
+
expect(results[i]).to eql("monkey")
|
114
114
|
end
|
115
115
|
end
|
116
116
|
end
|
@@ -120,19 +120,19 @@ describe Chef::ResourceCollection do
|
|
120
120
|
it "should allow you to iterate over every resource by index" do
|
121
121
|
load_up_resources
|
122
122
|
results = Array.new
|
123
|
-
|
123
|
+
expect {
|
124
124
|
rc.each_index do |i|
|
125
125
|
results << rc[i].name
|
126
126
|
end
|
127
|
-
}.
|
127
|
+
}.not_to raise_error
|
128
128
|
results.each_index do |i|
|
129
129
|
case i
|
130
130
|
when 0
|
131
|
-
results[i].
|
131
|
+
expect(results[i]).to eql("dog")
|
132
132
|
when 1
|
133
|
-
results[i].
|
133
|
+
expect(results[i]).to eql("cat")
|
134
134
|
when 2
|
135
|
-
results[i].
|
135
|
+
expect(results[i]).to eql("monkey")
|
136
136
|
end
|
137
137
|
end
|
138
138
|
end
|
@@ -142,23 +142,23 @@ describe Chef::ResourceCollection do
|
|
142
142
|
it "should allow you to find resources by name via lookup" do
|
143
143
|
zmr = Chef::Resource::ZenMaster.new("dog")
|
144
144
|
rc << zmr
|
145
|
-
rc.lookup(zmr.to_s).
|
145
|
+
expect(rc.lookup(zmr.to_s)).to eql(zmr)
|
146
146
|
|
147
147
|
zmr = Chef::Resource::ZenMaster.new("cat")
|
148
148
|
rc[0] = zmr
|
149
|
-
rc.lookup(zmr).
|
149
|
+
expect(rc.lookup(zmr)).to eql(zmr)
|
150
150
|
|
151
151
|
zmr = Chef::Resource::ZenMaster.new("monkey")
|
152
152
|
rc.push(zmr)
|
153
|
-
rc.lookup(zmr).
|
153
|
+
expect(rc.lookup(zmr)).to eql(zmr)
|
154
154
|
end
|
155
155
|
|
156
156
|
it "should raise an exception if you send something strange to lookup" do
|
157
|
-
|
157
|
+
expect { rc.lookup(:symbol) }.to raise_error(ArgumentError)
|
158
158
|
end
|
159
159
|
|
160
160
|
it "should raise an exception if it cannot find a resource with lookup" do
|
161
|
-
|
161
|
+
expect { rc.lookup("zen_master[dog]") }.to raise_error(Chef::Exceptions::ResourceNotFound)
|
162
162
|
end
|
163
163
|
end
|
164
164
|
|
@@ -166,81 +166,81 @@ describe Chef::ResourceCollection do
|
|
166
166
|
|
167
167
|
it "should find a resource by symbol and name (:zen_master => monkey)" do
|
168
168
|
load_up_resources
|
169
|
-
rc.resources(:zen_master => "monkey").name.
|
169
|
+
expect(rc.resources(:zen_master => "monkey").name).to eql("monkey")
|
170
170
|
end
|
171
171
|
|
172
172
|
it "should find a resource by symbol and array of names (:zen_master => [a,b])" do
|
173
173
|
load_up_resources
|
174
174
|
results = rc.resources(:zen_master => [ "monkey", "dog" ])
|
175
|
-
results.length.
|
175
|
+
expect(results.length).to eql(2)
|
176
176
|
check_by_names(results, "monkey", "dog")
|
177
177
|
end
|
178
178
|
|
179
179
|
it "should find resources of multiple kinds (:zen_master => a, :file => b)" do
|
180
180
|
load_up_resources
|
181
181
|
results = rc.resources(:zen_master => "monkey", :file => "something")
|
182
|
-
results.length.
|
182
|
+
expect(results.length).to eql(2)
|
183
183
|
check_by_names(results, "monkey", "something")
|
184
184
|
end
|
185
185
|
|
186
186
|
it "should find a resource by string zen_master[a]" do
|
187
187
|
load_up_resources
|
188
|
-
rc.resources("zen_master[monkey]").name.
|
188
|
+
expect(rc.resources("zen_master[monkey]").name).to eql("monkey")
|
189
189
|
end
|
190
190
|
|
191
191
|
it "should find resources by strings of zen_master[a,b]" do
|
192
192
|
load_up_resources
|
193
193
|
results = rc.resources("zen_master[monkey,dog]")
|
194
|
-
results.length.
|
194
|
+
expect(results.length).to eql(2)
|
195
195
|
check_by_names(results, "monkey", "dog")
|
196
196
|
end
|
197
197
|
|
198
198
|
it "should find resources of multiple types by strings of zen_master[a]" do
|
199
199
|
load_up_resources
|
200
200
|
results = rc.resources("zen_master[monkey]", "file[something]")
|
201
|
-
results.length.
|
201
|
+
expect(results.length).to eql(2)
|
202
202
|
check_by_names(results, "monkey", "something")
|
203
203
|
end
|
204
204
|
|
205
205
|
it "should raise an exception if you pass a bad name to resources" do
|
206
|
-
|
206
|
+
expect { rc.resources("michael jackson") }.to raise_error(ArgumentError)
|
207
207
|
end
|
208
208
|
|
209
209
|
it "should raise an exception if you pass something other than a string or hash to resource" do
|
210
|
-
|
210
|
+
expect { rc.resources([Array.new]) }.to raise_error(ArgumentError)
|
211
211
|
end
|
212
212
|
|
213
213
|
it "raises an error when attempting to find a resource that does not exist" do
|
214
|
-
|
214
|
+
expect {rc.find("script[nonesuch]")}.to raise_error(Chef::Exceptions::ResourceNotFound)
|
215
215
|
end
|
216
216
|
|
217
217
|
end
|
218
218
|
|
219
219
|
describe "when validating a resource query object" do
|
220
220
|
it "accepts a string of the form 'resource_type[resource_name]'" do
|
221
|
-
rc.validate_lookup_spec!("resource_type[resource_name]").
|
221
|
+
expect(rc.validate_lookup_spec!("resource_type[resource_name]")).to be_truthy
|
222
222
|
end
|
223
223
|
|
224
224
|
it "accepts a single-element :resource_type => 'resource_name' Hash" do
|
225
|
-
rc.validate_lookup_spec!(:service => "apache2").
|
225
|
+
expect(rc.validate_lookup_spec!(:service => "apache2")).to be_truthy
|
226
226
|
end
|
227
227
|
|
228
228
|
|
229
229
|
it "accepts a chef resource object" do
|
230
230
|
res = Chef::Resource.new("foo", nil)
|
231
|
-
rc.validate_lookup_spec!(res).
|
231
|
+
expect(rc.validate_lookup_spec!(res)).to be_truthy
|
232
232
|
end
|
233
233
|
|
234
234
|
it "rejects a malformed query string" do
|
235
|
-
|
235
|
+
expect do
|
236
236
|
rc.validate_lookup_spec!("resource_type[missing-end-bracket")
|
237
|
-
end.
|
237
|
+
end.to raise_error(Chef::Exceptions::InvalidResourceSpecification)
|
238
238
|
end
|
239
239
|
|
240
240
|
it "rejects an argument that is not a String, Hash, or Chef::Resource" do
|
241
|
-
|
241
|
+
expect do
|
242
242
|
rc.validate_lookup_spec!(Object.new)
|
243
|
-
end.
|
243
|
+
end.to raise_error(Chef::Exceptions::InvalidResourceSpecification)
|
244
244
|
end
|
245
245
|
|
246
246
|
end
|
@@ -248,8 +248,8 @@ describe Chef::ResourceCollection do
|
|
248
248
|
describe "to_json" do
|
249
249
|
it "should serialize to json" do
|
250
250
|
json = rc.to_json
|
251
|
-
json.
|
252
|
-
json.
|
251
|
+
expect(json).to match(/json_class/)
|
252
|
+
expect(json).to match(/instance_vars/)
|
253
253
|
end
|
254
254
|
|
255
255
|
include_examples "to_json equalivent to Chef::JSONCompat.to_json" do
|
@@ -266,27 +266,27 @@ describe Chef::ResourceCollection do
|
|
266
266
|
rc << resource
|
267
267
|
json = Chef::JSONCompat.to_json(rc)
|
268
268
|
s_rc = Chef::JSONCompat.from_json(json)
|
269
|
-
s_rc.
|
270
|
-
s_rc[0].name.
|
269
|
+
expect(s_rc).to be_a_kind_of(Chef::ResourceCollection)
|
270
|
+
expect(s_rc[0].name).to eql(resource.name)
|
271
271
|
end
|
272
272
|
end
|
273
273
|
|
274
274
|
describe "provides access to the raw resources array" do
|
275
275
|
it "returns the resources via the all_resources method" do
|
276
|
-
rc.all_resources.
|
276
|
+
expect(rc.all_resources).to equal(rc.instance_variable_get(:@resource_list).instance_variable_get(:@resources))
|
277
277
|
end
|
278
278
|
end
|
279
279
|
|
280
280
|
describe "provides access to stepable iterator" do
|
281
281
|
it "returns the iterator object" do
|
282
282
|
rc.instance_variable_get(:@resource_list).instance_variable_set(:@iterator, :fooboar)
|
283
|
-
rc.iterator.
|
283
|
+
expect(rc.iterator).to eq(:fooboar)
|
284
284
|
end
|
285
285
|
end
|
286
286
|
|
287
287
|
def check_by_names(results, *names)
|
288
288
|
names.each do |res_name|
|
289
|
-
results.detect{ |res| res.name == res_name }.
|
289
|
+
expect(results.detect{ |res| res.name == res_name }).not_to eql(nil)
|
290
290
|
end
|
291
291
|
end
|
292
292
|
|
@@ -85,7 +85,7 @@ describe Chef::ResourceDefinition do
|
|
85
85
|
expect(defn.recipe.call).to eql("I am what I am")
|
86
86
|
end
|
87
87
|
|
88
|
-
it "should set
|
88
|
+
it "should set parameters based on method_missing" do
|
89
89
|
defn.mind "to fly"
|
90
90
|
expect(defn.params[:mind]).to eql("to fly")
|
91
91
|
end
|
@@ -37,13 +37,13 @@ describe Chef::ResourceReporter do
|
|
37
37
|
@node = Chef::Node.new
|
38
38
|
@node.name("spitfire")
|
39
39
|
@rest_client = double("Chef::REST (mock)")
|
40
|
-
@rest_client.
|
40
|
+
allow(@rest_client).to receive(:post_rest).and_return(true)
|
41
41
|
@resource_reporter = Chef::ResourceReporter.new(@rest_client)
|
42
42
|
@new_resource = Chef::Resource::File.new("/tmp/a-file.txt")
|
43
43
|
@cookbook_name = "monkey"
|
44
44
|
@new_resource.cookbook_name = @cookbook_name
|
45
45
|
@cookbook_version = double("Cookbook::Version", :version => "1.2.3")
|
46
|
-
@new_resource.
|
46
|
+
allow(@new_resource).to receive(:cookbook_version).and_return(@cookbook_version)
|
47
47
|
@current_resource = Chef::Resource::File.new("/tmp/a-file.txt")
|
48
48
|
@start_time = Time.new
|
49
49
|
@end_time = Time.new + 20
|
@@ -51,25 +51,25 @@ describe Chef::ResourceReporter do
|
|
51
51
|
@run_context = Chef::RunContext.new(@node, {}, @events)
|
52
52
|
@run_status = Chef::RunStatus.new(@node, @events)
|
53
53
|
@run_id = @run_status.run_id
|
54
|
-
Time.
|
54
|
+
allow(Time).to receive(:now).and_return(@start_time, @end_time)
|
55
55
|
end
|
56
56
|
|
57
57
|
context "when first created" do
|
58
58
|
|
59
59
|
it "has no updated resources" do
|
60
|
-
@resource_reporter.
|
60
|
+
expect(@resource_reporter.updated_resources.size).to eq(0)
|
61
61
|
end
|
62
62
|
|
63
63
|
it "reports a successful run" do
|
64
|
-
@resource_reporter.status.
|
64
|
+
expect(@resource_reporter.status).to eq("success")
|
65
65
|
end
|
66
66
|
|
67
67
|
it "assumes the resource history feature is supported" do
|
68
|
-
@resource_reporter.reporting_enabled
|
68
|
+
expect(@resource_reporter.reporting_enabled?).to be_truthy
|
69
69
|
end
|
70
70
|
|
71
71
|
it "should have no error_descriptions" do
|
72
|
-
@resource_reporter.error_descriptions.
|
72
|
+
expect(@resource_reporter.error_descriptions).to eq({})
|
73
73
|
# @resource_reporter.error_descriptions.should be_empty
|
74
74
|
# @resource_reporter.should have(0).error_descriptions
|
75
75
|
end
|
@@ -82,16 +82,16 @@ describe Chef::ResourceReporter do
|
|
82
82
|
end
|
83
83
|
|
84
84
|
it "reports a successful run" do
|
85
|
-
|
86
|
-
@resource_reporter.status.
|
85
|
+
skip "refactor how node gets set."
|
86
|
+
expect(@resource_reporter.status).to eq("success")
|
87
87
|
end
|
88
88
|
end
|
89
89
|
|
90
90
|
context "when chef fails" do
|
91
91
|
before do
|
92
|
-
@rest_client.
|
93
|
-
@rest_client.
|
94
|
-
@rest_client.
|
92
|
+
allow(@rest_client).to receive(:create_url).and_return("reports/nodes/spitfire/runs/#{@run_id}");
|
93
|
+
allow(@rest_client).to receive(:raw_http_request).and_return({"result"=>"ok"});
|
94
|
+
allow(@rest_client).to receive(:post_rest).and_return({"uri"=>"https://example.com/reports/nodes/spitfire/runs/#{@run_id}"});
|
95
95
|
|
96
96
|
end
|
97
97
|
|
@@ -103,11 +103,11 @@ describe Chef::ResourceReporter do
|
|
103
103
|
end
|
104
104
|
|
105
105
|
it "sets the run status to 'failure'" do
|
106
|
-
@resource_reporter.status.
|
106
|
+
expect(@resource_reporter.status).to eq("failure")
|
107
107
|
end
|
108
108
|
|
109
109
|
it "keeps the exception data" do
|
110
|
-
@resource_reporter.exception.
|
110
|
+
expect(@resource_reporter.exception).to eq(@exception)
|
111
111
|
end
|
112
112
|
end
|
113
113
|
|
@@ -121,12 +121,12 @@ describe Chef::ResourceReporter do
|
|
121
121
|
end
|
122
122
|
|
123
123
|
it "collects the resource as an updated resource" do
|
124
|
-
@resource_reporter.
|
124
|
+
expect(@resource_reporter.updated_resources.size).to eq(1)
|
125
125
|
end
|
126
126
|
|
127
127
|
it "collects the desired state of the resource" do
|
128
128
|
update_record = @resource_reporter.updated_resources.first
|
129
|
-
update_record.new_resource.
|
129
|
+
expect(update_record.new_resource).to eq(@new_resource)
|
130
130
|
end
|
131
131
|
end
|
132
132
|
|
@@ -145,7 +145,7 @@ describe Chef::ResourceReporter do
|
|
145
145
|
end
|
146
146
|
|
147
147
|
it "has no updated resources" do
|
148
|
-
@resource_reporter.
|
148
|
+
expect(@resource_reporter.updated_resources.size).to eq(0)
|
149
149
|
end
|
150
150
|
end
|
151
151
|
|
@@ -158,17 +158,17 @@ describe Chef::ResourceReporter do
|
|
158
158
|
end
|
159
159
|
|
160
160
|
it "collects the updated resource" do
|
161
|
-
@resource_reporter.
|
161
|
+
expect(@resource_reporter.updated_resources.size).to eq(1)
|
162
162
|
end
|
163
163
|
|
164
164
|
it "collects the old state of the resource" do
|
165
165
|
update_record = @resource_reporter.updated_resources.first
|
166
|
-
update_record.current_resource.
|
166
|
+
expect(update_record.current_resource).to eq(@current_resource)
|
167
167
|
end
|
168
168
|
|
169
169
|
it "collects the new state of the resource" do
|
170
170
|
update_record = @resource_reporter.updated_resources.first
|
171
|
-
update_record.new_resource.
|
171
|
+
expect(update_record.new_resource).to eq(@new_resource)
|
172
172
|
end
|
173
173
|
|
174
174
|
context "and a subsequent resource fails before loading current resource" do
|
@@ -182,12 +182,12 @@ describe Chef::ResourceReporter do
|
|
182
182
|
|
183
183
|
it "collects the desired state of the failed resource" do
|
184
184
|
failed_resource_update = @resource_reporter.updated_resources.last
|
185
|
-
failed_resource_update.new_resource.
|
185
|
+
expect(failed_resource_update.new_resource).to eq(@next_new_resource)
|
186
186
|
end
|
187
187
|
|
188
188
|
it "does not have the current state of the failed resource" do
|
189
189
|
failed_resource_update = @resource_reporter.updated_resources.last
|
190
|
-
failed_resource_update.current_resource.
|
190
|
+
expect(failed_resource_update.current_resource).to be_nil
|
191
191
|
end
|
192
192
|
end
|
193
193
|
end
|
@@ -208,7 +208,7 @@ describe Chef::ResourceReporter do
|
|
208
208
|
end
|
209
209
|
|
210
210
|
it "does not collect data about the nested resource" do
|
211
|
-
@resource_reporter.
|
211
|
+
expect(@resource_reporter.updated_resources.size).to eq(1)
|
212
212
|
end
|
213
213
|
end
|
214
214
|
|
@@ -224,7 +224,7 @@ describe Chef::ResourceReporter do
|
|
224
224
|
end
|
225
225
|
|
226
226
|
it "does not collect data about the nested resource" do
|
227
|
-
@resource_reporter.
|
227
|
+
expect(@resource_reporter.updated_resources.size).to eq(1)
|
228
228
|
end
|
229
229
|
end
|
230
230
|
|
@@ -237,17 +237,17 @@ describe Chef::ResourceReporter do
|
|
237
237
|
end
|
238
238
|
|
239
239
|
it "collects the resource as an updated resource" do
|
240
|
-
@resource_reporter.
|
240
|
+
expect(@resource_reporter.updated_resources.size).to eq(1)
|
241
241
|
end
|
242
242
|
|
243
243
|
it "collects the desired state of the resource" do
|
244
244
|
update_record = @resource_reporter.updated_resources.first
|
245
|
-
update_record.new_resource.
|
245
|
+
expect(update_record.new_resource).to eq(@new_resource)
|
246
246
|
end
|
247
247
|
|
248
248
|
it "collects the current state of the resource" do
|
249
249
|
update_record = @resource_reporter.updated_resources.first
|
250
|
-
update_record.current_resource.
|
250
|
+
expect(update_record.current_resource).to eq(@current_resource)
|
251
251
|
end
|
252
252
|
end
|
253
253
|
|
@@ -257,9 +257,9 @@ describe Chef::ResourceReporter do
|
|
257
257
|
describe "when generating a report for the server" do
|
258
258
|
|
259
259
|
before do
|
260
|
-
@rest_client.
|
261
|
-
@rest_client.
|
262
|
-
@rest_client.
|
260
|
+
allow(@rest_client).to receive(:create_url).and_return("reports/nodes/spitfire/runs/#{@run_id}");
|
261
|
+
allow(@rest_client).to receive(:raw_http_request).and_return({"result"=>"ok"});
|
262
|
+
allow(@rest_client).to receive(:post_rest).and_return({"uri"=>"https://example.com/reports/nodes/spitfire/runs/#{@run_id}"});
|
263
263
|
|
264
264
|
@resource_reporter.run_started(@run_status)
|
265
265
|
end
|
@@ -268,8 +268,8 @@ describe Chef::ResourceReporter do
|
|
268
268
|
context "the new_resource name and id are nil" do
|
269
269
|
before do
|
270
270
|
@bad_resource = Chef::Resource::File.new("/tmp/nameless_file.txt")
|
271
|
-
@bad_resource.
|
272
|
-
@bad_resource.
|
271
|
+
allow(@bad_resource).to receive(:name).and_return(nil)
|
272
|
+
allow(@bad_resource).to receive(:identity).and_return(nil)
|
273
273
|
@resource_reporter.resource_action_start(@bad_resource, :create)
|
274
274
|
@resource_reporter.resource_current_state_loaded(@bad_resource, :create, @current_resource)
|
275
275
|
@resource_reporter.resource_updated(@bad_resource, :create)
|
@@ -280,19 +280,19 @@ describe Chef::ResourceReporter do
|
|
280
280
|
end
|
281
281
|
|
282
282
|
it "resource_name in prepared_run_data is a string" do
|
283
|
-
@first_update_report["name"].class.
|
283
|
+
expect(@first_update_report["name"].class).to eq(String)
|
284
284
|
end
|
285
285
|
|
286
286
|
it "resource_id in prepared_run_data is a string" do
|
287
|
-
@first_update_report["id"].class.
|
287
|
+
expect(@first_update_report["id"].class).to eq(String)
|
288
288
|
end
|
289
289
|
end
|
290
290
|
|
291
291
|
context "the new_resource name and id are hashes" do
|
292
292
|
before do
|
293
293
|
@bad_resource = Chef::Resource::File.new("/tmp/filename_as_hash.txt")
|
294
|
-
@bad_resource.
|
295
|
-
@bad_resource.
|
294
|
+
allow(@bad_resource).to receive(:name).and_return({:foo=>:bar})
|
295
|
+
allow(@bad_resource).to receive(:identity).and_return({:foo=>:bar})
|
296
296
|
@resource_reporter.resource_action_start(@bad_resource, :create)
|
297
297
|
@resource_reporter.resource_current_state_loaded(@bad_resource, :create, @current_resource)
|
298
298
|
@resource_reporter.resource_updated(@bad_resource, :create)
|
@@ -309,11 +309,11 @@ describe Chef::ResourceReporter do
|
|
309
309
|
# => "{:foo=>:bar}"
|
310
310
|
# Hence checking for the class instead of the actual value.
|
311
311
|
it "resource_name in prepared_run_data is a string" do
|
312
|
-
@first_update_report["name"].class.
|
312
|
+
expect(@first_update_report["name"].class).to eq(String)
|
313
313
|
end
|
314
314
|
|
315
315
|
it "resource_id in prepared_run_data is a string" do
|
316
|
-
@first_update_report["id"].class.
|
316
|
+
expect(@first_update_report["id"].class).to eq(String)
|
317
317
|
end
|
318
318
|
end
|
319
319
|
end
|
@@ -360,73 +360,73 @@ describe Chef::ResourceReporter do
|
|
360
360
|
end
|
361
361
|
|
362
362
|
it "includes the run's status" do
|
363
|
-
@report.
|
363
|
+
expect(@report).to have_key("status")
|
364
364
|
end
|
365
365
|
|
366
366
|
it "includes a list of updated resources" do
|
367
|
-
@report.
|
367
|
+
expect(@report).to have_key("resources")
|
368
368
|
end
|
369
369
|
|
370
370
|
it "includes an updated resource's type" do
|
371
|
-
@first_update_report.
|
371
|
+
expect(@first_update_report).to have_key("type")
|
372
372
|
end
|
373
373
|
|
374
374
|
it "includes an updated resource's initial state" do
|
375
|
-
@first_update_report["before"].
|
375
|
+
expect(@first_update_report["before"]).to eq(current_resource.state)
|
376
376
|
end
|
377
377
|
|
378
378
|
it "includes an updated resource's final state" do
|
379
|
-
@first_update_report["after"].
|
379
|
+
expect(@first_update_report["after"]).to eq(new_resource.state)
|
380
380
|
end
|
381
381
|
|
382
382
|
it "includes the resource's name" do
|
383
|
-
@first_update_report["name"].
|
383
|
+
expect(@first_update_report["name"]).to eq(new_resource.name)
|
384
384
|
end
|
385
385
|
|
386
386
|
it "includes the resource's id attribute" do
|
387
|
-
@first_update_report["id"].
|
387
|
+
expect(@first_update_report["id"]).to eq(new_resource.identity)
|
388
388
|
end
|
389
389
|
|
390
390
|
it "includes the elapsed time for the resource to converge" do
|
391
391
|
# TODO: API takes integer number of milliseconds as a string. This
|
392
392
|
# should be an int.
|
393
|
-
@first_update_report.
|
394
|
-
@first_update_report["duration"].to_i.
|
393
|
+
expect(@first_update_report).to have_key("duration")
|
394
|
+
expect(@first_update_report["duration"].to_i).to be_within(100).of(0)
|
395
395
|
end
|
396
396
|
|
397
397
|
it "includes the action executed by the resource" do
|
398
398
|
# TODO: rename as "action"
|
399
|
-
@first_update_report["result"].
|
399
|
+
expect(@first_update_report["result"]).to eq("create")
|
400
400
|
end
|
401
401
|
|
402
402
|
it "includes the cookbook name of the resource" do
|
403
|
-
@first_update_report.
|
404
|
-
@first_update_report["cookbook_name"].
|
403
|
+
expect(@first_update_report).to have_key("cookbook_name")
|
404
|
+
expect(@first_update_report["cookbook_name"]).to eq(@cookbook_name)
|
405
405
|
end
|
406
406
|
|
407
407
|
it "includes the cookbook version of the resource" do
|
408
|
-
@first_update_report.
|
409
|
-
@first_update_report["cookbook_version"].
|
408
|
+
expect(@first_update_report).to have_key("cookbook_version")
|
409
|
+
expect(@first_update_report["cookbook_version"]).to eq("1.2.3")
|
410
410
|
end
|
411
411
|
|
412
412
|
it "includes the total resource count" do
|
413
|
-
@report.
|
414
|
-
@report["total_res_count"].
|
413
|
+
expect(@report).to have_key("total_res_count")
|
414
|
+
expect(@report["total_res_count"]).to eq("1")
|
415
415
|
end
|
416
416
|
|
417
417
|
it "includes the data hash" do
|
418
|
-
@report.
|
419
|
-
@report["data"].
|
418
|
+
expect(@report).to have_key("data")
|
419
|
+
expect(@report["data"]).to eq({})
|
420
420
|
end
|
421
421
|
|
422
422
|
it "includes the run_list" do
|
423
|
-
@report.
|
424
|
-
@report["run_list"].
|
423
|
+
expect(@report).to have_key("run_list")
|
424
|
+
expect(@report["run_list"]).to eq(Chef::JSONCompat.to_json(@run_status.node.run_list))
|
425
425
|
end
|
426
426
|
|
427
427
|
it "includes the end_time" do
|
428
|
-
@report.
|
429
|
-
@report["end_time"].
|
428
|
+
expect(@report).to have_key("end_time")
|
429
|
+
expect(@report["end_time"]).to eq(@run_status.end_time.to_s)
|
430
430
|
end
|
431
431
|
|
432
432
|
end
|
@@ -442,8 +442,8 @@ describe Chef::ResourceReporter do
|
|
442
442
|
let(:new_resource) do
|
443
443
|
resource = Chef::Resource::RegistryKey.new('Wubba\Lubba\Dub\Dubs')
|
444
444
|
resource.values([ { :name => 'rick', :type => :binary, :data => 255.chr * 1 } ])
|
445
|
-
resource.
|
446
|
-
resource.
|
445
|
+
allow(resource).to receive(:cookbook_name).and_return(@cookbook_name)
|
446
|
+
allow(resource).to receive(:cookbook_version).and_return(@cookbook_version)
|
447
447
|
resource
|
448
448
|
end
|
449
449
|
|
@@ -463,33 +463,33 @@ describe Chef::ResourceReporter do
|
|
463
463
|
@node = Chef::Node.new
|
464
464
|
@node.name("spitfire")
|
465
465
|
@exception = ArgumentError.new
|
466
|
-
@exception.
|
467
|
-
@exception.
|
468
|
-
@exception.
|
466
|
+
allow(@exception).to receive(:inspect).and_return("Net::HTTPServerException")
|
467
|
+
allow(@exception).to receive(:message).and_return("Object not found")
|
468
|
+
allow(@exception).to receive(:backtrace).and_return(@backtrace)
|
469
469
|
@resource_reporter.run_list_expand_failed(@node, @exception)
|
470
470
|
@resource_reporter.run_failed(@exception)
|
471
471
|
@report = @resource_reporter.prepare_run_data
|
472
472
|
end
|
473
473
|
|
474
474
|
it "includes the exception type in the event data" do
|
475
|
-
@report.
|
476
|
-
@report["data"]["exception"].
|
477
|
-
@report["data"]["exception"]["class"].
|
475
|
+
expect(@report).to have_key("data")
|
476
|
+
expect(@report["data"]["exception"]).to have_key("class")
|
477
|
+
expect(@report["data"]["exception"]["class"]).to eq("Net::HTTPServerException")
|
478
478
|
end
|
479
479
|
|
480
480
|
it "includes the exception message in the event data" do
|
481
|
-
@report["data"]["exception"].
|
482
|
-
@report["data"]["exception"]["message"].
|
481
|
+
expect(@report["data"]["exception"]).to have_key("message")
|
482
|
+
expect(@report["data"]["exception"]["message"]).to eq("Object not found")
|
483
483
|
end
|
484
484
|
|
485
485
|
it "includes the exception trace in the event data" do
|
486
|
-
@report["data"]["exception"].
|
487
|
-
@report["data"]["exception"]["backtrace"].
|
486
|
+
expect(@report["data"]["exception"]).to have_key("backtrace")
|
487
|
+
expect(@report["data"]["exception"]["backtrace"]).to eq(Chef::JSONCompat.to_json(@backtrace))
|
488
488
|
end
|
489
489
|
|
490
490
|
it "includes the error inspector output in the event data" do
|
491
|
-
@report["data"]["exception"].
|
492
|
-
@report["data"]["exception"]["description"].
|
491
|
+
expect(@report["data"]["exception"]).to have_key("description")
|
492
|
+
expect(@report["data"]["exception"]["description"]).to include({"title"=>"Error expanding the run_list:", "sections"=>[{"Unexpected Error:" => "ArgumentError: Object not found"}]})
|
493
493
|
end
|
494
494
|
|
495
495
|
end
|
@@ -509,39 +509,39 @@ describe Chef::ResourceReporter do
|
|
509
509
|
end
|
510
510
|
|
511
511
|
it "includes an updated resource's initial state" do
|
512
|
-
@first_update_report["before"].
|
512
|
+
expect(@first_update_report["before"]).to eq(@current_resource.state)
|
513
513
|
end
|
514
514
|
|
515
515
|
it "includes an updated resource's final state" do
|
516
|
-
@first_update_report["after"].
|
516
|
+
expect(@first_update_report["after"]).to eq(@new_resource.state)
|
517
517
|
end
|
518
518
|
|
519
519
|
it "includes the resource's name" do
|
520
|
-
@first_update_report["name"].
|
520
|
+
expect(@first_update_report["name"]).to eq(@new_resource.name)
|
521
521
|
end
|
522
522
|
|
523
523
|
it "includes the resource's id attribute" do
|
524
|
-
@first_update_report["id"].
|
524
|
+
expect(@first_update_report["id"]).to eq(@new_resource.identity)
|
525
525
|
end
|
526
526
|
|
527
527
|
it "includes the elapsed time for the resource to converge" do
|
528
528
|
# TODO: API takes integer number of milliseconds as a string. This
|
529
529
|
# should be an int.
|
530
|
-
@first_update_report.
|
531
|
-
@first_update_report["duration"].to_i.
|
530
|
+
expect(@first_update_report).to have_key("duration")
|
531
|
+
expect(@first_update_report["duration"].to_i).to be_within(100).of(0)
|
532
532
|
end
|
533
533
|
|
534
534
|
it "includes the action executed by the resource" do
|
535
535
|
# TODO: rename as "action"
|
536
|
-
@first_update_report["result"].
|
536
|
+
expect(@first_update_report["result"]).to eq("create")
|
537
537
|
end
|
538
538
|
|
539
539
|
it "does not include a cookbook name for the resource" do
|
540
|
-
@first_update_report.
|
540
|
+
expect(@first_update_report).not_to have_key("cookbook_name")
|
541
541
|
end
|
542
542
|
|
543
543
|
it "does not include a cookbook version for the resource" do
|
544
|
-
@first_update_report.
|
544
|
+
expect(@first_update_report).not_to have_key("cookbook_version")
|
545
545
|
end
|
546
546
|
end
|
547
547
|
|
@@ -562,13 +562,13 @@ describe Chef::ResourceReporter do
|
|
562
562
|
end
|
563
563
|
|
564
564
|
it "sets before to {} instead of nil" do
|
565
|
-
@first_update_report.
|
566
|
-
@first_update_report['before'].
|
565
|
+
expect(@first_update_report).to have_key("before")
|
566
|
+
expect(@first_update_report['before']).to eq({})
|
567
567
|
end
|
568
568
|
|
569
569
|
it "sets after to {} instead of 'Running'" do
|
570
|
-
@first_update_report.
|
571
|
-
@first_update_report['after'].
|
570
|
+
expect(@first_update_report).to have_key("after")
|
571
|
+
expect(@first_update_report['after']).to eq({})
|
572
572
|
end
|
573
573
|
end
|
574
574
|
|
@@ -585,7 +585,7 @@ describe Chef::ResourceReporter do
|
|
585
585
|
# 404 getting the run_id
|
586
586
|
@response = Net::HTTPNotFound.new("a response body", "404", "Not Found")
|
587
587
|
@error = Net::HTTPServerException.new("404 message", @response)
|
588
|
-
@rest_client.
|
588
|
+
expect(@rest_client).to receive(:post_rest).
|
589
589
|
with("reports/nodes/spitfire/runs", {:action => :start, :run_id => @run_id,
|
590
590
|
:start_time => @start_time.to_s},
|
591
591
|
{'X-Ops-Reporting-Protocol-Version' => Chef::ResourceReporter::PROTOCOL_VERSION}).
|
@@ -594,17 +594,17 @@ describe Chef::ResourceReporter do
|
|
594
594
|
|
595
595
|
it "assumes the feature is not enabled" do
|
596
596
|
@resource_reporter.run_started(@run_status)
|
597
|
-
@resource_reporter.reporting_enabled
|
597
|
+
expect(@resource_reporter.reporting_enabled?).to be_falsey
|
598
598
|
end
|
599
599
|
|
600
600
|
it "does not send a resource report to the server" do
|
601
601
|
@resource_reporter.run_started(@run_status)
|
602
|
-
@rest_client.
|
602
|
+
expect(@rest_client).not_to receive(:post_rest)
|
603
603
|
@resource_reporter.run_completed(@node)
|
604
604
|
end
|
605
605
|
|
606
606
|
it "prints an error about the 404" do
|
607
|
-
Chef::Log.
|
607
|
+
expect(Chef::Log).to receive(:debug).with(/404/)
|
608
608
|
@resource_reporter.run_started(@run_status)
|
609
609
|
end
|
610
610
|
|
@@ -615,7 +615,7 @@ describe Chef::ResourceReporter do
|
|
615
615
|
# 500 getting the run_id
|
616
616
|
@response = Net::HTTPInternalServerError.new("a response body", "500", "Internal Server Error")
|
617
617
|
@error = Net::HTTPServerException.new("500 message", @response)
|
618
|
-
@rest_client.
|
618
|
+
expect(@rest_client).to receive(:post_rest).
|
619
619
|
with("reports/nodes/spitfire/runs", {:action => :start, :run_id => @run_id, :start_time => @start_time.to_s},
|
620
620
|
{'X-Ops-Reporting-Protocol-Version' => Chef::ResourceReporter::PROTOCOL_VERSION}).
|
621
621
|
and_raise(@error)
|
@@ -623,17 +623,17 @@ describe Chef::ResourceReporter do
|
|
623
623
|
|
624
624
|
it "assumes the feature is not enabled" do
|
625
625
|
@resource_reporter.run_started(@run_status)
|
626
|
-
@resource_reporter.reporting_enabled
|
626
|
+
expect(@resource_reporter.reporting_enabled?).to be_falsey
|
627
627
|
end
|
628
628
|
|
629
629
|
it "does not send a resource report to the server" do
|
630
630
|
@resource_reporter.run_started(@run_status)
|
631
|
-
@rest_client.
|
631
|
+
expect(@rest_client).not_to receive(:post_rest)
|
632
632
|
@resource_reporter.run_completed(@node)
|
633
633
|
end
|
634
634
|
|
635
635
|
it "prints an error about the error" do
|
636
|
-
Chef::Log.
|
636
|
+
expect(Chef::Log).to receive(:info).with(/500/)
|
637
637
|
@resource_reporter.run_started(@run_status)
|
638
638
|
end
|
639
639
|
end
|
@@ -645,7 +645,7 @@ describe Chef::ResourceReporter do
|
|
645
645
|
# 500 getting the run_id
|
646
646
|
@response = Net::HTTPInternalServerError.new("a response body", "500", "Internal Server Error")
|
647
647
|
@error = Net::HTTPServerException.new("500 message", @response)
|
648
|
-
@rest_client.
|
648
|
+
expect(@rest_client).to receive(:post_rest).
|
649
649
|
with("reports/nodes/spitfire/runs", {:action => :start, :run_id => @run_id, :start_time => @start_time.to_s},
|
650
650
|
{'X-Ops-Reporting-Protocol-Version' => Chef::ResourceReporter::PROTOCOL_VERSION}).
|
651
651
|
and_raise(@error)
|
@@ -656,17 +656,17 @@ describe Chef::ResourceReporter do
|
|
656
656
|
end
|
657
657
|
|
658
658
|
it "fails the run and prints an message about the error" do
|
659
|
-
Chef::Log.
|
660
|
-
|
659
|
+
expect(Chef::Log).to receive(:error).with(/500/)
|
660
|
+
expect {
|
661
661
|
@resource_reporter.run_started(@run_status)
|
662
|
-
}.
|
662
|
+
}.to raise_error(Net::HTTPServerException)
|
663
663
|
end
|
664
664
|
end
|
665
665
|
|
666
666
|
context "after creating the run history document" do
|
667
667
|
before do
|
668
668
|
response = {"uri"=>"https://example.com/reports/nodes/spitfire/runs/@run_id"}
|
669
|
-
@rest_client.
|
669
|
+
expect(@rest_client).to receive(:post_rest).
|
670
670
|
with("reports/nodes/spitfire/runs", {:action => :start, :run_id => @run_id, :start_time => @start_time.to_s},
|
671
671
|
{'X-Ops-Reporting-Protocol-Version' => Chef::ResourceReporter::PROTOCOL_VERSION}).
|
672
672
|
and_return(response)
|
@@ -674,7 +674,7 @@ describe Chef::ResourceReporter do
|
|
674
674
|
end
|
675
675
|
|
676
676
|
it "creates a run document on the server at the start of the run" do
|
677
|
-
@resource_reporter.run_id.
|
677
|
+
expect(@resource_reporter.run_id).to eq(@run_id)
|
678
678
|
end
|
679
679
|
|
680
680
|
it "updates the run document with resource updates at the end of the run" do
|
@@ -683,25 +683,25 @@ describe Chef::ResourceReporter do
|
|
683
683
|
@resource_reporter.resource_current_state_loaded(@new_resource, :create, @current_resource)
|
684
684
|
@resource_reporter.resource_updated(@new_resource, :create)
|
685
685
|
|
686
|
-
@resource_reporter.
|
686
|
+
allow(@resource_reporter).to receive(:end_time).and_return(@end_time)
|
687
687
|
@expected_data = @resource_reporter.prepare_run_data
|
688
688
|
|
689
689
|
post_url = "https://chef_server/example_url"
|
690
690
|
response = {"result"=>"ok"}
|
691
691
|
|
692
|
-
@rest_client.
|
692
|
+
expect(@rest_client).to receive(:create_url).
|
693
693
|
with("reports/nodes/spitfire/runs/#{@run_id}").
|
694
694
|
ordered.
|
695
695
|
and_return(post_url)
|
696
|
-
@rest_client.
|
697
|
-
method.
|
698
|
-
url.
|
699
|
-
headers.
|
696
|
+
expect(@rest_client).to receive(:raw_http_request).ordered do |method, url, headers, data|
|
697
|
+
expect(method).to eq(:POST)
|
698
|
+
expect(url).to eq(post_url)
|
699
|
+
expect(headers).to eq({'Content-Encoding' => 'gzip',
|
700
700
|
'X-Ops-Reporting-Protocol-Version' => Chef::ResourceReporter::PROTOCOL_VERSION
|
701
701
|
})
|
702
702
|
data_stream = Zlib::GzipReader.new(StringIO.new(data))
|
703
703
|
data = data_stream.read
|
704
|
-
data.
|
704
|
+
expect(data).to eq(Chef::JSONCompat.to_json(@expected_data))
|
705
705
|
response
|
706
706
|
end
|
707
707
|
|
@@ -714,7 +714,7 @@ describe Chef::ResourceReporter do
|
|
714
714
|
@enable_reporting_url_fatals = Chef::Config[:enable_reporting_url_fatals]
|
715
715
|
Chef::Config[:enable_reporting_url_fatals] = true
|
716
716
|
# this call doesn't matter for this context
|
717
|
-
@rest_client.
|
717
|
+
allow(@rest_client).to receive(:create_url)
|
718
718
|
end
|
719
719
|
|
720
720
|
after do
|
@@ -724,8 +724,8 @@ describe Chef::ResourceReporter do
|
|
724
724
|
it "should log 4xx errors" do
|
725
725
|
response = Net::HTTPClientError.new("forbidden", "403", "Forbidden")
|
726
726
|
error = Net::HTTPServerException.new("403 message", response)
|
727
|
-
@rest_client.
|
728
|
-
Chef::Log.
|
727
|
+
allow(@rest_client).to receive(:raw_http_request).and_raise(error)
|
728
|
+
expect(Chef::Log).to receive(:error).with(/403/)
|
729
729
|
|
730
730
|
@resource_reporter.post_reporting_data
|
731
731
|
end
|
@@ -733,26 +733,26 @@ describe Chef::ResourceReporter do
|
|
733
733
|
it "should log error 5xx errors" do
|
734
734
|
response = Net::HTTPServerError.new("internal error", "500", "Internal Server Error")
|
735
735
|
error = Net::HTTPFatalError.new("500 message", response)
|
736
|
-
@rest_client.
|
737
|
-
Chef::Log.
|
736
|
+
allow(@rest_client).to receive(:raw_http_request).and_raise(error)
|
737
|
+
expect(Chef::Log).to receive(:error).with(/500/)
|
738
738
|
|
739
739
|
@resource_reporter.post_reporting_data
|
740
740
|
end
|
741
741
|
|
742
742
|
it "should log if a socket error happens" do
|
743
|
-
@rest_client.
|
744
|
-
Chef::Log.
|
743
|
+
allow(@rest_client).to receive(:raw_http_request).and_raise(SocketError.new("test socket error"))
|
744
|
+
expect(Chef::Log).to receive(:error).with(/test socket error/)
|
745
745
|
|
746
746
|
@resource_reporter.post_reporting_data
|
747
747
|
|
748
748
|
end
|
749
749
|
|
750
750
|
it "should raise if an unkwown error happens" do
|
751
|
-
@rest_client.
|
751
|
+
allow(@rest_client).to receive(:raw_http_request).and_raise(Exception.new)
|
752
752
|
|
753
|
-
|
753
|
+
expect {
|
754
754
|
@resource_reporter.post_reporting_data
|
755
|
-
}.
|
755
|
+
}.to raise_error(Exception)
|
756
756
|
end
|
757
757
|
end
|
758
758
|
end
|