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
@@ -41,9 +41,7 @@ describe Chef::Knife::Exec do
|
|
41
41
|
@server.stop
|
42
42
|
end
|
43
43
|
|
44
|
-
|
45
|
-
|
46
|
-
it "executes a script in the context of the chef-shell main context", :ruby_gte_19_only do
|
44
|
+
it "executes a script in the context of the chef-shell main context" do
|
47
45
|
@node = Chef::Node.new
|
48
46
|
@node.name("ohai-world")
|
49
47
|
response = {"rows" => [@node],"start" => 0,"total" => 1}
|
@@ -51,7 +49,7 @@ describe Chef::Knife::Exec do
|
|
51
49
|
code = "$output.puts nodes.all"
|
52
50
|
@knife.config[:exec] = code
|
53
51
|
@knife.run
|
54
|
-
$output.string.
|
52
|
+
expect($output.string).to match(%r{node\[ohai-world\]})
|
55
53
|
end
|
56
54
|
|
57
55
|
end
|
@@ -40,7 +40,7 @@ describe Chef::Knife::Ssh do
|
|
40
40
|
|
41
41
|
it "uses the ssh_identity_file" do
|
42
42
|
@knife.run
|
43
|
-
@knife.config[:identity_file].
|
43
|
+
expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
|
44
44
|
end
|
45
45
|
end
|
46
46
|
|
@@ -52,7 +52,7 @@ describe Chef::Knife::Ssh do
|
|
52
52
|
|
53
53
|
it "uses the ssh_identity_file" do
|
54
54
|
@knife.run
|
55
|
-
@knife.config[:identity_file].
|
55
|
+
expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
|
56
56
|
end
|
57
57
|
end
|
58
58
|
|
@@ -64,13 +64,13 @@ describe Chef::Knife::Ssh do
|
|
64
64
|
|
65
65
|
it "should use the value on the command line" do
|
66
66
|
@knife.run
|
67
|
-
@knife.config[:identity_file].
|
67
|
+
expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
|
68
68
|
end
|
69
69
|
|
70
70
|
it "should override what is set in knife.rb" do
|
71
71
|
Chef::Config[:knife][:ssh_identity_file] = "~/.ssh/other.rsa"
|
72
72
|
@knife.run
|
73
|
-
@knife.config[:identity_file].
|
73
|
+
expect(@knife.config[:identity_file]).to eq("~/.ssh/aws.rsa")
|
74
74
|
end
|
75
75
|
end
|
76
76
|
|
@@ -82,7 +82,7 @@ describe Chef::Knife::Ssh do
|
|
82
82
|
|
83
83
|
it "uses the default" do
|
84
84
|
@knife.run
|
85
|
-
@knife.config[:identity_file].
|
85
|
+
expect(@knife.config[:identity_file]).to eq(nil)
|
86
86
|
end
|
87
87
|
end
|
88
88
|
end
|
@@ -95,7 +95,7 @@ describe Chef::Knife::Ssh do
|
|
95
95
|
|
96
96
|
it "uses the ssh_port" do
|
97
97
|
@knife.run
|
98
|
-
@knife.config[:ssh_port].
|
98
|
+
expect(@knife.config[:ssh_port]).to eq("31337")
|
99
99
|
end
|
100
100
|
end
|
101
101
|
end
|
@@ -109,7 +109,7 @@ describe Chef::Knife::Ssh do
|
|
109
109
|
|
110
110
|
it "uses the ssh_user" do
|
111
111
|
@knife.run
|
112
|
-
@knife.config[:ssh_user].
|
112
|
+
expect(@knife.config[:ssh_user]).to eq("ubuntu")
|
113
113
|
end
|
114
114
|
end
|
115
115
|
|
@@ -121,7 +121,7 @@ describe Chef::Knife::Ssh do
|
|
121
121
|
|
122
122
|
it "uses the ssh_user" do
|
123
123
|
@knife.run
|
124
|
-
@knife.config[:ssh_user].
|
124
|
+
expect(@knife.config[:ssh_user]).to eq("ubuntu")
|
125
125
|
end
|
126
126
|
end
|
127
127
|
|
@@ -133,13 +133,13 @@ describe Chef::Knife::Ssh do
|
|
133
133
|
|
134
134
|
it "should use the value on the command line" do
|
135
135
|
@knife.run
|
136
|
-
@knife.config[:ssh_user].
|
136
|
+
expect(@knife.config[:ssh_user]).to eq("ubuntu")
|
137
137
|
end
|
138
138
|
|
139
139
|
it "should override what is set in knife.rb" do
|
140
140
|
Chef::Config[:knife][:ssh_user] = "root"
|
141
141
|
@knife.run
|
142
|
-
@knife.config[:ssh_user].
|
142
|
+
expect(@knife.config[:ssh_user]).to eq("ubuntu")
|
143
143
|
end
|
144
144
|
end
|
145
145
|
|
@@ -151,7 +151,7 @@ describe Chef::Knife::Ssh do
|
|
151
151
|
|
152
152
|
it "uses the default (current user)" do
|
153
153
|
@knife.run
|
154
|
-
@knife.config[:ssh_user].
|
154
|
+
expect(@knife.config[:ssh_user]).to eq(nil)
|
155
155
|
end
|
156
156
|
end
|
157
157
|
end
|
@@ -165,7 +165,7 @@ describe Chef::Knife::Ssh do
|
|
165
165
|
|
166
166
|
it "uses the ssh_attribute" do
|
167
167
|
@knife.run
|
168
|
-
@knife.config[:attribute].
|
168
|
+
expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
|
169
169
|
end
|
170
170
|
end
|
171
171
|
|
@@ -177,7 +177,7 @@ describe Chef::Knife::Ssh do
|
|
177
177
|
|
178
178
|
it "uses the default" do
|
179
179
|
@knife.run
|
180
|
-
@knife.config[:attribute].
|
180
|
+
expect(@knife.config[:attribute]).to eq("fqdn")
|
181
181
|
end
|
182
182
|
end
|
183
183
|
|
@@ -189,7 +189,7 @@ describe Chef::Knife::Ssh do
|
|
189
189
|
|
190
190
|
it "should use the value on the command line" do
|
191
191
|
@knife.run
|
192
|
-
@knife.config[:attribute].
|
192
|
+
expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
|
193
193
|
end
|
194
194
|
|
195
195
|
it "should override what is set in knife.rb" do
|
@@ -198,7 +198,7 @@ describe Chef::Knife::Ssh do
|
|
198
198
|
# Then we run knife with the -a flag, which sets the above variable
|
199
199
|
setup_knife(['-a ec2.public_hostname', '*:*', 'uptime'])
|
200
200
|
@knife.run
|
201
|
-
@knife.config[:attribute].
|
201
|
+
expect(@knife.config[:attribute]).to eq("ec2.public_hostname")
|
202
202
|
end
|
203
203
|
end
|
204
204
|
end
|
@@ -211,9 +211,9 @@ describe Chef::Knife::Ssh do
|
|
211
211
|
end
|
212
212
|
|
213
213
|
it "uses the ssh_gateway" do
|
214
|
-
@knife.session.
|
214
|
+
expect(@knife.session).to receive(:via).with("ec2.public_hostname", "user", {})
|
215
215
|
@knife.run
|
216
|
-
@knife.config[:ssh_gateway].
|
216
|
+
expect(@knife.config[:ssh_gateway]).to eq("user@ec2.public_hostname")
|
217
217
|
end
|
218
218
|
end
|
219
219
|
|
@@ -224,9 +224,9 @@ describe Chef::Knife::Ssh do
|
|
224
224
|
end
|
225
225
|
|
226
226
|
it "uses the ssh_gateway" do
|
227
|
-
@knife.session.
|
227
|
+
expect(@knife.session).to receive(:via).with("ec2.public_hostname", "user", {})
|
228
228
|
@knife.run
|
229
|
-
@knife.config[:ssh_gateway].
|
229
|
+
expect(@knife.config[:ssh_gateway]).to eq("user@ec2.public_hostname")
|
230
230
|
end
|
231
231
|
end
|
232
232
|
|
@@ -234,13 +234,13 @@ describe Chef::Knife::Ssh do
|
|
234
234
|
before do
|
235
235
|
setup_knife(['-G user@ec2.public_hostname', '*:*', 'uptime'])
|
236
236
|
Chef::Config[:knife][:ssh_gateway] = nil
|
237
|
-
@knife.session.
|
237
|
+
allow(@knife.session).to receive(:via) do |host, user, options|
|
238
238
|
raise Net::SSH::AuthenticationFailed unless options[:password]
|
239
239
|
end
|
240
240
|
end
|
241
241
|
|
242
242
|
it "should prompt the user for a password" do
|
243
|
-
@knife.ui.
|
243
|
+
expect(@knife.ui).to receive(:ask).with("Enter the password for user@ec2.public_hostname: ").and_return("password")
|
244
244
|
@knife.run
|
245
245
|
end
|
246
246
|
end
|
@@ -252,7 +252,7 @@ describe Chef::Knife::Ssh do
|
|
252
252
|
# if available, but #merge_configs (which is called by #configure_chef) is
|
253
253
|
# necessary to have default options merged in.
|
254
254
|
@knife.merge_configs
|
255
|
-
@knife.
|
255
|
+
allow(@knife).to receive(:ssh_command) { 0 }
|
256
256
|
@api = TinyServer::API.instance
|
257
257
|
@api.clear
|
258
258
|
|
@@ -260,7 +260,7 @@ describe Chef::Knife::Ssh do
|
|
260
260
|
Chef::Config[:client_key] = nil
|
261
261
|
Chef::Config[:chef_server_url] = 'http://localhost:9000'
|
262
262
|
|
263
|
-
@api.get("/search/node?q=*:*&sort=X_CHEF_id_CHEF_X%20asc&start=0
|
263
|
+
@api.get("/search/node?q=*:*&sort=X_CHEF_id_CHEF_X%20asc&start=0", 200) {
|
264
264
|
%({"total":1, "start":0, "rows":[{"name":"i-xxxxxxxx", "json_class":"Chef::Node", "automatic":{"fqdn":"the.fqdn", "ec2":{"public_hostname":"the_public_hostname"}},"recipes":[]}]})
|
265
265
|
}
|
266
266
|
end
|
@@ -64,9 +64,9 @@ describe Chef::Provider::RemoteFile::CacheControlData do
|
|
64
64
|
it "writes the data to the cache and the same data can be read back" do
|
65
65
|
cache_control_data.save
|
66
66
|
saved_cache_control_data = Chef::Provider::RemoteFile::CacheControlData.load_and_validate(uri, file_checksum)
|
67
|
-
saved_cache_control_data.etag.
|
68
|
-
saved_cache_control_data.mtime.
|
69
|
-
saved_cache_control_data.checksum.
|
67
|
+
expect(saved_cache_control_data.etag).to eq(cache_control_data.etag)
|
68
|
+
expect(saved_cache_control_data.mtime).to eq(cache_control_data.mtime)
|
69
|
+
expect(saved_cache_control_data.checksum).to eq(cache_control_data.checksum)
|
70
70
|
end
|
71
71
|
|
72
72
|
# Cover the very long remote file path case -- see CHEF-4422 where
|
@@ -81,17 +81,17 @@ describe Chef::Provider::RemoteFile::CacheControlData do
|
|
81
81
|
let(:uri) { uri_exceeds_file_system_limit }
|
82
82
|
|
83
83
|
it "writes data to the cache" do
|
84
|
-
|
84
|
+
expect do
|
85
85
|
cache_control_data.save
|
86
|
-
end.
|
86
|
+
end.not_to raise_error
|
87
87
|
end
|
88
88
|
|
89
89
|
it "writes the data to the cache and the same data can be read back" do
|
90
90
|
cache_control_data.save
|
91
91
|
saved_cache_control_data = Chef::Provider::RemoteFile::CacheControlData.load_and_validate(uri, file_checksum)
|
92
|
-
saved_cache_control_data.etag.
|
93
|
-
saved_cache_control_data.mtime.
|
94
|
-
saved_cache_control_data.checksum.
|
92
|
+
expect(saved_cache_control_data.etag).to eq(cache_control_data.etag)
|
93
|
+
expect(saved_cache_control_data.mtime).to eq(cache_control_data.mtime)
|
94
|
+
expect(saved_cache_control_data.checksum).to eq(cache_control_data.checksum)
|
95
95
|
end
|
96
96
|
|
97
97
|
end
|
@@ -44,8 +44,8 @@ describe Chef::Resource::WhyrunSafeRubyBlock do
|
|
44
44
|
|
45
45
|
it "updates the evil laugh, even in why-run mode" do
|
46
46
|
new_resource.run_action(new_resource.action)
|
47
|
-
$evil_global_evil_laugh.
|
48
|
-
new_resource.
|
47
|
+
expect($evil_global_evil_laugh).to eq(:mwahahaha)
|
48
|
+
expect(new_resource).to be_updated
|
49
49
|
end
|
50
50
|
end
|
51
51
|
end
|
@@ -70,7 +70,7 @@ describe Chef::Platform::Rebooter do
|
|
70
70
|
|
71
71
|
shared_context 'test a reboot method' do
|
72
72
|
def test_rebooter_method(method_sym, is_windows, expected_reboot_str)
|
73
|
-
Chef::Platform.
|
73
|
+
allow(Chef::Platform).to receive(:windows?).and_return(is_windows)
|
74
74
|
expect(rebooter).to receive(:shell_out!).once.with(expected_reboot_str)
|
75
75
|
expect(rebooter).to receive(method_sym).once.and_call_original
|
76
76
|
rebooter.send(method_sym, run_context.node)
|
@@ -28,12 +28,12 @@ describe Chef::Resource::Service, :requires_root, :aix_only do
|
|
28
28
|
|
29
29
|
# Platform specific validation routines.
|
30
30
|
def service_should_be_started(file_name)
|
31
|
-
# The
|
32
|
-
expect(File.exists?("/tmp/#{file_name}")).to
|
31
|
+
# The existence of this file indicates that the service was started.
|
32
|
+
expect(File.exists?("/tmp/#{file_name}")).to be_truthy
|
33
33
|
end
|
34
34
|
|
35
35
|
def service_should_be_stopped(file_name)
|
36
|
-
expect(File.exists?("/tmp/#{file_name}")).to
|
36
|
+
expect(File.exists?("/tmp/#{file_name}")).to be_falsey
|
37
37
|
end
|
38
38
|
|
39
39
|
def valide_symlinks(expected_output, run_level = nil, status = nil, priority = nil)
|
@@ -0,0 +1,88 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Serdar Sutay (<serdar@opscode.com>)
|
3
|
+
# Copyright:: Copyright (c) 2014 Opscode, Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'spec_helper'
|
20
|
+
require 'functional/resource/base'
|
21
|
+
|
22
|
+
describe Chef::Resource::Bash, :unix_only do
|
23
|
+
let(:code) { "echo hello" }
|
24
|
+
let(:resource) {
|
25
|
+
resource = Chef::Resource::Bash.new("foo_resource", run_context)
|
26
|
+
resource.code(code)
|
27
|
+
resource
|
28
|
+
}
|
29
|
+
|
30
|
+
describe "when setting the command attribute" do
|
31
|
+
let (:command) { 'wizard racket' }
|
32
|
+
|
33
|
+
# in Chef-12 the `command` attribute is largely useless, but does set the identity attribute
|
34
|
+
# so that notifications need to target the value of the command. it will not run the `command`
|
35
|
+
# and if it is given without a code block then it does nothing and always succeeds.
|
36
|
+
describe "in Chef-12", :chef_lt_13_only do
|
37
|
+
it "gets the commmand attribute from the name" do
|
38
|
+
expect(resource.command).to eql("foo_resource")
|
39
|
+
end
|
40
|
+
|
41
|
+
it "sets the resource identity to the command name" do
|
42
|
+
resource.command command
|
43
|
+
expect(resource.identity).to eql(command)
|
44
|
+
end
|
45
|
+
|
46
|
+
it "warns when the code is not present and a useless `command` is present" do
|
47
|
+
expect(Chef::Log).to receive(:warn).with(/coding error/)
|
48
|
+
expect(Chef::Log).to receive(:warn).with(/deprecated/)
|
49
|
+
resource.code nil
|
50
|
+
resource.command command
|
51
|
+
expect { resource.run_action(:run) }.not_to raise_error
|
52
|
+
end
|
53
|
+
|
54
|
+
describe "when the code is not present" do
|
55
|
+
let(:code) { nil }
|
56
|
+
it "warns" do
|
57
|
+
expect(Chef::Log).to receive(:warn)
|
58
|
+
expect { resource.run_action(:run) }.not_to raise_error
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
# in Chef-13 the `command` attribute needs to be for internal use only
|
64
|
+
describe "in Chef-13", :chef_gte_13_only do
|
65
|
+
it "should raise an exception when trying to set the command" do
|
66
|
+
expect { resource.command command }.to raise_error # FIXME: add a real error in Chef-13
|
67
|
+
end
|
68
|
+
|
69
|
+
it "should initialize the command to nil" do
|
70
|
+
expect(resource.command).to be_nil
|
71
|
+
end
|
72
|
+
|
73
|
+
describe "when the code is not present" do
|
74
|
+
let(:code) { nil }
|
75
|
+
it "raises an exception" do
|
76
|
+
expect { resource.run_action(:run) }.to raise_error # FIXME: add a real error in Chef-13
|
77
|
+
expect { resource.run_action(:run) }.not_to raise_error
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
it "times out when a timeout is set on the resource" do
|
84
|
+
resource.code 'sleep 600'
|
85
|
+
resource.timeout 0.1
|
86
|
+
expect { resource.run_action(:run) }.to raise_error(Mixlib::ShellOut::CommandTimeout)
|
87
|
+
end
|
88
|
+
end
|
@@ -45,11 +45,10 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
45
45
|
|
46
46
|
before(:all) do
|
47
47
|
@ohai = Ohai::System.new
|
48
|
-
@ohai.all_plugins("os")
|
48
|
+
@ohai.all_plugins(["platform", "os"])
|
49
49
|
end
|
50
50
|
|
51
51
|
let(:node) do
|
52
|
-
|
53
52
|
Chef::Node.new.tap do |n|
|
54
53
|
n.name "rspec-test"
|
55
54
|
n.consume_external_attrs(@ohai.data, {})
|
@@ -173,12 +172,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
173
172
|
it "deploys the app to the target revision (#{target_rev_spec})" do
|
174
173
|
target_rev = send(target_rev_spec)
|
175
174
|
|
176
|
-
File.
|
175
|
+
expect(File).to exist(rel_path("current"))
|
177
176
|
|
178
|
-
actual_current_rev.
|
177
|
+
expect(actual_current_rev).to eq(target_rev)
|
179
178
|
|
180
179
|
# Is the app code actually there?
|
181
|
-
File.
|
180
|
+
expect(File).to exist(rel_path("current/app/app.rb"))
|
182
181
|
end
|
183
182
|
end
|
184
183
|
|
@@ -193,12 +192,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
193
192
|
the_app_is_deployed_at_revision(:latest_rev)
|
194
193
|
|
195
194
|
it "restarts the application" do
|
196
|
-
File.
|
197
|
-
actual_operations_order.
|
195
|
+
expect(File).to exist(rel_path("current/restart.txt"))
|
196
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
|
198
197
|
end
|
199
198
|
|
200
199
|
it "is marked as updated" do
|
201
|
-
deploy_to_latest_rev.
|
200
|
+
expect(deploy_to_latest_rev).to be_updated_by_last_action
|
202
201
|
end
|
203
202
|
end
|
204
203
|
|
@@ -215,15 +214,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
215
214
|
the_app_is_deployed_at_revision(:latest_rev)
|
216
215
|
|
217
216
|
it "restarts the application after rolling back" do
|
218
|
-
actual_operations_order.
|
217
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again])
|
219
218
|
end
|
220
219
|
|
221
220
|
it "is marked updated" do
|
222
|
-
deploy_to_latest_rev_again.
|
221
|
+
expect(deploy_to_latest_rev_again).to be_updated_by_last_action
|
223
222
|
end
|
224
223
|
|
225
224
|
it "deploys the right code" do
|
226
|
-
IO.read(rel_path("current/app/app.rb")).
|
225
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the fourth version of the app")
|
227
226
|
end
|
228
227
|
end
|
229
228
|
|
@@ -233,27 +232,27 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
233
232
|
end
|
234
233
|
|
235
234
|
it "creates the required directory tree" do
|
236
|
-
File.
|
237
|
-
File.
|
238
|
-
File.
|
235
|
+
expect(File).to be_directory(rel_path("releases"))
|
236
|
+
expect(File).to be_directory(rel_path("shared"))
|
237
|
+
expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
|
239
238
|
|
240
|
-
File.
|
241
|
-
File.
|
242
|
-
File.
|
239
|
+
expect(File).to be_directory(rel_path("current/tmp"))
|
240
|
+
expect(File).to be_directory(rel_path("current/config"))
|
241
|
+
expect(File).to be_directory(rel_path("current/public"))
|
243
242
|
|
244
|
-
File.
|
245
|
-
File.readlink(rel_path("current")).
|
243
|
+
expect(File).to be_symlink(rel_path("current"))
|
244
|
+
expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
|
246
245
|
end
|
247
246
|
|
248
247
|
the_app_is_deployed_at_revision(:latest_rev)
|
249
248
|
|
250
249
|
it "restarts the application" do
|
251
|
-
File.
|
252
|
-
actual_operations_order.
|
250
|
+
expect(File).to exist(rel_path("current/restart.txt"))
|
251
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
|
253
252
|
end
|
254
253
|
|
255
254
|
it "is marked as updated" do
|
256
|
-
deploy_to_latest_rev.
|
255
|
+
expect(deploy_to_latest_rev).to be_updated_by_last_action
|
257
256
|
end
|
258
257
|
end
|
259
258
|
|
@@ -266,11 +265,11 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
266
265
|
the_app_is_deployed_at_revision(:latest_rev)
|
267
266
|
|
268
267
|
it "does not restart the app" do
|
269
|
-
actual_operations_order.
|
268
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev])
|
270
269
|
end
|
271
270
|
|
272
271
|
it "is not marked updated" do
|
273
|
-
deploy_to_latest_rev.
|
272
|
+
expect(deploy_to_latest_rev).not_to be_updated_by_last_action
|
274
273
|
end
|
275
274
|
|
276
275
|
end
|
@@ -284,11 +283,11 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
284
283
|
the_app_is_deployed_at_revision(:latest_rev)
|
285
284
|
|
286
285
|
it "restarts the app" do
|
287
|
-
actual_operations_order.
|
286
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_latest_rev_again])
|
288
287
|
end
|
289
288
|
|
290
289
|
it "is marked updated" do
|
291
|
-
deploy_to_latest_rev.
|
290
|
+
expect(deploy_to_latest_rev).to be_updated_by_last_action
|
292
291
|
end
|
293
292
|
|
294
293
|
end
|
@@ -302,15 +301,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
302
301
|
the_app_is_deployed_at_revision(:latest_rev)
|
303
302
|
|
304
303
|
it "restarts the application after the new deploy" do
|
305
|
-
actual_operations_order.
|
304
|
+
expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev])
|
306
305
|
end
|
307
306
|
|
308
307
|
it "is marked updated" do
|
309
|
-
deploy_to_previous_rev.
|
308
|
+
expect(deploy_to_previous_rev).to be_updated_by_last_action
|
310
309
|
end
|
311
310
|
|
312
311
|
it "leaves the old copy of the app around for rollback" do
|
313
|
-
File.
|
312
|
+
expect(File).to exist(File.join(deploy_directory, "releases", previous_rev))
|
314
313
|
end
|
315
314
|
|
316
315
|
end
|
@@ -325,15 +324,15 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
325
324
|
the_app_is_deployed_at_revision(:latest_rev)
|
326
325
|
|
327
326
|
it "restarts the application after rolling back" do
|
328
|
-
actual_operations_order.
|
327
|
+
expect(actual_operations_order).to eq(%w[deploy_to_latest_rev deploy_to_previous_rev deploy_to_latest_rev_again])
|
329
328
|
end
|
330
329
|
|
331
330
|
it "is marked updated" do
|
332
|
-
deploy_to_latest_rev_again.
|
331
|
+
expect(deploy_to_latest_rev_again).to be_updated_by_last_action
|
333
332
|
end
|
334
333
|
|
335
334
|
it "deploys the right code" do
|
336
|
-
IO.read(rel_path("current/app/app.rb")).
|
335
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the fourth version of the app")
|
337
336
|
end
|
338
337
|
end
|
339
338
|
|
@@ -350,31 +349,31 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
350
349
|
the_app_is_deployed_at_revision(:previous_rev)
|
351
350
|
|
352
351
|
it "restarts the application after rolling back" do
|
353
|
-
actual_operations_order.
|
352
|
+
expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_latest_rev_again])
|
354
353
|
end
|
355
354
|
|
356
355
|
it "is marked updated" do
|
357
|
-
deploy_to_latest_rev_again.
|
356
|
+
expect(deploy_to_latest_rev_again).to be_updated_by_last_action
|
358
357
|
end
|
359
358
|
|
360
359
|
it "deploys the right code" do
|
361
|
-
IO.read(rel_path("current/app/app.rb")).
|
360
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the third version of the app")
|
362
361
|
end
|
363
362
|
|
364
363
|
it "all_releases after first deploy should have one entry" do
|
365
|
-
@previous_rev_all_releases.length.
|
364
|
+
expect(@previous_rev_all_releases.length).to eq(1)
|
366
365
|
end
|
367
366
|
|
368
367
|
it "all_releases after second deploy should have two entries" do
|
369
|
-
@latest_rev_all_releases.length.
|
368
|
+
expect(@latest_rev_all_releases.length).to eq(2)
|
370
369
|
end
|
371
370
|
|
372
371
|
it "all_releases after rollback should have one entry" do
|
373
|
-
@previous_rev_again_all_releases.length.
|
372
|
+
expect(@previous_rev_again_all_releases.length).to eq(1)
|
374
373
|
end
|
375
374
|
|
376
375
|
it "all_releases after rollback should be the same as after the first deploy" do
|
377
|
-
@previous_rev_again_all_releases.
|
376
|
+
expect(@previous_rev_again_all_releases).to eq(@previous_rev_all_releases)
|
378
377
|
end
|
379
378
|
|
380
379
|
end
|
@@ -393,31 +392,31 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
393
392
|
the_app_is_deployed_at_revision(:previous_rev)
|
394
393
|
|
395
394
|
it "restarts the application after rolling back" do
|
396
|
-
actual_operations_order.
|
395
|
+
expect(actual_operations_order).to eq(%w[deploy_to_previous_rev deploy_to_latest_rev deploy_to_previous_rev_again])
|
397
396
|
end
|
398
397
|
|
399
398
|
it "is marked updated" do
|
400
|
-
deploy_to_previous_rev_again.
|
399
|
+
expect(deploy_to_previous_rev_again).to be_updated_by_last_action
|
401
400
|
end
|
402
401
|
|
403
402
|
it "deploys the right code" do
|
404
|
-
IO.read(rel_path("current/app/app.rb")).
|
403
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the third version of the app")
|
405
404
|
end
|
406
405
|
|
407
406
|
it "all_releases after first deploy should have one entry" do
|
408
|
-
@previous_rev_all_releases.length.
|
407
|
+
expect(@previous_rev_all_releases.length).to eq(1)
|
409
408
|
end
|
410
409
|
|
411
410
|
it "all_releases after second deploy should have two entries" do
|
412
|
-
@latest_rev_all_releases.length.
|
411
|
+
expect(@latest_rev_all_releases.length).to eq(2)
|
413
412
|
end
|
414
413
|
|
415
414
|
it "all_releases after rollback should have one entry" do
|
416
|
-
@previous_rev_again_all_releases.length.
|
415
|
+
expect(@previous_rev_again_all_releases.length).to eq(1)
|
417
416
|
end
|
418
417
|
|
419
418
|
it "all_releases after rollback should be the same as after the first deploy" do
|
420
|
-
@previous_rev_again_all_releases.
|
419
|
+
expect(@previous_rev_again_all_releases).to eq(@previous_rev_all_releases)
|
421
420
|
end
|
422
421
|
end
|
423
422
|
|
@@ -438,23 +437,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
438
437
|
the_app_is_deployed_at_revision(:second_rev)
|
439
438
|
|
440
439
|
it "restarts the application after rolling back" do
|
441
|
-
actual_operations_order.
|
440
|
+
expect(actual_operations_order).to eq(%w[deploy_to_second_rev deploy_to_previous_rev deploy_to_previous_rev_again deploy_to_latest_rev deploy_to_latest_rev_again])
|
442
441
|
end
|
443
442
|
|
444
443
|
it "is marked updated" do
|
445
|
-
deploy_to_latest_rev_again.
|
444
|
+
expect(deploy_to_latest_rev_again).to be_updated_by_last_action
|
446
445
|
end
|
447
446
|
|
448
447
|
it "deploys the right code" do
|
449
|
-
IO.read(rel_path("current/app/app.rb")).
|
448
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the second version of the app")
|
450
449
|
end
|
451
450
|
|
452
451
|
it "all_releases after rollback should have one entry" do
|
453
|
-
@fifth_deploy_all_releases.length.
|
452
|
+
expect(@fifth_deploy_all_releases.length).to eq(1)
|
454
453
|
end
|
455
454
|
|
456
455
|
it "all_releases after rollback should be the same as after the first deploy" do
|
457
|
-
@fifth_deploy_all_releases.
|
456
|
+
expect(@fifth_deploy_all_releases).to eq(@first_deploy_all_releases)
|
458
457
|
end
|
459
458
|
end
|
460
459
|
|
@@ -475,23 +474,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
475
474
|
the_app_is_deployed_at_revision(:second_rev)
|
476
475
|
|
477
476
|
it "restarts the application after rolling back" do
|
478
|
-
actual_operations_order.
|
477
|
+
expect(actual_operations_order).to eq(%w[deploy_to_second_rev deploy_to_previous_rev deploy_to_second_rev_again deploy_to_latest_rev deploy_to_second_rev_again_again])
|
479
478
|
end
|
480
479
|
|
481
480
|
it "is marked updated" do
|
482
|
-
deploy_to_second_rev_again_again.
|
481
|
+
expect(deploy_to_second_rev_again_again).to be_updated_by_last_action
|
483
482
|
end
|
484
483
|
|
485
484
|
it "deploys the right code" do
|
486
|
-
IO.read(rel_path("current/app/app.rb")).
|
485
|
+
expect(IO.read(rel_path("current/app/app.rb"))).to include("this is the second version of the app")
|
487
486
|
end
|
488
487
|
|
489
488
|
it "all_releases after rollback should have one entry" do
|
490
|
-
@fifth_deploy_all_releases.length.
|
489
|
+
expect(@fifth_deploy_all_releases.length).to eq(1)
|
491
490
|
end
|
492
491
|
|
493
492
|
it "all_releases after rollback should be the same as after the first deploy" do
|
494
|
-
@fifth_deploy_all_releases.
|
493
|
+
expect(@fifth_deploy_all_releases).to eq(@first_deploy_all_releases)
|
495
494
|
end
|
496
495
|
|
497
496
|
end
|
@@ -510,21 +509,21 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
510
509
|
end
|
511
510
|
|
512
511
|
before do
|
513
|
-
File.
|
512
|
+
expect(File).not_to exist(deploy_directory)
|
514
513
|
deploy_to_latest_rev.run_action(:deploy)
|
515
514
|
end
|
516
515
|
|
517
516
|
it "creates the required directory tree" do
|
518
|
-
File.
|
519
|
-
File.
|
520
|
-
File.
|
517
|
+
expect(File).to be_directory(rel_path("releases"))
|
518
|
+
expect(File).to be_directory(rel_path("shared"))
|
519
|
+
expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
|
521
520
|
|
522
|
-
File.
|
523
|
-
File.
|
524
|
-
File.
|
521
|
+
expect(File).to be_directory(rel_path("current/tmp"))
|
522
|
+
expect(File).to be_directory(rel_path("current/config"))
|
523
|
+
expect(File).to be_directory(rel_path("current/public"))
|
525
524
|
|
526
|
-
File.
|
527
|
-
File.readlink(rel_path("current")).
|
525
|
+
expect(File).to be_symlink(rel_path("current"))
|
526
|
+
expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
|
528
527
|
end
|
529
528
|
|
530
529
|
the_app_is_deployed_at_revision(:latest_rev)
|
@@ -599,18 +598,18 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
599
598
|
the_app_is_deployed_at_revision(:latest_rev)
|
600
599
|
|
601
600
|
it "is marked updated" do
|
602
|
-
deploy_to_latest_with_inline_recipes.
|
601
|
+
expect(deploy_to_latest_with_inline_recipes).to be_updated_by_last_action
|
603
602
|
end
|
604
603
|
|
605
604
|
it "calls the callbacks in order" do
|
606
|
-
callback_order.
|
605
|
+
expect(callback_order).to eq([:before_migrate, :before_symlink, :before_restart, :after_restart])
|
607
606
|
end
|
608
607
|
|
609
608
|
it "runs chef resources in the callbacks" do
|
610
|
-
File.
|
611
|
-
File.
|
612
|
-
File.
|
613
|
-
File.
|
609
|
+
expect(File).to exist(rel_path("current/before_migrate.txt"))
|
610
|
+
expect(File).to exist(rel_path("current/before_symlink.txt"))
|
611
|
+
expect(File).to exist(rel_path("current/tmp/before_restart.txt"))
|
612
|
+
expect(File).to exist(rel_path("current/tmp/after_restart.txt"))
|
614
613
|
end
|
615
614
|
end
|
616
615
|
|
@@ -629,10 +628,10 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
629
628
|
the_app_is_deployed_at_revision(:rev_with_in_repo_callbacks)
|
630
629
|
|
631
630
|
it "runs chef resources in the callbacks" do
|
632
|
-
File.
|
633
|
-
File.
|
634
|
-
File.
|
635
|
-
File.
|
631
|
+
expect(File).to exist(rel_path("current/before_migrate.txt"))
|
632
|
+
expect(File).to exist(rel_path("current/before_symlink.txt"))
|
633
|
+
expect(File).to exist(rel_path("current/tmp/before_restart.txt"))
|
634
|
+
expect(File).to exist(rel_path("current/tmp/after_restart.txt"))
|
636
635
|
end
|
637
636
|
|
638
637
|
end
|
@@ -690,7 +689,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
690
689
|
end
|
691
690
|
|
692
691
|
it "runs migrations in between the before_migrate and before_symlink steps" do
|
693
|
-
actual_operations_order.
|
692
|
+
expect(actual_operations_order).to eq(%w[before_migrate migration before_symlink before_restart after_restart])
|
694
693
|
end
|
695
694
|
end
|
696
695
|
|
@@ -703,7 +702,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
703
702
|
end
|
704
703
|
|
705
704
|
it "should not raise an exception calling File.utime on symlinks" do
|
706
|
-
|
705
|
+
expect { deploy_with_in_repo_symlinks.run_action(:deploy) }.not_to raise_error
|
707
706
|
end
|
708
707
|
end
|
709
708
|
|
@@ -712,16 +711,16 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
712
711
|
shared_examples_for "a redeployed application" do
|
713
712
|
|
714
713
|
it "should redeploy the application" do
|
715
|
-
File.
|
716
|
-
File.
|
717
|
-
File.
|
714
|
+
expect(File).to be_directory(rel_path("releases"))
|
715
|
+
expect(File).to be_directory(rel_path("shared"))
|
716
|
+
expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
|
718
717
|
|
719
|
-
File.
|
720
|
-
File.
|
721
|
-
File.
|
718
|
+
expect(File).to be_directory(rel_path("current/tmp"))
|
719
|
+
expect(File).to be_directory(rel_path("current/config"))
|
720
|
+
expect(File).to be_directory(rel_path("current/public"))
|
722
721
|
|
723
|
-
File.
|
724
|
-
File.readlink(rel_path("current")).
|
722
|
+
expect(File).to be_symlink(rel_path("current"))
|
723
|
+
expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
|
725
724
|
end
|
726
725
|
end
|
727
726
|
|
@@ -758,23 +757,23 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
758
757
|
shared_examples_for "a recovered deployment" do
|
759
758
|
|
760
759
|
it "should redeploy the application" do
|
761
|
-
File.
|
762
|
-
File.
|
763
|
-
File.
|
760
|
+
expect(File).to be_directory(rel_path("releases"))
|
761
|
+
expect(File).to be_directory(rel_path("shared"))
|
762
|
+
expect(File).to be_directory(rel_path("releases/#{latest_rev}"))
|
764
763
|
|
765
|
-
File.
|
766
|
-
File.
|
767
|
-
File.
|
764
|
+
expect(File).to be_directory(rel_path("current/tmp"))
|
765
|
+
expect(File).to be_directory(rel_path("current/config"))
|
766
|
+
expect(File).to be_directory(rel_path("current/public"))
|
768
767
|
|
769
|
-
File.
|
770
|
-
File.readlink(rel_path("current")).
|
768
|
+
expect(File).to be_symlink(rel_path("current"))
|
769
|
+
expect(File.readlink(rel_path("current"))).to eq(rel_path("releases/#{latest_rev}"))
|
771
770
|
|
772
771
|
# if callbacks ran, we know the app was deployed and not merely rolled
|
773
772
|
# back to a (busted) prior deployment.
|
774
|
-
callback_order.
|
773
|
+
expect(callback_order).to eq([:before_migrate,
|
775
774
|
:before_symlink,
|
776
775
|
:before_restart,
|
777
|
-
:after_restart ]
|
776
|
+
:after_restart ])
|
778
777
|
end
|
779
778
|
end
|
780
779
|
|
@@ -794,7 +793,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
794
793
|
|
795
794
|
context "in the `#{callback}' callback" do
|
796
795
|
before do
|
797
|
-
|
796
|
+
expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Exception, %r{I am a failed deploy})
|
798
797
|
deploy_to_latest_with_callback_tracking.run_action(:deploy)
|
799
798
|
end
|
800
799
|
|
@@ -820,7 +819,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
820
819
|
end
|
821
820
|
|
822
821
|
before do
|
823
|
-
|
822
|
+
expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Chef::Exceptions::Exec)
|
824
823
|
deploy_to_latest_with_callback_tracking.run_action(:deploy)
|
825
824
|
end
|
826
825
|
|
@@ -852,7 +851,7 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
852
851
|
end
|
853
852
|
|
854
853
|
before do
|
855
|
-
|
854
|
+
expect { deploy_that_fails.run_action(:deploy) }.to raise_error(RuntimeError, /network error/)
|
856
855
|
deploy_to_latest_with_callback_tracking.run_action(:deploy)
|
857
856
|
end
|
858
857
|
|
@@ -868,12 +867,12 @@ describe Chef::Resource::DeployRevision, :unix_only => true do
|
|
868
867
|
end
|
869
868
|
|
870
869
|
before do
|
871
|
-
|
870
|
+
expect { deploy_that_fails.run_action(:deploy) }.to raise_error(Exception, %r{I am a failed deploy})
|
872
871
|
deploy_to_latest_rev.run_action(:deploy)
|
873
872
|
end
|
874
873
|
|
875
874
|
it "removes the unsuccessful deploy after a later successful deploy" do
|
876
|
-
::File.
|
875
|
+
expect(::File).not_to exist(File.join(deploy_directory, "releases", previous_rev))
|
877
876
|
end
|
878
877
|
|
879
878
|
end
|