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
@@ -23,18 +23,18 @@ describe Chef::Cookbook::Chefignore do
|
|
23
23
|
end
|
24
24
|
|
25
25
|
it "loads the globs in the chefignore file" do
|
26
|
-
@chefignore.ignores.
|
26
|
+
expect(@chefignore.ignores).to match_array(%w[recipes/ignoreme.rb ignored])
|
27
27
|
end
|
28
28
|
|
29
29
|
it "removes items from an array that match the ignores" do
|
30
30
|
file_list = %w[ recipes/ignoreme.rb recipes/dontignoreme.rb ]
|
31
|
-
@chefignore.remove_ignores_from(file_list).
|
31
|
+
expect(@chefignore.remove_ignores_from(file_list)).to eq(%w[recipes/dontignoreme.rb])
|
32
32
|
end
|
33
33
|
|
34
34
|
it "determines if a file is ignored" do
|
35
|
-
@chefignore.ignored?('ignored').
|
36
|
-
@chefignore.ignored?('recipes/ignoreme.rb').
|
37
|
-
@chefignore.ignored?('recipes/dontignoreme.rb').
|
35
|
+
expect(@chefignore.ignored?('ignored')).to be_truthy
|
36
|
+
expect(@chefignore.ignored?('recipes/ignoreme.rb')).to be_truthy
|
37
|
+
expect(@chefignore.ignored?('recipes/dontignoreme.rb')).to be_falsey
|
38
38
|
end
|
39
39
|
|
40
40
|
context "when using the single cookbook pattern" do
|
@@ -43,7 +43,7 @@ describe Chef::Cookbook::Chefignore do
|
|
43
43
|
end
|
44
44
|
|
45
45
|
it "loads the globs in the chefignore file" do
|
46
|
-
@chefignore.ignores.
|
46
|
+
expect(@chefignore.ignores).to match_array(%w[recipes/ignoreme.rb ignored vendor/bundle/*])
|
47
47
|
end
|
48
48
|
end
|
49
49
|
end
|
@@ -20,7 +20,7 @@ require 'spec_helper'
|
|
20
20
|
|
21
21
|
describe Chef::Cookbook::CookbookVersionLoader do
|
22
22
|
before do
|
23
|
-
Chef::Platform.
|
23
|
+
allow(Chef::Platform).to receive(:windows?) { false }
|
24
24
|
end
|
25
25
|
|
26
26
|
describe "loading a cookbook" do
|
@@ -74,8 +74,8 @@ describe Chef::Cookbook::CookbookVersionLoader do
|
|
74
74
|
end
|
75
75
|
|
76
76
|
it "should load the metadata for the cookbook" do
|
77
|
-
loaded_cookbook.metadata.name.to_s.
|
78
|
-
loaded_cookbook.metadata.
|
77
|
+
expect(loaded_cookbook.metadata.name.to_s).to eq("openldap")
|
78
|
+
expect(loaded_cookbook.metadata).to be_a_kind_of(Chef::Cookbook::Metadata)
|
79
79
|
end
|
80
80
|
|
81
81
|
context "when a cookbook has ignored files" do
|
@@ -34,7 +34,7 @@ describe Chef::Cookbook::Metadata do
|
|
34
34
|
end
|
35
35
|
|
36
36
|
it "does not depend on object identity for equality" do
|
37
|
-
metadata.
|
37
|
+
expect(metadata).to eq(metadata.dup)
|
38
38
|
end
|
39
39
|
|
40
40
|
it "is not equal to another object if it isn't have all of the metadata fields" do
|
@@ -46,7 +46,7 @@ describe Chef::Cookbook::Metadata do
|
|
46
46
|
setter = "#{field}="
|
47
47
|
metadata_value = metadata.send(field)
|
48
48
|
almost_duck_type.send(setter, metadata_value) if almost_duck_type.respond_to?(setter)
|
49
|
-
@mets.
|
49
|
+
expect(@mets).not_to eq(almost_duck_type)
|
50
50
|
end
|
51
51
|
end
|
52
52
|
end
|
@@ -58,7 +58,7 @@ describe Chef::Cookbook::Metadata do
|
|
58
58
|
metadata_value = metadata.send(field)
|
59
59
|
duck_type.send(setter, metadata_value)
|
60
60
|
end
|
61
|
-
metadata.
|
61
|
+
expect(metadata).to eq(duck_type)
|
62
62
|
end
|
63
63
|
|
64
64
|
it "is not equal if any values are different" do
|
@@ -73,7 +73,7 @@ describe Chef::Cookbook::Metadata do
|
|
73
73
|
end
|
74
74
|
|
75
75
|
duck_type.send("#{field_to_change}=".to_sym, :epic_fail)
|
76
|
-
metadata.
|
76
|
+
expect(metadata).not_to eq(duck_type)
|
77
77
|
end
|
78
78
|
end
|
79
79
|
|
@@ -82,71 +82,71 @@ describe Chef::Cookbook::Metadata do
|
|
82
82
|
describe "when first created" do
|
83
83
|
|
84
84
|
it "has no name" do
|
85
|
-
metadata.name.
|
85
|
+
expect(metadata.name).to eq(nil)
|
86
86
|
end
|
87
87
|
|
88
88
|
it "has an empty description" do
|
89
|
-
metadata.description.
|
89
|
+
expect(metadata.description).to eq("")
|
90
90
|
end
|
91
91
|
|
92
92
|
it "has an empty long description" do
|
93
|
-
metadata.long_description.
|
93
|
+
expect(metadata.long_description).to eq("")
|
94
94
|
end
|
95
95
|
|
96
96
|
it "defaults to 'all rights reserved' license" do
|
97
|
-
metadata.license.
|
97
|
+
expect(metadata.license).to eq("All rights reserved")
|
98
98
|
end
|
99
99
|
|
100
100
|
it "has an empty maintainer field" do
|
101
|
-
metadata.maintainer.
|
101
|
+
expect(metadata.maintainer).to eq(nil)
|
102
102
|
end
|
103
103
|
|
104
104
|
it "has an empty maintainer_email field" do
|
105
|
-
metadata.maintainer.
|
105
|
+
expect(metadata.maintainer).to eq(nil)
|
106
106
|
end
|
107
107
|
|
108
108
|
it "has an empty platforms list" do
|
109
|
-
metadata.platforms.
|
109
|
+
expect(metadata.platforms).to eq(Mash.new)
|
110
110
|
end
|
111
111
|
|
112
112
|
it "has an empty dependencies list" do
|
113
|
-
metadata.dependencies.
|
113
|
+
expect(metadata.dependencies).to eq(Mash.new)
|
114
114
|
end
|
115
115
|
|
116
116
|
it "has an empty recommends list" do
|
117
|
-
metadata.recommendations.
|
117
|
+
expect(metadata.recommendations).to eq(Mash.new)
|
118
118
|
end
|
119
119
|
|
120
120
|
it "has an empty suggestions list" do
|
121
|
-
metadata.suggestions.
|
121
|
+
expect(metadata.suggestions).to eq(Mash.new)
|
122
122
|
end
|
123
123
|
|
124
124
|
it "has an empty conflicts list" do
|
125
|
-
metadata.conflicting.
|
125
|
+
expect(metadata.conflicting).to eq(Mash.new)
|
126
126
|
end
|
127
127
|
|
128
128
|
it "has an empty replaces list" do
|
129
|
-
metadata.replacing.
|
129
|
+
expect(metadata.replacing).to eq(Mash.new)
|
130
130
|
end
|
131
131
|
|
132
132
|
it "has an empty attributes list" do
|
133
|
-
metadata.attributes.
|
133
|
+
expect(metadata.attributes).to eq(Mash.new)
|
134
134
|
end
|
135
135
|
|
136
136
|
it "has an empty groupings list" do
|
137
|
-
metadata.groupings.
|
137
|
+
expect(metadata.groupings).to eq(Mash.new)
|
138
138
|
end
|
139
139
|
|
140
140
|
it "has an empty recipes list" do
|
141
|
-
metadata.recipes.
|
141
|
+
expect(metadata.recipes).to eq(Mash.new)
|
142
142
|
end
|
143
143
|
|
144
144
|
it "has an empty source_url string" do
|
145
|
-
metadata.source_url.
|
145
|
+
expect(metadata.source_url).to eq('')
|
146
146
|
end
|
147
147
|
|
148
148
|
it "has an empty issues_url string" do
|
149
|
-
metadata.issues_url.
|
149
|
+
expect(metadata.issues_url).to eq('')
|
150
150
|
end
|
151
151
|
end
|
152
152
|
|
@@ -155,12 +155,12 @@ describe Chef::Cookbook::Metadata do
|
|
155
155
|
context "when no required fields are set" do
|
156
156
|
|
157
157
|
it "is not valid" do
|
158
|
-
metadata.
|
158
|
+
expect(metadata).not_to be_valid
|
159
159
|
end
|
160
160
|
|
161
161
|
it "has a list of validation errors" do
|
162
162
|
expected_errors = ["The `name' attribute is required in cookbook metadata"]
|
163
|
-
metadata.errors.
|
163
|
+
expect(metadata.errors).to eq(expected_errors)
|
164
164
|
end
|
165
165
|
|
166
166
|
end
|
@@ -171,11 +171,11 @@ describe Chef::Cookbook::Metadata do
|
|
171
171
|
end
|
172
172
|
|
173
173
|
it "is valid" do
|
174
|
-
metadata.
|
174
|
+
expect(metadata).to be_valid
|
175
175
|
end
|
176
176
|
|
177
177
|
it "has no validation errors" do
|
178
|
-
metadata.errors.
|
178
|
+
expect(metadata.errors).to be_empty
|
179
179
|
end
|
180
180
|
|
181
181
|
end
|
@@ -185,7 +185,7 @@ describe Chef::Cookbook::Metadata do
|
|
185
185
|
describe "adding a supported platform" do
|
186
186
|
it "should support adding a supported platform with a single expression" do
|
187
187
|
metadata.supports("ubuntu", ">= 8.04")
|
188
|
-
metadata.platforms["ubuntu"].
|
188
|
+
expect(metadata.platforms["ubuntu"]).to eq('>= 8.04')
|
189
189
|
end
|
190
190
|
end
|
191
191
|
|
@@ -203,23 +203,23 @@ describe Chef::Cookbook::Metadata do
|
|
203
203
|
params.sort { |a,b| a.to_s <=> b.to_s }.each do |field, field_value|
|
204
204
|
describe field do
|
205
205
|
it "should be set-able via #{field}" do
|
206
|
-
metadata.send(field, field_value).
|
206
|
+
expect(metadata.send(field, field_value)).to eql(field_value)
|
207
207
|
end
|
208
208
|
it "should be get-able via #{field}" do
|
209
209
|
metadata.send(field, field_value)
|
210
|
-
metadata.send(field).
|
210
|
+
expect(metadata.send(field)).to eql(field_value)
|
211
211
|
end
|
212
212
|
end
|
213
213
|
end
|
214
214
|
|
215
215
|
describe "version transformation" do
|
216
216
|
it "should transform an '0.6' version to '0.6.0'" do
|
217
|
-
metadata.send(:version, "0.6").
|
217
|
+
expect(metadata.send(:version, "0.6")).to eql("0.6.0")
|
218
218
|
end
|
219
219
|
|
220
220
|
it "should spit out '0.6.0' after transforming '0.6'" do
|
221
221
|
metadata.send(:version, "0.6")
|
222
|
-
metadata.send(:version).
|
222
|
+
expect(metadata.send(:version)).to eql("0.6.0")
|
223
223
|
end
|
224
224
|
end
|
225
225
|
end
|
@@ -238,11 +238,11 @@ describe Chef::Cookbook::Metadata do
|
|
238
238
|
check_with = dep_args.shift
|
239
239
|
describe dep do
|
240
240
|
it "should be set-able via #{dep}" do
|
241
|
-
metadata.send(dep, *dep_args).
|
241
|
+
expect(metadata.send(dep, *dep_args)).to eq(dep_args[1])
|
242
242
|
end
|
243
243
|
it "should be get-able via #{check_with}" do
|
244
244
|
metadata.send(dep, *dep_args)
|
245
|
-
metadata.send(check_with).
|
245
|
+
expect(metadata.send(check_with)).to eq({ dep_args[0] => dep_args[1] })
|
246
246
|
end
|
247
247
|
end
|
248
248
|
end
|
@@ -260,11 +260,11 @@ describe Chef::Cookbook::Metadata do
|
|
260
260
|
normalized_version = dep_args.pop
|
261
261
|
describe dep do
|
262
262
|
it "should be set-able and normalized via #{dep}" do
|
263
|
-
metadata.send(dep, *dep_args).
|
263
|
+
expect(metadata.send(dep, *dep_args)).to eq(normalized_version)
|
264
264
|
end
|
265
265
|
it "should be get-able and normalized via #{check_with}" do
|
266
266
|
metadata.send(dep, *dep_args)
|
267
|
-
metadata.send(check_with).
|
267
|
+
expect(metadata.send(check_with)).to eq({ dep_args[0] => normalized_version })
|
268
268
|
end
|
269
269
|
end
|
270
270
|
end
|
@@ -282,7 +282,7 @@ describe Chef::Cookbook::Metadata do
|
|
282
282
|
|
283
283
|
dep_types.each do |dep, dep_args|
|
284
284
|
it "for #{dep} raises an informative error instead of vomiting on your shoes" do
|
285
|
-
|
285
|
+
expect {metadata.send(dep, *dep_args)}.to raise_error(Chef::Exceptions::ObsoleteDependencySyntax)
|
286
286
|
end
|
287
287
|
end
|
288
288
|
end
|
@@ -300,7 +300,7 @@ describe Chef::Cookbook::Metadata do
|
|
300
300
|
|
301
301
|
dep_types.each do |dep, dep_args|
|
302
302
|
it "for #{dep} raises an informative error instead of vomiting on your shoes" do
|
303
|
-
|
303
|
+
expect {metadata.send(dep, *dep_args)}.to raise_error(Chef::Exceptions::InvalidVersionConstraint)
|
304
304
|
end
|
305
305
|
end
|
306
306
|
end
|
@@ -312,24 +312,24 @@ describe Chef::Cookbook::Metadata do
|
|
312
312
|
"title" => "MySQL Tuning",
|
313
313
|
"description" => "Setting from the my.cnf file that allow you to tune your mysql server"
|
314
314
|
}
|
315
|
-
metadata.grouping("/db/mysql/databases/tuning", group).
|
315
|
+
expect(metadata.grouping("/db/mysql/databases/tuning", group)).to eq(group)
|
316
316
|
end
|
317
317
|
it "should not accept anything but a string for display_name" do
|
318
|
-
|
318
|
+
expect {
|
319
319
|
metadata.grouping("db/mysql/databases", :title => "foo")
|
320
|
-
}.
|
321
|
-
|
320
|
+
}.not_to raise_error
|
321
|
+
expect {
|
322
322
|
metadata.grouping("db/mysql/databases", :title => Hash.new)
|
323
|
-
}.
|
323
|
+
}.to raise_error(ArgumentError)
|
324
324
|
end
|
325
325
|
|
326
326
|
it "should not accept anything but a string for the description" do
|
327
|
-
|
327
|
+
expect {
|
328
328
|
metadata.grouping("db/mysql/databases", :description => "foo")
|
329
|
-
}.
|
330
|
-
|
329
|
+
}.not_to raise_error
|
330
|
+
expect {
|
331
331
|
metadata.grouping("db/mysql/databases", :description => Hash.new)
|
332
|
-
}.
|
332
|
+
}.to raise_error(ArgumentError)
|
333
333
|
end
|
334
334
|
end
|
335
335
|
|
@@ -347,170 +347,170 @@ describe Chef::Cookbook::Metadata do
|
|
347
347
|
"source_url" => "http://example.com",
|
348
348
|
"issues_url" => "http://example.com/issues"
|
349
349
|
}
|
350
|
-
metadata.attribute("/db/mysql/databases", attrs).
|
350
|
+
expect(metadata.attribute("/db/mysql/databases", attrs)).to eq(attrs)
|
351
351
|
end
|
352
352
|
|
353
353
|
it "should not accept anything but a string for display_name" do
|
354
|
-
|
354
|
+
expect {
|
355
355
|
metadata.attribute("db/mysql/databases", :display_name => "foo")
|
356
|
-
}.
|
357
|
-
|
356
|
+
}.not_to raise_error
|
357
|
+
expect {
|
358
358
|
metadata.attribute("db/mysql/databases", :display_name => Hash.new)
|
359
|
-
}.
|
359
|
+
}.to raise_error(ArgumentError)
|
360
360
|
end
|
361
361
|
|
362
362
|
it "should not accept anything but a string for the description" do
|
363
|
-
|
363
|
+
expect {
|
364
364
|
metadata.attribute("db/mysql/databases", :description => "foo")
|
365
|
-
}.
|
366
|
-
|
365
|
+
}.not_to raise_error
|
366
|
+
expect {
|
367
367
|
metadata.attribute("db/mysql/databases", :description => Hash.new)
|
368
|
-
}.
|
368
|
+
}.to raise_error(ArgumentError)
|
369
369
|
end
|
370
370
|
|
371
371
|
it "should not accept anything but a string for the source_url" do
|
372
|
-
|
372
|
+
expect {
|
373
373
|
metadata.attribute("db/mysql/databases", :source_url => "foo")
|
374
|
-
}.
|
375
|
-
|
374
|
+
}.not_to raise_error
|
375
|
+
expect {
|
376
376
|
metadata.attribute("db/mysql/databases", :source_url => Hash.new)
|
377
|
-
}.
|
377
|
+
}.to raise_error(ArgumentError)
|
378
378
|
end
|
379
379
|
|
380
380
|
it "should not accept anything but a string for the issues_url" do
|
381
|
-
|
381
|
+
expect {
|
382
382
|
metadata.attribute("db/mysql/databases", :issues_url => "foo")
|
383
|
-
}.
|
384
|
-
|
383
|
+
}.not_to raise_error
|
384
|
+
expect {
|
385
385
|
metadata.attribute("db/mysql/databases", :issues_url => Hash.new)
|
386
|
-
}.
|
386
|
+
}.to raise_error(ArgumentError)
|
387
387
|
end
|
388
388
|
|
389
389
|
it "should not accept anything but an array of strings for choice" do
|
390
|
-
|
390
|
+
expect {
|
391
391
|
metadata.attribute("db/mysql/databases", :choice => ['dedicated', 'shared'])
|
392
|
-
}.
|
393
|
-
|
392
|
+
}.not_to raise_error
|
393
|
+
expect {
|
394
394
|
metadata.attribute("db/mysql/databases", :choice => [10, 'shared'])
|
395
|
-
}.
|
396
|
-
|
395
|
+
}.to raise_error(ArgumentError)
|
396
|
+
expect {
|
397
397
|
metadata.attribute("db/mysql/databases", :choice => Hash.new)
|
398
|
-
}.
|
398
|
+
}.to raise_error(ArgumentError)
|
399
399
|
end
|
400
400
|
|
401
401
|
it "should set choice to empty array by default" do
|
402
402
|
metadata.attribute("db/mysql/databases", {})
|
403
|
-
metadata.attributes["db/mysql/databases"][:choice].
|
403
|
+
expect(metadata.attributes["db/mysql/databases"][:choice]).to eq([])
|
404
404
|
end
|
405
405
|
|
406
406
|
it "should let calculated be true or false" do
|
407
|
-
|
407
|
+
expect {
|
408
408
|
metadata.attribute("db/mysql/databases", :calculated => true)
|
409
|
-
}.
|
410
|
-
|
409
|
+
}.not_to raise_error
|
410
|
+
expect {
|
411
411
|
metadata.attribute("db/mysql/databases", :calculated => false)
|
412
|
-
}.
|
413
|
-
|
412
|
+
}.not_to raise_error
|
413
|
+
expect {
|
414
414
|
metadata.attribute("db/mysql/databases", :calculated => Hash.new)
|
415
|
-
}.
|
415
|
+
}.to raise_error(ArgumentError)
|
416
416
|
end
|
417
417
|
|
418
418
|
it "should set calculated to false by default" do
|
419
419
|
metadata.attribute("db/mysql/databases", {})
|
420
|
-
metadata.attributes["db/mysql/databases"][:calculated].
|
420
|
+
expect(metadata.attributes["db/mysql/databases"][:calculated]).to eq(false)
|
421
421
|
end
|
422
422
|
|
423
423
|
it "accepts String for the attribute type" do
|
424
|
-
|
424
|
+
expect {
|
425
425
|
metadata.attribute("db/mysql/databases", :type => "string")
|
426
|
-
}.
|
426
|
+
}.not_to raise_error
|
427
427
|
end
|
428
428
|
|
429
429
|
it "accepts Array for the attribute type" do
|
430
|
-
|
430
|
+
expect {
|
431
431
|
metadata.attribute("db/mysql/databases", :type => "array")
|
432
|
-
}.
|
433
|
-
|
432
|
+
}.not_to raise_error
|
433
|
+
expect {
|
434
434
|
metadata.attribute("db/mysql/databases", :type => Array.new)
|
435
|
-
}.
|
435
|
+
}.to raise_error(ArgumentError)
|
436
436
|
end
|
437
437
|
|
438
438
|
it "accepts symbol for the attribute type" do
|
439
|
-
|
439
|
+
expect {
|
440
440
|
metadata.attribute("db/mysql/databases", :type => "symbol")
|
441
|
-
}.
|
441
|
+
}.not_to raise_error
|
442
442
|
end
|
443
443
|
|
444
|
-
it "should let type be hash (backwards
|
445
|
-
|
444
|
+
it "should let type be hash (backwards compatibility only)" do
|
445
|
+
expect {
|
446
446
|
metadata.attribute("db/mysql/databases", :type => "hash")
|
447
|
-
}.
|
447
|
+
}.not_to raise_error
|
448
448
|
end
|
449
449
|
|
450
450
|
it "should let required be required, recommended or optional" do
|
451
|
-
|
451
|
+
expect {
|
452
452
|
metadata.attribute("db/mysql/databases", :required => 'required')
|
453
|
-
}.
|
454
|
-
|
453
|
+
}.not_to raise_error
|
454
|
+
expect {
|
455
455
|
metadata.attribute("db/mysql/databases", :required => 'recommended')
|
456
|
-
}.
|
457
|
-
|
456
|
+
}.not_to raise_error
|
457
|
+
expect {
|
458
458
|
metadata.attribute("db/mysql/databases", :required => 'optional')
|
459
|
-
}.
|
459
|
+
}.not_to raise_error
|
460
460
|
end
|
461
461
|
|
462
462
|
it "should convert required true to required" do
|
463
|
-
|
463
|
+
expect {
|
464
464
|
metadata.attribute("db/mysql/databases", :required => true)
|
465
|
-
}.
|
465
|
+
}.not_to raise_error
|
466
466
|
#attrib = metadata.attributes["db/mysql/databases"][:required].should == "required"
|
467
467
|
end
|
468
468
|
|
469
469
|
it "should convert required false to optional" do
|
470
|
-
|
470
|
+
expect {
|
471
471
|
metadata.attribute("db/mysql/databases", :required => false)
|
472
|
-
}.
|
472
|
+
}.not_to raise_error
|
473
473
|
#attrib = metadata.attributes["db/mysql/databases"][:required].should == "optional"
|
474
474
|
end
|
475
475
|
|
476
476
|
it "should set required to 'optional' by default" do
|
477
477
|
metadata.attribute("db/mysql/databases", {})
|
478
|
-
metadata.attributes["db/mysql/databases"][:required].
|
478
|
+
expect(metadata.attributes["db/mysql/databases"][:required]).to eq('optional')
|
479
479
|
end
|
480
480
|
|
481
481
|
it "should make sure recipes is an array" do
|
482
|
-
|
482
|
+
expect {
|
483
483
|
metadata.attribute("db/mysql/databases", :recipes => [])
|
484
|
-
}.
|
485
|
-
|
484
|
+
}.not_to raise_error
|
485
|
+
expect {
|
486
486
|
metadata.attribute("db/mysql/databases", :required => Hash.new)
|
487
|
-
}.
|
487
|
+
}.to raise_error(ArgumentError)
|
488
488
|
end
|
489
489
|
|
490
490
|
it "should set recipes to an empty array by default" do
|
491
491
|
metadata.attribute("db/mysql/databases", {})
|
492
|
-
metadata.attributes["db/mysql/databases"][:recipes].
|
492
|
+
expect(metadata.attributes["db/mysql/databases"][:recipes]).to eq([])
|
493
493
|
end
|
494
494
|
|
495
495
|
it "should allow the default value to be a string, array, hash, boolean or numeric" do
|
496
|
-
|
496
|
+
expect {
|
497
497
|
metadata.attribute("db/mysql/databases", :default => [])
|
498
|
-
}.
|
499
|
-
|
498
|
+
}.not_to raise_error
|
499
|
+
expect {
|
500
500
|
metadata.attribute("db/mysql/databases", :default => {})
|
501
|
-
}.
|
502
|
-
|
501
|
+
}.not_to raise_error
|
502
|
+
expect {
|
503
503
|
metadata.attribute("db/mysql/databases", :default => "alice in chains")
|
504
|
-
}.
|
505
|
-
|
504
|
+
}.not_to raise_error
|
505
|
+
expect {
|
506
506
|
metadata.attribute("db/mysql/databases", :default => 1337)
|
507
|
-
}.
|
508
|
-
|
507
|
+
}.not_to raise_error
|
508
|
+
expect {
|
509
509
|
metadata.attribute("db/mysql/databases", :default => true)
|
510
|
-
}.
|
511
|
-
|
510
|
+
}.not_to raise_error
|
511
|
+
expect {
|
512
512
|
metadata.attribute("db/mysql/databases", :required => :not_gonna_do_it)
|
513
|
-
}.
|
513
|
+
}.to raise_error(ArgumentError)
|
514
514
|
end
|
515
515
|
|
516
516
|
it "should limit the types allowed in the choice array" do
|
@@ -519,87 +519,87 @@ describe Chef::Cookbook::Metadata do
|
|
519
519
|
:choice => [ "test1", "test2" ],
|
520
520
|
:default => "test1"
|
521
521
|
}
|
522
|
-
|
522
|
+
expect {
|
523
523
|
metadata.attribute("test_cookbook/test", options)
|
524
|
-
}.
|
524
|
+
}.not_to raise_error
|
525
525
|
|
526
526
|
options = {
|
527
527
|
:type => "boolean",
|
528
528
|
:choice => [ true, false ],
|
529
529
|
:default => true
|
530
530
|
}
|
531
|
-
|
531
|
+
expect {
|
532
532
|
metadata.attribute("test_cookbook/test", options)
|
533
|
-
}.
|
533
|
+
}.not_to raise_error
|
534
534
|
|
535
535
|
options = {
|
536
536
|
:type => "numeric",
|
537
537
|
:choice => [ 1337, 420 ],
|
538
538
|
:default => 1337
|
539
539
|
}
|
540
|
-
|
540
|
+
expect {
|
541
541
|
metadata.attribute("test_cookbook/test", options)
|
542
|
-
}.
|
542
|
+
}.not_to raise_error
|
543
543
|
|
544
544
|
options = {
|
545
545
|
:type => "numeric",
|
546
546
|
:choice => [ true, "false" ],
|
547
547
|
:default => false
|
548
548
|
}
|
549
|
-
|
549
|
+
expect {
|
550
550
|
metadata.attribute("test_cookbook/test", options)
|
551
|
-
}.
|
551
|
+
}.to raise_error
|
552
552
|
end
|
553
553
|
|
554
554
|
it "should error if default used with calculated" do
|
555
|
-
|
555
|
+
expect {
|
556
556
|
attrs = {
|
557
557
|
:calculated => true,
|
558
558
|
:default => [ "I thought you said calculated" ]
|
559
559
|
}
|
560
560
|
metadata.attribute("db/mysql/databases", attrs)
|
561
|
-
}.
|
562
|
-
|
561
|
+
}.to raise_error(ArgumentError)
|
562
|
+
expect {
|
563
563
|
attrs = {
|
564
564
|
:calculated => true,
|
565
565
|
:default => "I thought you said calculated"
|
566
566
|
}
|
567
567
|
metadata.attribute("db/mysql/databases", attrs)
|
568
|
-
}.
|
568
|
+
}.to raise_error(ArgumentError)
|
569
569
|
end
|
570
570
|
|
571
571
|
it "should allow a default that is a choice" do
|
572
|
-
|
572
|
+
expect {
|
573
573
|
attrs = {
|
574
574
|
:choice => [ "a", "b", "c"],
|
575
575
|
:default => "b"
|
576
576
|
}
|
577
577
|
metadata.attribute("db/mysql/databases", attrs)
|
578
|
-
}.
|
579
|
-
|
578
|
+
}.not_to raise_error
|
579
|
+
expect {
|
580
580
|
attrs = {
|
581
581
|
:choice => [ "a", "b", "c", "d", "e"],
|
582
582
|
:default => ["b", "d"]
|
583
583
|
}
|
584
584
|
metadata.attribute("db/mysql/databases", attrs)
|
585
|
-
}.
|
585
|
+
}.not_to raise_error
|
586
586
|
end
|
587
587
|
|
588
588
|
it "should error if default is not a choice" do
|
589
|
-
|
589
|
+
expect {
|
590
590
|
attrs = {
|
591
591
|
:choice => [ "a", "b", "c"],
|
592
592
|
:default => "d"
|
593
593
|
}
|
594
594
|
metadata.attribute("db/mysql/databases", attrs)
|
595
|
-
}.
|
596
|
-
|
595
|
+
}.to raise_error(ArgumentError)
|
596
|
+
expect {
|
597
597
|
attrs = {
|
598
598
|
:choice => [ "a", "b", "c", "d", "e"],
|
599
599
|
:default => ["b", "z"]
|
600
600
|
}
|
601
601
|
metadata.attribute("db/mysql/databases", attrs)
|
602
|
-
}.
|
602
|
+
}.to raise_error(ArgumentError)
|
603
603
|
end
|
604
604
|
end
|
605
605
|
|
@@ -616,18 +616,18 @@ describe Chef::Cookbook::Metadata do
|
|
616
616
|
end
|
617
617
|
|
618
618
|
it "should have the names of the recipes" do
|
619
|
-
metadata.recipes["test_cookbook"].
|
620
|
-
metadata.recipes["test_cookbook::enlighten"].
|
619
|
+
expect(metadata.recipes["test_cookbook"]).to eq("")
|
620
|
+
expect(metadata.recipes["test_cookbook::enlighten"]).to eq("")
|
621
621
|
end
|
622
622
|
|
623
623
|
it "should let you set the description for a recipe" do
|
624
624
|
metadata.recipe "test_cookbook", "It, um... tests stuff?"
|
625
|
-
metadata.recipes["test_cookbook"].
|
625
|
+
expect(metadata.recipes["test_cookbook"]).to eq("It, um... tests stuff?")
|
626
626
|
end
|
627
627
|
|
628
628
|
it "should automatically provide each recipe" do
|
629
|
-
metadata.providing.has_key?("test_cookbook").
|
630
|
-
metadata.providing.has_key?("test_cookbook::enlighten").
|
629
|
+
expect(metadata.providing.has_key?("test_cookbook")).to eq(true)
|
630
|
+
expect(metadata.providing.has_key?("test_cookbook::enlighten")).to eq(true)
|
631
631
|
end
|
632
632
|
|
633
633
|
end
|
@@ -662,7 +662,7 @@ describe Chef::Cookbook::Metadata do
|
|
662
662
|
let(:deserialized_metadata) { Chef::JSONCompat.from_json(Chef::JSONCompat.to_json(metadata)) }
|
663
663
|
|
664
664
|
it "should serialize to a json hash" do
|
665
|
-
deserialized_metadata.
|
665
|
+
expect(deserialized_metadata).to be_a_kind_of(Hash)
|
666
666
|
end
|
667
667
|
|
668
668
|
%w{
|
@@ -686,7 +686,7 @@ describe Chef::Cookbook::Metadata do
|
|
686
686
|
issues_url
|
687
687
|
}.each do |t|
|
688
688
|
it "should include '#{t}'" do
|
689
|
-
deserialized_metadata[t].
|
689
|
+
expect(deserialized_metadata[t]).to eq(metadata.send(t.to_sym))
|
690
690
|
end
|
691
691
|
end
|
692
692
|
end
|
@@ -697,7 +697,7 @@ describe Chef::Cookbook::Metadata do
|
|
697
697
|
|
698
698
|
|
699
699
|
it "should deserialize to a Chef::Cookbook::Metadata object" do
|
700
|
-
deserialized_metadata.
|
700
|
+
expect(deserialized_metadata).to be_a_kind_of(Chef::Cookbook::Metadata)
|
701
701
|
end
|
702
702
|
|
703
703
|
%w{
|
@@ -721,7 +721,7 @@ describe Chef::Cookbook::Metadata do
|
|
721
721
|
issues_url
|
722
722
|
}.each do |t|
|
723
723
|
it "should match '#{t}'" do
|
724
|
-
deserialized_metadata.send(t.to_sym).
|
724
|
+
expect(deserialized_metadata.send(t.to_sym)).to eq(metadata.send(t.to_sym))
|
725
725
|
end
|
726
726
|
end
|
727
727
|
end
|
@@ -739,31 +739,31 @@ describe Chef::Cookbook::Metadata do
|
|
739
739
|
it "should transform deprecated greater than syntax for :#{to_check.to_s}" do
|
740
740
|
@hash[to_check.to_s]["foo::bar"] = ">> 0.2"
|
741
741
|
deserial = Chef::Cookbook::Metadata.from_hash(@hash)
|
742
|
-
deserial.send(to_check)["foo::bar"].
|
742
|
+
expect(deserial.send(to_check)["foo::bar"]).to eq('> 0.2')
|
743
743
|
end
|
744
744
|
|
745
745
|
it "should transform deprecated less than syntax for :#{to_check.to_s}" do
|
746
746
|
@hash[to_check.to_s]["foo::bar"] = "<< 0.2"
|
747
747
|
deserial = Chef::Cookbook::Metadata.from_hash(@hash)
|
748
|
-
deserial.send(to_check)["foo::bar"].
|
748
|
+
expect(deserial.send(to_check)["foo::bar"]).to eq('< 0.2')
|
749
749
|
end
|
750
750
|
|
751
751
|
it "should ignore multiple dependency constraints for :#{to_check.to_s}" do
|
752
752
|
@hash[to_check.to_s]["foo::bar"] = [ ">= 1.0", "<= 5.2" ]
|
753
753
|
deserial = Chef::Cookbook::Metadata.from_hash(@hash)
|
754
|
-
deserial.send(to_check)["foo::bar"].
|
754
|
+
expect(deserial.send(to_check)["foo::bar"]).to eq([])
|
755
755
|
end
|
756
756
|
|
757
757
|
it "should accept an empty array of dependency constraints for :#{to_check.to_s}" do
|
758
758
|
@hash[to_check.to_s]["foo::bar"] = []
|
759
759
|
deserial = Chef::Cookbook::Metadata.from_hash(@hash)
|
760
|
-
deserial.send(to_check)["foo::bar"].
|
760
|
+
expect(deserial.send(to_check)["foo::bar"]).to eq([])
|
761
761
|
end
|
762
762
|
|
763
763
|
it "should accept single-element arrays of dependency constraints for :#{to_check.to_s}" do
|
764
764
|
@hash[to_check.to_s]["foo::bar"] = [ ">= 2.0" ]
|
765
765
|
deserial = Chef::Cookbook::Metadata.from_hash(@hash)
|
766
|
-
deserial.send(to_check)["foo::bar"].
|
766
|
+
expect(deserial.send(to_check)["foo::bar"]).to eq(">= 2.0")
|
767
767
|
end
|
768
768
|
end
|
769
769
|
end
|