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
@@ -39,18 +39,18 @@ describe Chef::Knife::Core::BootstrapContext do
|
|
39
39
|
end
|
40
40
|
|
41
41
|
it "runs chef with the first-boot.json in the _default environment" do
|
42
|
-
bootstrap_context.start_chef.
|
42
|
+
expect(bootstrap_context.start_chef).to eq "chef-client -j /etc/chef/first-boot.json -E _default"
|
43
43
|
end
|
44
44
|
|
45
45
|
describe "when in verbosity mode" do
|
46
46
|
let(:config) { {:verbosity => 2} }
|
47
47
|
it "adds '-l debug' when verbosity is >= 2" do
|
48
|
-
bootstrap_context.start_chef.
|
48
|
+
expect(bootstrap_context.start_chef).to eq "chef-client -j /etc/chef/first-boot.json -l debug -E _default"
|
49
49
|
end
|
50
50
|
end
|
51
51
|
|
52
52
|
it "reads the validation key" do
|
53
|
-
bootstrap_context.validation_key.
|
53
|
+
expect(bootstrap_context.validation_key).to eq IO.read(File.join(CHEF_SPEC_DATA, 'ssl', 'private_key.pem'))
|
54
54
|
end
|
55
55
|
|
56
56
|
it "generates the config file data" do
|
@@ -60,7 +60,7 @@ chef_server_url "http://chef.example.com:4444"
|
|
60
60
|
validation_client_name "chef-validator-testing"
|
61
61
|
# Using default node name (fqdn)
|
62
62
|
EXPECTED
|
63
|
-
bootstrap_context.config_content.
|
63
|
+
expect(bootstrap_context.config_content).to eq expected
|
64
64
|
end
|
65
65
|
|
66
66
|
it "does not set a default log_level" do
|
@@ -70,14 +70,15 @@ EXPECTED
|
|
70
70
|
describe "alternate chef-client path" do
|
71
71
|
let(:chef_config){ {:chef_client_path => '/usr/local/bin/chef-client'} }
|
72
72
|
it "runs chef-client from another path when specified" do
|
73
|
-
bootstrap_context.start_chef.
|
73
|
+
expect(bootstrap_context.start_chef).to eq "/usr/local/bin/chef-client -j /etc/chef/first-boot.json -E _default"
|
74
74
|
end
|
75
75
|
end
|
76
76
|
|
77
77
|
describe "validation key path that contains a ~" do
|
78
78
|
let(:chef_config){ {:validation_key => '~/my.key'} }
|
79
79
|
it "reads the validation key when it contains a ~" do
|
80
|
-
|
80
|
+
expect(File).to receive(:exist?).with(File.expand_path("my.key", ENV['HOME'])).and_return(true)
|
81
|
+
expect(IO).to receive(:read).with(File.expand_path("my.key", ENV['HOME']))
|
81
82
|
bootstrap_context.validation_key
|
82
83
|
end
|
83
84
|
end
|
@@ -85,44 +86,44 @@ EXPECTED
|
|
85
86
|
describe "when an explicit node name is given" do
|
86
87
|
let(:config){ {:chef_node_name => 'foobar.example.com' }}
|
87
88
|
it "sets the node name in the client.rb" do
|
88
|
-
bootstrap_context.config_content.
|
89
|
+
expect(bootstrap_context.config_content).to match(/node_name "foobar\.example\.com"/)
|
89
90
|
end
|
90
91
|
end
|
91
92
|
|
92
93
|
describe "when bootstrapping into a specific environment" do
|
93
94
|
let(:chef_config){ {:environment => "prodtastic"} }
|
94
95
|
it "starts chef in the configured environment" do
|
95
|
-
bootstrap_context.start_chef.
|
96
|
+
expect(bootstrap_context.start_chef).to eq('chef-client -j /etc/chef/first-boot.json -E prodtastic')
|
96
97
|
end
|
97
98
|
end
|
98
99
|
|
99
100
|
describe "when JSON attributes are given" do
|
100
101
|
let(:config) { {:first_boot_attributes => {:baz => :quux}} }
|
101
102
|
it "adds the attributes to first_boot" do
|
102
|
-
Chef::JSONCompat.to_json(bootstrap_context.first_boot).
|
103
|
+
expect(Chef::JSONCompat.to_json(bootstrap_context.first_boot)).to eq(Chef::JSONCompat.to_json({:baz => :quux, :run_list => run_list}))
|
103
104
|
end
|
104
105
|
end
|
105
106
|
|
106
107
|
describe "when JSON attributes are NOT given" do
|
107
108
|
it "sets first_boot equal to run_list" do
|
108
|
-
Chef::JSONCompat.to_json(bootstrap_context.first_boot).
|
109
|
+
expect(Chef::JSONCompat.to_json(bootstrap_context.first_boot)).to eq(Chef::JSONCompat.to_json({:run_list => run_list}))
|
109
110
|
end
|
110
111
|
end
|
111
112
|
|
112
113
|
describe "when an encrypted_data_bag_secret is provided" do
|
113
114
|
let(:secret) { "supersekret" }
|
114
115
|
it "reads the encrypted_data_bag_secret" do
|
115
|
-
bootstrap_context.encrypted_data_bag_secret.
|
116
|
+
expect(bootstrap_context.encrypted_data_bag_secret).to eq "supersekret"
|
116
117
|
end
|
117
118
|
end
|
118
119
|
|
119
120
|
describe "to support compatibility with existing templates" do
|
120
121
|
it "sets the @config instance variable" do
|
121
|
-
bootstrap_context.instance_variable_get(:@config).
|
122
|
+
expect(bootstrap_context.instance_variable_get(:@config)).to eq config
|
122
123
|
end
|
123
124
|
|
124
125
|
it "sets the @run_list instance variable" do
|
125
|
-
bootstrap_context.instance_variable_get(:@run_list).
|
126
|
+
expect(bootstrap_context.instance_variable_get(:@run_list)).to eq run_list
|
126
127
|
end
|
127
128
|
end
|
128
129
|
|
@@ -134,7 +135,7 @@ EXPECTED
|
|
134
135
|
end
|
135
136
|
|
136
137
|
it "should send the full version to the installer" do
|
137
|
-
bootstrap_context.latest_current_chef_version_string.
|
138
|
+
expect(bootstrap_context.latest_current_chef_version_string).to eq("-v 11.12.4")
|
138
139
|
end
|
139
140
|
end
|
140
141
|
|
@@ -146,20 +147,20 @@ EXPECTED
|
|
146
147
|
end
|
147
148
|
|
148
149
|
it "should send the full version to the installer and set the pre-release flag" do
|
149
|
-
bootstrap_context.latest_current_chef_version_string.
|
150
|
+
expect(bootstrap_context.latest_current_chef_version_string).to eq("-v 11.12.4.rc.0 -p")
|
150
151
|
end
|
151
152
|
end
|
152
153
|
|
153
154
|
describe "when a bootstrap_version is not specified" do
|
154
155
|
it "should send the latest current to the installer" do
|
155
156
|
# Intentionally hard coded in order not to replicate the logic.
|
156
|
-
bootstrap_context.latest_current_chef_version_string.
|
157
|
+
expect(bootstrap_context.latest_current_chef_version_string).to eq("-v #{Chef::VERSION.to_i}")
|
157
158
|
end
|
158
159
|
end
|
159
160
|
|
160
161
|
describe "ssl_verify_mode" do
|
161
162
|
it "isn't set in the config_content by default" do
|
162
|
-
bootstrap_context.config_content.
|
163
|
+
expect(bootstrap_context.config_content).not_to include("ssl_verify_mode")
|
163
164
|
end
|
164
165
|
|
165
166
|
describe "when configured in config" do
|
@@ -170,14 +171,14 @@ EXPECTED
|
|
170
171
|
end
|
171
172
|
|
172
173
|
it "uses the config value" do
|
173
|
-
bootstrap_context.config_content.
|
174
|
+
expect(bootstrap_context.config_content).to include("ssl_verify_mode :verify_peer")
|
174
175
|
end
|
175
176
|
|
176
177
|
describe "when configured via CLI" do
|
177
178
|
let(:config) {{:node_ssl_verify_mode => "none"}}
|
178
179
|
|
179
180
|
it "uses CLI value" do
|
180
|
-
bootstrap_context.config_content.
|
181
|
+
expect(bootstrap_context.config_content).to include("ssl_verify_mode :verify_none")
|
181
182
|
end
|
182
183
|
end
|
183
184
|
end
|
@@ -185,7 +186,7 @@ EXPECTED
|
|
185
186
|
|
186
187
|
describe "verify_api_cert" do
|
187
188
|
it "isn't set in the config_content by default" do
|
188
|
-
bootstrap_context.config_content.
|
189
|
+
expect(bootstrap_context.config_content).not_to include("verify_api_cert")
|
189
190
|
end
|
190
191
|
|
191
192
|
describe "when configured in config" do
|
@@ -196,17 +197,31 @@ EXPECTED
|
|
196
197
|
end
|
197
198
|
|
198
199
|
it "uses the config value" do
|
199
|
-
bootstrap_context.config_content.
|
200
|
+
expect(bootstrap_context.config_content).to include("verify_api_cert false")
|
200
201
|
end
|
201
202
|
|
202
203
|
describe "when configured via CLI" do
|
203
204
|
let(:config) {{:node_verify_api_cert => true}}
|
204
205
|
|
205
206
|
it "uses CLI value" do
|
206
|
-
bootstrap_context.config_content.
|
207
|
+
expect(bootstrap_context.config_content).to include("verify_api_cert true")
|
207
208
|
end
|
208
209
|
end
|
209
210
|
end
|
210
211
|
end
|
211
212
|
|
213
|
+
describe "prerelease" do
|
214
|
+
it "isn't set in the config_content by default" do
|
215
|
+
expect(bootstrap_context.config_content).not_to include("prerelease")
|
216
|
+
end
|
217
|
+
|
218
|
+
describe "when configured via cli" do
|
219
|
+
let(:config) {{:prerelease => true}}
|
220
|
+
|
221
|
+
it "uses CLI value" do
|
222
|
+
expect(bootstrap_context.latest_current_chef_version_string).to eq("-p")
|
223
|
+
end
|
224
|
+
end
|
225
|
+
end
|
226
|
+
|
212
227
|
end
|
@@ -39,45 +39,45 @@ BRANCHES
|
|
39
39
|
end
|
40
40
|
|
41
41
|
it "has a path to the cookbook repo" do
|
42
|
-
@cookbook_repo.repo_path.
|
42
|
+
expect(@cookbook_repo.repo_path).to eq(@repo_path)
|
43
43
|
end
|
44
44
|
|
45
45
|
it "has a default branch" do
|
46
|
-
@cookbook_repo.default_branch.
|
46
|
+
expect(@cookbook_repo.default_branch).to eq('master')
|
47
47
|
end
|
48
48
|
|
49
49
|
describe "when sanity checking the repo" do
|
50
50
|
it "exits when the directory does not exist" do
|
51
|
-
::File.
|
52
|
-
|
51
|
+
expect(::File).to receive(:directory?).with(@repo_path).and_return(false)
|
52
|
+
expect {@cookbook_repo.sanity_check}.to raise_error(SystemExit)
|
53
53
|
end
|
54
54
|
|
55
55
|
describe "and the repo dir exists" do
|
56
56
|
before do
|
57
|
-
::File.
|
57
|
+
allow(::File).to receive(:directory?).with(@repo_path).and_return(true)
|
58
58
|
end
|
59
59
|
|
60
60
|
it "exits when there is no git repo" do
|
61
|
-
::File.
|
62
|
-
|
61
|
+
allow(::File).to receive(:directory?).with(/.*\.git/).and_return(false)
|
62
|
+
expect {@cookbook_repo.sanity_check}.to raise_error(SystemExit)
|
63
63
|
end
|
64
64
|
|
65
65
|
describe "and the repo is a git repo" do
|
66
66
|
before do
|
67
|
-
::File.
|
67
|
+
allow(::File).to receive(:directory?).with(File.join(@repo_path, '.git')).and_return(true)
|
68
68
|
end
|
69
69
|
|
70
70
|
it "exits when the default branch doesn't exist" do
|
71
71
|
@nobranches = Mixlib::ShellOut.new.tap {|s|s.stdout.replace "\n"}
|
72
|
-
@cookbook_repo.
|
73
|
-
|
72
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git branch --no-color', :cwd => @repo_path).and_return(@nobranches)
|
73
|
+
expect {@cookbook_repo.sanity_check}.to raise_error(SystemExit)
|
74
74
|
end
|
75
75
|
|
76
76
|
describe "and the default branch exists" do
|
77
77
|
before do
|
78
78
|
@master_branch = Mixlib::ShellOut.new
|
79
79
|
@master_branch.stdout.replace "* master\n"
|
80
|
-
@cookbook_repo.
|
80
|
+
expect(@cookbook_repo).to receive(:shell_out!).with("git branch --no-color", :cwd => @repo_path).and_return(@master_branch)
|
81
81
|
end
|
82
82
|
|
83
83
|
it "exits when the git repo is dirty" do
|
@@ -85,14 +85,14 @@ BRANCHES
|
|
85
85
|
@dirty_status.stdout.replace(<<-DIRTY)
|
86
86
|
M chef/lib/chef/knife/cookbook_site_vendor.rb
|
87
87
|
DIRTY
|
88
|
-
@cookbook_repo.
|
89
|
-
|
88
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git status --porcelain', :cwd => @repo_path).and_return(@dirty_status)
|
89
|
+
expect {@cookbook_repo.sanity_check}.to raise_error(SystemExit)
|
90
90
|
end
|
91
91
|
|
92
92
|
describe "and the repo is clean" do
|
93
93
|
before do
|
94
94
|
@clean_status = Mixlib::ShellOut.new.tap {|s| s.stdout.replace("\n")}
|
95
|
-
@cookbook_repo.
|
95
|
+
allow(@cookbook_repo).to receive(:shell_out!).with('git status --porcelain', :cwd => @repo_path).and_return(@clean_status)
|
96
96
|
end
|
97
97
|
|
98
98
|
it "passes the sanity check" do
|
@@ -106,35 +106,35 @@ DIRTY
|
|
106
106
|
end
|
107
107
|
|
108
108
|
it "resets to default state by checking out the default branch" do
|
109
|
-
@cookbook_repo.
|
109
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git checkout master', :cwd => @repo_path)
|
110
110
|
@cookbook_repo.reset_to_default_state
|
111
111
|
end
|
112
112
|
|
113
113
|
it "determines if a the pristine copy branch exists" do
|
114
|
-
@cookbook_repo.
|
115
|
-
@cookbook_repo.branch_exists?("chef-vendor-apache2").
|
116
|
-
@cookbook_repo.
|
117
|
-
@cookbook_repo.branch_exists?("chef-vendor-nginx").
|
114
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git branch --no-color', :cwd => @repo_path).and_return(@branch_list)
|
115
|
+
expect(@cookbook_repo.branch_exists?("chef-vendor-apache2")).to be_truthy
|
116
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git branch --no-color', :cwd => @repo_path).and_return(@branch_list)
|
117
|
+
expect(@cookbook_repo.branch_exists?("chef-vendor-nginx")).to be_falsey
|
118
118
|
end
|
119
119
|
|
120
120
|
it "determines if a the branch not exists correctly without substring search" do
|
121
|
-
@cookbook_repo.
|
122
|
-
@cookbook_repo.
|
123
|
-
@cookbook_repo.
|
121
|
+
expect(@cookbook_repo).to receive(:shell_out!).twice.with('git branch --no-color', :cwd => @repo_path).and_return(@branch_list)
|
122
|
+
expect(@cookbook_repo).not_to be_branch_exists("chef-vendor-absent")
|
123
|
+
expect(@cookbook_repo).to be_branch_exists("chef-vendor-absent-new")
|
124
124
|
end
|
125
125
|
|
126
126
|
describe "when the pristine copy branch does not exist" do
|
127
127
|
it "prepares for import by creating the pristine copy branch" do
|
128
|
-
@cookbook_repo.
|
129
|
-
@cookbook_repo.
|
128
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git branch --no-color', :cwd => @repo_path).and_return(@branch_list)
|
129
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git checkout -b chef-vendor-nginx', :cwd => @repo_path)
|
130
130
|
@cookbook_repo.prepare_to_import("nginx")
|
131
131
|
end
|
132
132
|
end
|
133
133
|
|
134
134
|
describe "when the pristine copy branch does exist" do
|
135
135
|
it "prepares for import by checking out the pristine copy branch" do
|
136
|
-
@cookbook_repo.
|
137
|
-
@cookbook_repo.
|
136
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git branch --no-color', :cwd => @repo_path).and_return(@branch_list)
|
137
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git checkout chef-vendor-apache2', :cwd => @repo_path)
|
138
138
|
@cookbook_repo.prepare_to_import("apache2")
|
139
139
|
end
|
140
140
|
end
|
@@ -143,15 +143,15 @@ DIRTY
|
|
143
143
|
before do
|
144
144
|
@updates = Mixlib::ShellOut.new
|
145
145
|
@updates.stdout.replace("\n")
|
146
|
-
@cookbook_repo.
|
146
|
+
allow(@cookbook_repo).to receive(:shell_out!).with('git status --porcelain -- apache2', :cwd => @repo_path).and_return(@updates)
|
147
147
|
end
|
148
148
|
|
149
149
|
it "shows no changes in the pristine copy" do
|
150
|
-
@cookbook_repo.updated?('apache2').
|
150
|
+
expect(@cookbook_repo.updated?('apache2')).to be_falsey
|
151
151
|
end
|
152
152
|
|
153
153
|
it "does nothing to finalize the updates" do
|
154
|
-
@cookbook_repo.finalize_updates_to('apache2', '1.2.3').
|
154
|
+
expect(@cookbook_repo.finalize_updates_to('apache2', '1.2.3')).to be_falsey
|
155
155
|
end
|
156
156
|
end
|
157
157
|
|
@@ -159,18 +159,18 @@ DIRTY
|
|
159
159
|
before do
|
160
160
|
@updates = Mixlib::ShellOut.new
|
161
161
|
@updates.stdout.replace(" M cookbooks/apache2/recipes/default.rb\n")
|
162
|
-
@cookbook_repo.
|
162
|
+
allow(@cookbook_repo).to receive(:shell_out!).with('git status --porcelain -- apache2', :cwd => @repo_path).and_return(@updates)
|
163
163
|
end
|
164
164
|
|
165
165
|
it "shows changes in the pristine copy" do
|
166
|
-
@cookbook_repo.updated?('apache2').
|
166
|
+
expect(@cookbook_repo.updated?('apache2')).to be_truthy
|
167
167
|
end
|
168
168
|
|
169
169
|
it "commits the changes to the repo and tags the commit" do
|
170
|
-
@cookbook_repo.
|
171
|
-
@cookbook_repo.
|
172
|
-
@cookbook_repo.
|
173
|
-
@cookbook_repo.finalize_updates_to("apache2", "1.2.3").
|
170
|
+
expect(@cookbook_repo).to receive(:shell_out!).with("git add apache2", :cwd => @repo_path)
|
171
|
+
expect(@cookbook_repo).to receive(:shell_out!).with("git commit -m \"Import apache2 version 1.2.3\" -- apache2", :cwd => @repo_path)
|
172
|
+
expect(@cookbook_repo).to receive(:shell_out!).with("git tag -f cookbook-site-imported-apache2-1.2.3", :cwd => @repo_path)
|
173
|
+
expect(@cookbook_repo.finalize_updates_to("apache2", "1.2.3")).to be_truthy
|
174
174
|
end
|
175
175
|
end
|
176
176
|
|
@@ -180,7 +180,7 @@ DIRTY
|
|
180
180
|
end
|
181
181
|
|
182
182
|
it "resets to default state by checking out the default branch" do
|
183
|
-
@cookbook_repo.
|
183
|
+
expect(@cookbook_repo).to receive(:shell_out!).with('git checkout develop', :cwd => @repo_path)
|
184
184
|
@cookbook_repo.reset_to_default_state
|
185
185
|
end
|
186
186
|
end
|
@@ -24,17 +24,17 @@ describe Chef::Knife::Core::ObjectLoader do
|
|
24
24
|
before(:each) do
|
25
25
|
@knife = Chef::Knife.new
|
26
26
|
@stdout = StringIO.new
|
27
|
-
@knife.ui.
|
27
|
+
allow(@knife.ui).to receive(:stdout).and_return(@stdout)
|
28
28
|
Dir.chdir(File.join(CHEF_SPEC_DATA, 'object_loader'))
|
29
29
|
end
|
30
30
|
|
31
31
|
shared_examples_for "Chef object" do |chef_class|
|
32
32
|
it "should create a #{chef_class} object" do
|
33
|
-
@object.
|
33
|
+
expect(@object).to be_a_kind_of(chef_class)
|
34
34
|
end
|
35
35
|
|
36
36
|
it "should has a attribute 'name'" do
|
37
|
-
@object.name.
|
37
|
+
expect(@object.name).to eql('test')
|
38
38
|
end
|
39
39
|
end
|
40
40
|
|
@@ -20,22 +20,22 @@ require 'spec_helper'
|
|
20
20
|
|
21
21
|
describe Chef::Knife::SubcommandLoader do
|
22
22
|
before do
|
23
|
-
Chef::Platform.
|
23
|
+
allow(Chef::Platform).to receive(:windows?) { false }
|
24
24
|
@home = File.join(CHEF_SPEC_DATA, 'knife-home')
|
25
25
|
@env = {'HOME' => @home}
|
26
26
|
@loader = Chef::Knife::SubcommandLoader.new(File.join(CHEF_SPEC_DATA, 'knife-site-subcommands'), @env)
|
27
27
|
end
|
28
28
|
|
29
29
|
it "builds a list of the core subcommand file require paths" do
|
30
|
-
@loader.subcommand_files.
|
30
|
+
expect(@loader.subcommand_files).not_to be_empty
|
31
31
|
@loader.subcommand_files.each do |require_path|
|
32
|
-
require_path.
|
32
|
+
expect(require_path).to match(/chef\/knife\/.*|plugins\/knife\/.*/)
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
36
|
it "finds files installed via rubygems" do
|
37
|
-
@loader.find_subcommands_via_rubygems.
|
38
|
-
@loader.find_subcommands_via_rubygems.each {|rel_path, abs_path| abs_path.
|
37
|
+
expect(@loader.find_subcommands_via_rubygems).to include('chef/knife/node_create')
|
38
|
+
@loader.find_subcommands_via_rubygems.each {|rel_path, abs_path| expect(abs_path).to match(%r[chef/knife/.+])}
|
39
39
|
end
|
40
40
|
|
41
41
|
it "finds files from latest version of installed gems" do
|
@@ -44,74 +44,148 @@ describe Chef::Knife::SubcommandLoader do
|
|
44
44
|
'/usr/lib/ruby/gems/knife-ec2-0.5.12/lib/chef/knife/ec2_base.rb',
|
45
45
|
'/usr/lib/ruby/gems/knife-ec2-0.5.12/lib/chef/knife/ec2_otherstuff.rb'
|
46
46
|
]
|
47
|
-
$LOAD_PATH.
|
47
|
+
expect($LOAD_PATH).to receive(:map).and_return([])
|
48
48
|
if Gem::Specification.respond_to? :latest_specs
|
49
|
-
Gem::Specification.
|
50
|
-
gems[0].
|
49
|
+
expect(Gem::Specification).to receive(:latest_specs).with(true).and_return(gems)
|
50
|
+
expect(gems[0]).to receive(:matches_for_glob).with(/chef\/knife\/\*\.rb\{(.*),\.rb,(.*)\}/).and_return(gem_files)
|
51
51
|
else
|
52
|
-
Gem.source_index.
|
53
|
-
gems[0].
|
54
|
-
gems[0].
|
55
|
-
Dir.
|
52
|
+
expect(Gem.source_index).to receive(:latest_specs).with(true).and_return(gems)
|
53
|
+
expect(gems[0]).to receive(:require_paths).twice.and_return(['lib'])
|
54
|
+
expect(gems[0]).to receive(:full_gem_path).and_return('/usr/lib/ruby/gems/knife-ec2-0.5.12')
|
55
|
+
expect(Dir).to receive(:[]).with('/usr/lib/ruby/gems/knife-ec2-0.5.12/lib/chef/knife/*.rb').and_return(gem_files)
|
56
56
|
end
|
57
|
-
@loader.
|
58
|
-
@loader.find_subcommands_via_rubygems.values.select { |file| file =~ /knife-ec2/ }.sort.
|
57
|
+
expect(@loader).to receive(:find_subcommands_via_dirglob).and_return({})
|
58
|
+
expect(@loader.find_subcommands_via_rubygems.values.select { |file| file =~ /knife-ec2/ }.sort).to eq(gem_files)
|
59
59
|
end
|
60
60
|
|
61
61
|
it "finds files using a dirglob when rubygems is not available" do
|
62
|
-
@loader.find_subcommands_via_dirglob.
|
63
|
-
@loader.find_subcommands_via_dirglob.each {|rel_path, abs_path| abs_path.
|
62
|
+
expect(@loader.find_subcommands_via_dirglob).to include('chef/knife/node_create')
|
63
|
+
@loader.find_subcommands_via_dirglob.each {|rel_path, abs_path| expect(abs_path).to match(%r[chef/knife/.+])}
|
64
64
|
end
|
65
65
|
|
66
66
|
it "finds user-specific subcommands in the user's ~/.chef directory" do
|
67
67
|
expected_command = File.join(@home, '.chef', 'plugins', 'knife', 'example_home_subcommand.rb')
|
68
|
-
@loader.site_subcommands.
|
68
|
+
expect(@loader.site_subcommands).to include(expected_command)
|
69
69
|
end
|
70
70
|
|
71
71
|
it "finds repo specific subcommands by searching for a .chef directory" do
|
72
72
|
expected_command = File.join(CHEF_SPEC_DATA, 'knife-site-subcommands', 'plugins', 'knife', 'example_subcommand.rb')
|
73
|
-
@loader.site_subcommands.
|
73
|
+
expect(@loader.site_subcommands).to include(expected_command)
|
74
74
|
end
|
75
75
|
|
76
|
-
|
76
|
+
# https://github.com/opscode/chef-dk/issues/227
|
77
|
+
#
|
78
|
+
# `knife` in ChefDK isn't from a gem install, it's directly run from a clone
|
79
|
+
# of the source, but there can be one or more versions of chef also installed
|
80
|
+
# as a gem. If the gem install contains a command that doesn't exist in the
|
81
|
+
# source tree of the "primary" chef install, it can be loaded and cause an
|
82
|
+
# error. We also want to ensure that we only load builtin commands from the
|
83
|
+
# "primary" chef install.
|
84
|
+
context "when a different version of chef is also installed as a gem" do
|
85
|
+
|
86
|
+
let(:all_found_commands) do
|
87
|
+
[
|
88
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/bootstrap.rb",
|
89
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/client_bulk_delete.rb",
|
90
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/client_create.rb",
|
91
|
+
|
92
|
+
# We use the fake version 1.0.0 because that version doesn't exist,
|
93
|
+
# which ensures it won't ever equal "chef-#{Chef::VERSION}"
|
94
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-1.0.0/lib/chef/knife/bootstrap.rb",
|
95
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-1.0.0/lib/chef/knife/client_bulk_delete.rb",
|
96
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-1.0.0/lib/chef/knife/client_create.rb",
|
97
|
+
|
98
|
+
# Test that we don't accept a version number that is different only in
|
99
|
+
# trailing characters, e.g. we are running Chef 12.0.0 but there is a
|
100
|
+
# Chef 12.0.0.rc.0 gem also:
|
101
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-#{Chef::VERSION}.rc.0/lib/chef/knife/thing.rb",
|
102
|
+
|
103
|
+
# This command is "extra" compared to what's in the embedded/apps/chef install:
|
104
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-1.0.0/lib/chef/knife/data_bag_secret_options.rb",
|
105
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-vault-2.2.4/lib/chef/knife/decrypt.rb",
|
106
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/knife-spork-1.4.1/lib/chef/knife/spork-bump.rb",
|
107
|
+
|
108
|
+
# These are fake commands that have names designed to test that the
|
109
|
+
# regex is strict enough
|
110
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-foo-#{Chef::VERSION}/lib/chef/knife/chef-foo.rb",
|
111
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/foo-chef-#{Chef::VERSION}/lib/chef/knife/foo-chef.rb",
|
112
|
+
|
113
|
+
# In a real scenario, we'd use rubygems APIs to only select the most
|
114
|
+
# recent gem, but for this test we want to check that we're doing the
|
115
|
+
# right thing both when the plugin version matches and does not match
|
116
|
+
# the current chef version. Looking at
|
117
|
+
# `SubcommandLoader::MATCHES_THIS_CHEF_GEM` and
|
118
|
+
# `SubcommandLoader::MATCHES_CHEF_GEM` should make it clear why we want
|
119
|
+
# to test these two cases.
|
120
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-bar-1.0.0/lib/chef/knife/chef-bar.rb",
|
121
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/bar-chef-1.0.0/lib/chef/knife/bar-chef.rb"
|
122
|
+
]
|
123
|
+
end
|
124
|
+
|
125
|
+
let(:expected_valid_commands) do
|
126
|
+
[
|
127
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/bootstrap.rb",
|
128
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/client_bulk_delete.rb",
|
129
|
+
"/opt/chefdk/embedded/apps/chef/lib/chef/knife/client_create.rb",
|
130
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-vault-2.2.4/lib/chef/knife/decrypt.rb",
|
131
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/knife-spork-1.4.1/lib/chef/knife/spork-bump.rb",
|
132
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-foo-#{Chef::VERSION}/lib/chef/knife/chef-foo.rb",
|
133
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/foo-chef-#{Chef::VERSION}/lib/chef/knife/foo-chef.rb",
|
134
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/chef-bar-1.0.0/lib/chef/knife/chef-bar.rb",
|
135
|
+
"/opt/chefdk/embedded/lib/ruby/gems/2.1.0/gems/bar-chef-1.0.0/lib/chef/knife/bar-chef.rb"
|
136
|
+
]
|
137
|
+
end
|
138
|
+
|
139
|
+
before do
|
140
|
+
expect(@loader).to receive(:find_files_latest_gems).with("chef/knife/*.rb").and_return(all_found_commands)
|
141
|
+
expect(@loader).to receive(:find_subcommands_via_dirglob).and_return({})
|
142
|
+
end
|
143
|
+
|
144
|
+
it "ignores commands from the non-matching gem install" do
|
145
|
+
expect(@loader.find_subcommands_via_rubygems.values).to eq(expected_valid_commands)
|
146
|
+
end
|
147
|
+
|
148
|
+
end
|
149
|
+
|
150
|
+
describe "finding 3rd party plugins" do
|
77
151
|
let(:env_home) { "/home/alice" }
|
78
152
|
let(:manifest_path) { env_home + "/.chef/plugin_manifest.json" }
|
79
153
|
|
80
154
|
before do
|
81
155
|
env_dup = ENV.to_hash
|
82
|
-
ENV.
|
83
|
-
ENV.
|
156
|
+
allow(ENV).to receive(:[]) { |key| env_dup[key] }
|
157
|
+
allow(ENV).to receive(:[]).with("HOME").and_return(env_home)
|
84
158
|
end
|
85
159
|
|
86
160
|
context "when there is not a ~/.chef/plugin_manifest.json file" do
|
87
161
|
before do
|
88
|
-
File.
|
162
|
+
allow(File).to receive(:exist?).with(manifest_path).and_return(false)
|
89
163
|
end
|
90
164
|
|
91
165
|
it "searches rubygems for plugins" do
|
92
166
|
if Gem::Specification.respond_to?(:latest_specs)
|
93
|
-
Gem::Specification.
|
167
|
+
expect(Gem::Specification).to receive(:latest_specs).and_call_original
|
94
168
|
else
|
95
|
-
Gem.source_index.
|
169
|
+
expect(Gem.source_index).to receive(:latest_specs).and_call_original
|
96
170
|
end
|
97
171
|
@loader.subcommand_files.each do |require_path|
|
98
|
-
require_path.
|
172
|
+
expect(require_path).to match(/chef\/knife\/.*|plugins\/knife\/.*/)
|
99
173
|
end
|
100
174
|
end
|
101
175
|
|
102
176
|
context "and HOME environment variable is not set" do
|
103
177
|
before do
|
104
|
-
ENV.
|
178
|
+
allow(ENV).to receive(:[]).with("HOME").and_return(nil)
|
105
179
|
end
|
106
180
|
|
107
181
|
it "searches rubygems for plugins" do
|
108
182
|
if Gem::Specification.respond_to?(:latest_specs)
|
109
|
-
Gem::Specification.
|
183
|
+
expect(Gem::Specification).to receive(:latest_specs).and_call_original
|
110
184
|
else
|
111
|
-
Gem.source_index.
|
185
|
+
expect(Gem.source_index).to receive(:latest_specs).and_call_original
|
112
186
|
end
|
113
187
|
@loader.subcommand_files.each do |require_path|
|
114
|
-
require_path.
|
188
|
+
expect(require_path).to match(/chef\/knife\/.*|plugins\/knife\/.*/)
|
115
189
|
end
|
116
190
|
end
|
117
191
|
end
|
@@ -135,13 +209,13 @@ describe Chef::Knife::SubcommandLoader do
|
|
135
209
|
let(:manifest_json) { Chef::JSONCompat.to_json(manifest_content) }
|
136
210
|
|
137
211
|
before do
|
138
|
-
File.
|
139
|
-
File.
|
212
|
+
allow(File).to receive(:exist?).with(manifest_path).and_return(true)
|
213
|
+
allow(File).to receive(:read).with(manifest_path).and_return(manifest_json)
|
140
214
|
end
|
141
215
|
|
142
216
|
it "uses paths from the manifest instead of searching gems" do
|
143
|
-
Gem::Specification.
|
144
|
-
@loader.subcommand_files.
|
217
|
+
expect(Gem::Specification).not_to receive(:latest_specs).and_call_original
|
218
|
+
expect(@loader.subcommand_files).to include(ec2_server_create_plugin)
|
145
219
|
end
|
146
220
|
|
147
221
|
end
|