chef 12.0.3-x86-mingw32 → 12.1.0.rc.0-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +4 -1
- data/README.md +42 -18
- data/distro/common/html/_sources/ctl_chef_client.txt +1 -1
- data/distro/common/html/_sources/ctl_chef_server.txt +53 -35
- data/distro/common/html/_sources/ctl_chef_solo.txt +1 -1
- data/distro/common/html/_sources/knife_bootstrap.txt +1 -1
- data/distro/common/html/_sources/knife_cookbook_site.txt +1 -1
- data/distro/common/html/_sources/knife_data_bag.txt +4 -4
- data/distro/common/html/_sources/knife_status.txt +1 -1
- data/distro/common/html/_static/searchtools.js +1 -1
- data/distro/common/html/ctl_chef_client.html +55 -7
- data/distro/common/html/ctl_chef_server.html +84 -41
- data/distro/common/html/ctl_chef_shell.html +45 -1
- data/distro/common/html/ctl_chef_solo.html +51 -5
- data/distro/common/html/index.html +2 -2
- data/distro/common/html/knife.html +1 -1
- data/distro/common/html/knife_bootstrap.html +30 -10
- data/distro/common/html/knife_cookbook_site.html +2 -0
- data/distro/common/html/knife_data_bag.html +4 -4
- data/distro/common/html/knife_node.html +2 -2
- data/distro/common/html/knife_raw.html +1 -1
- data/distro/common/html/knife_role.html +1 -1
- data/distro/common/html/knife_search.html +3 -3
- data/distro/common/html/knife_status.html +4 -0
- data/distro/common/html/searchindex.js +1 -1
- data/distro/common/man/man1/chef-shell.1 +72 -1
- data/distro/common/man/man1/knife-bootstrap.1 +71 -63
- data/distro/common/man/man1/knife-client.1 +1 -1
- data/distro/common/man/man1/knife-configure.1 +1 -1
- data/distro/common/man/man1/knife-cookbook-site.1 +4 -1
- data/distro/common/man/man1/knife-cookbook.1 +1 -1
- data/distro/common/man/man1/knife-data-bag.1 +5 -5
- data/distro/common/man/man1/knife-delete.1 +1 -1
- data/distro/common/man/man1/knife-deps.1 +1 -1
- data/distro/common/man/man1/knife-diff.1 +1 -1
- data/distro/common/man/man1/knife-download.1 +1 -1
- data/distro/common/man/man1/knife-edit.1 +1 -1
- data/distro/common/man/man1/knife-environment.1 +1 -1
- data/distro/common/man/man1/knife-exec.1 +1 -1
- data/distro/common/man/man1/knife-index-rebuild.1 +1 -1
- data/distro/common/man/man1/knife-list.1 +1 -1
- data/distro/common/man/man1/knife-node.1 +3 -3
- data/distro/common/man/man1/knife-raw.1 +2 -2
- data/distro/common/man/man1/knife-recipe-list.1 +1 -1
- data/distro/common/man/man1/knife-role.1 +2 -2
- data/distro/common/man/man1/knife-search.1 +4 -4
- data/distro/common/man/man1/knife-serve.1 +1 -1
- data/distro/common/man/man1/knife-show.1 +1 -1
- data/distro/common/man/man1/knife-ssh.1 +1 -1
- data/distro/common/man/man1/knife-ssl-check.1 +1 -1
- data/distro/common/man/man1/knife-ssl-fetch.1 +1 -1
- data/distro/common/man/man1/knife-status.1 +1 -1
- data/distro/common/man/man1/knife-tag.1 +1 -1
- data/distro/common/man/man1/knife-upload.1 +1 -1
- data/distro/common/man/man1/knife-user.1 +1 -1
- data/distro/common/man/man1/knife-xargs.1 +1 -1
- data/distro/common/man/man1/knife.1 +1 -1
- data/distro/common/man/man8/chef-apply.8 +86 -0
- data/distro/common/man/man8/chef-client.8 +76 -5
- data/distro/common/man/man8/chef-solo.8 +79 -6
- data/distro/common/markdown/man1/knife-bootstrap.mkd +1 -1
- data/distro/common/markdown/man1/knife-cookbook-site.mkd +1 -1
- data/distro/common/markdown/man1/knife-data-bag.mkd +1 -1
- data/distro/common/markdown/man1/knife-environment.mkd +1 -1
- data/distro/common/markdown/man1/knife.mkd +1 -1
- data/lib/chef.rb +0 -7
- data/lib/chef/api_client.rb +10 -2
- data/lib/chef/api_client/registration.rb +7 -9
- data/lib/chef/application.rb +28 -12
- data/lib/chef/application/apply.rb +17 -1
- data/lib/chef/application/client.rb +74 -6
- data/lib/chef/application/knife.rb +1 -2
- data/lib/chef/application/solo.rb +30 -0
- data/lib/chef/application/windows_service.rb +1 -0
- data/lib/chef/application/windows_service_manager.rb +8 -2
- data/lib/chef/applications.rb +0 -1
- data/lib/chef/audit/audit_event_proxy.rb +93 -0
- data/lib/chef/audit/audit_reporter.rb +169 -0
- data/lib/chef/audit/control_group_data.rb +140 -0
- data/lib/chef/audit/rspec_formatter.rb +37 -0
- data/lib/chef/audit/runner.rb +178 -0
- data/lib/chef/chef_fs/chef_fs_data_store.rb +11 -2
- data/lib/chef/chef_fs/config.rb +25 -4
- data/lib/chef/chef_fs/data_handler/policy_data_handler.rb +15 -0
- data/lib/chef/chef_fs/data_handler/user_data_handler.rb +1 -0
- data/lib/chef/chef_fs/file_system.rb +1 -1
- data/lib/chef/chef_fs/file_system/base_fs_dir.rb +5 -0
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbook_entry.rb +3 -2
- data/lib/chef/{shef/ext.rb → chef_fs/file_system/chef_repository_file_system_policies_dir.rb} +22 -3
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_root_dir.rb +4 -0
- data/lib/chef/client.rb +81 -52
- data/lib/chef/config.rb +35 -3
- data/lib/chef/cookbook/metadata.rb +3 -3
- data/lib/chef/cookbook_manifest.rb +275 -0
- data/lib/chef/cookbook_site_streaming_uploader.rb +24 -23
- data/lib/chef/cookbook_uploader.rb +11 -2
- data/lib/chef/cookbook_version.rb +71 -194
- data/lib/chef/data_bag.rb +5 -2
- data/lib/chef/data_bag_item.rb +6 -3
- data/lib/chef/deprecation/warnings.rb +5 -4
- data/lib/chef/dsl/audit.rb +51 -0
- data/lib/chef/dsl/include_recipe.rb +2 -3
- data/lib/chef/dsl/reboot_pending.rb +1 -1
- data/lib/chef/dsl/recipe.rb +49 -31
- data/lib/chef/encrypted_data_bag_item/assertions.rb +0 -3
- data/lib/chef/environment.rb +5 -2
- data/lib/chef/event_dispatch/base.rb +36 -1
- data/lib/chef/event_dispatch/dispatcher.rb +3 -5
- data/lib/chef/exceptions.rb +61 -2
- data/lib/chef/file_access_control/unix.rb +12 -0
- data/lib/chef/file_access_control/windows.rb +14 -0
- data/lib/chef/formatters/doc.rb +47 -1
- data/{spec/unit/monkey_patches/string_spec.rb → lib/chef/guard_interpreter.rb} +11 -16
- data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +3 -2
- data/lib/chef/http.rb +1 -2
- data/lib/chef/knife.rb +5 -3
- data/lib/chef/knife/bootstrap.rb +84 -15
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +165 -0
- data/lib/chef/knife/bootstrap/client_builder.rb +190 -0
- data/lib/chef/knife/bootstrap/{README.md → templates/README.md} +0 -0
- data/lib/chef/knife/bootstrap/{archlinux-gems.erb → templates/archlinux-gems.erb} +9 -0
- data/lib/chef/knife/bootstrap/{chef-aix.erb → templates/chef-aix.erb} +9 -0
- data/lib/chef/knife/bootstrap/{chef-full.erb → templates/chef-full.erb} +10 -1
- data/lib/chef/knife/client_create.rb +8 -7
- data/lib/chef/knife/cookbook_site_download.rb +1 -1
- data/lib/chef/knife/cookbook_site_install.rb +1 -1
- data/lib/chef/knife/cookbook_site_list.rb +1 -1
- data/lib/chef/knife/cookbook_site_search.rb +1 -1
- data/lib/chef/knife/cookbook_site_share.rb +39 -28
- data/lib/chef/knife/cookbook_site_show.rb +3 -3
- data/lib/chef/knife/cookbook_site_unshare.rb +1 -1
- data/lib/chef/knife/cookbook_test.rb +1 -0
- data/lib/chef/knife/cookbook_upload.rb +13 -8
- data/lib/chef/knife/core/bootstrap_context.rb +14 -3
- data/lib/chef/knife/core/generic_presenter.rb +5 -2
- data/lib/chef/knife/core/object_loader.rb +1 -1
- data/lib/chef/knife/core/subcommand_loader.rb +24 -0
- data/lib/chef/knife/core/ui.rb +9 -1
- data/lib/chef/knife/node_run_list_remove.rb +11 -3
- data/lib/chef/knife/raw.rb +14 -3
- data/lib/chef/knife/role_env_run_list_add.rb +86 -0
- data/lib/chef/knife/role_env_run_list_clear.rb +55 -0
- data/lib/chef/knife/role_env_run_list_remove.rb +57 -0
- data/lib/chef/knife/role_env_run_list_replace.rb +59 -0
- data/lib/chef/knife/role_env_run_list_set.rb +70 -0
- data/lib/chef/knife/role_run_list_add.rb +86 -0
- data/lib/chef/knife/role_run_list_clear.rb +55 -0
- data/lib/chef/knife/role_run_list_remove.rb +57 -0
- data/lib/chef/knife/role_run_list_replace.rb +59 -0
- data/lib/chef/knife/role_run_list_set.rb +70 -0
- data/lib/chef/knife/search.rb +4 -4
- data/lib/chef/knife/serve.rb +3 -0
- data/lib/chef/knife/ssh.rb +1 -1
- data/lib/chef/knife/ssl_check.rb +2 -2
- data/lib/chef/knife/ssl_fetch.rb +14 -1
- data/lib/chef/log.rb +10 -1
- data/lib/chef/mixin/command.rb +1 -1
- data/lib/chef/mixin/command/windows.rb +1 -5
- data/lib/chef/mixin/get_source_from_package.rb +1 -0
- data/lib/chef/mixin/params_validate.rb +2 -2
- data/lib/chef/mixin/securable.rb +1 -7
- data/lib/chef/mixin/shell_out.rb +7 -1
- data/lib/chef/mixin/template.rb +2 -14
- data/lib/chef/mixin/why_run.rb +1 -1
- data/lib/chef/monkey_patches/net_http.rb +4 -0
- data/lib/chef/monologger.rb +0 -2
- data/lib/chef/node.rb +5 -2
- data/lib/chef/node/attribute.rb +11 -9
- data/lib/chef/node/attribute_collections.rb +8 -12
- data/lib/chef/node/immutable_collections.rb +4 -10
- data/lib/chef/org.rb +148 -0
- data/lib/chef/platform/provider_mapping.rb +3 -2
- data/lib/chef/platform/provider_priority_map.rb +2 -0
- data/lib/chef/platform/query_helpers.rb +0 -3
- data/lib/chef/policy_builder/policyfile.rb +51 -8
- data/lib/chef/provider/deploy.rb +1 -2
- data/lib/chef/provider/directory.rb +3 -3
- data/lib/chef/provider/dsc_script.rb +13 -7
- data/lib/chef/provider/env.rb +8 -8
- data/lib/chef/provider/execute.rb +55 -36
- data/lib/chef/provider/file.rb +8 -0
- data/lib/chef/provider/group.rb +2 -0
- data/lib/chef/provider/group/dscl.rb +3 -4
- data/lib/chef/provider/ifconfig.rb +25 -25
- data/lib/chef/provider/ifconfig/aix.rb +25 -27
- data/lib/chef/provider/lwrp_base.rb +1 -1
- data/lib/chef/provider/mount.rb +2 -2
- data/lib/chef/provider/mount/mount.rb +3 -4
- data/lib/chef/provider/mount/solaris.rb +1 -1
- data/lib/chef/provider/package.rb +297 -48
- data/lib/chef/provider/package/aix.rb +25 -30
- data/lib/chef/provider/package/apt.rb +63 -19
- data/lib/chef/provider/package/dpkg.rb +15 -16
- data/lib/chef/provider/package/macports.rb +7 -7
- data/lib/chef/provider/package/openbsd.rb +107 -0
- data/lib/chef/provider/package/pacman.rb +13 -15
- data/lib/chef/provider/package/portage.rb +3 -4
- data/lib/chef/provider/package/rpm.rb +28 -17
- data/lib/chef/provider/package/rubygems.rb +9 -9
- data/lib/chef/provider/package/solaris.rb +17 -21
- data/lib/chef/provider/package/windows/msi.rb +1 -1
- data/lib/chef/provider/package/yum-dump.py +2 -2
- data/lib/chef/provider/package/yum.rb +117 -51
- data/lib/chef/provider/package/zypper.rb +17 -18
- data/lib/chef/provider/powershell_script.rb +4 -4
- data/lib/chef/provider/registry_key.rb +2 -2
- data/lib/chef/provider/remote_directory.rb +1 -1
- data/lib/chef/provider/script.rb +25 -16
- data/lib/chef/provider/service.rb +1 -1
- data/lib/chef/provider/service/freebsd.rb +1 -1
- data/lib/chef/provider/service/openbsd.rb +216 -0
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/service/windows.rb +99 -1
- data/lib/chef/provider/user.rb +1 -1
- data/lib/chef/provider/user/dscl.rb +19 -4
- data/lib/chef/providers.rb +2 -0
- data/lib/chef/recipe.rb +11 -5
- data/lib/chef/request_id.rb +1 -1
- data/lib/chef/resource.rb +839 -444
- data/lib/chef/resource/chef_gem.rb +20 -3
- data/lib/chef/resource/conditional.rb +3 -14
- data/lib/chef/resource/dsc_script.rb +14 -0
- data/lib/chef/resource/execute.rb +14 -7
- data/lib/chef/resource/file.rb +14 -0
- data/lib/chef/resource/file/verification.rb +122 -0
- data/lib/chef/resource/ips_package.rb +1 -1
- data/lib/chef/resource/lwrp_base.rb +2 -11
- data/lib/chef/resource/macports_package.rb +2 -1
- data/lib/chef/resource/openbsd_package.rb +51 -0
- data/lib/chef/resource/package.rb +2 -2
- data/lib/chef/resource/paludis_package.rb +1 -1
- data/lib/chef/resource/reboot.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -0
- data/lib/chef/resource/rpm_package.rb +9 -0
- data/lib/chef/resource/script.rb +11 -0
- data/lib/chef/resource/template.rb +2 -3
- data/lib/chef/resource/windows_package.rb +1 -1
- data/lib/chef/resource/windows_service.rb +18 -0
- data/lib/chef/resource_builder.rb +137 -0
- data/lib/chef/resource_definition.rb +1 -1
- data/lib/chef/resource_reporter.rb +1 -1
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/role.rb +17 -4
- data/lib/chef/run_context.rb +10 -6
- data/lib/chef/search/query.rb +66 -87
- data/lib/chef/shell/ext.rb +2 -2
- data/lib/chef/util/diff.rb +1 -4
- data/lib/chef/util/dsc/configuration_generator.rb +30 -6
- data/lib/chef/util/dsc/lcm_output_parser.rb +7 -3
- data/lib/chef/util/dsc/local_configuration_manager.rb +8 -8
- data/lib/chef/util/file_edit.rb +2 -2
- data/lib/chef/util/path_helper.rb +1 -4
- data/lib/chef/util/windows/net_use.rb +3 -3
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +1 -0
- data/lib/chef/win32/api/security.rb +26 -0
- data/lib/chef/win32/file.rb +21 -0
- data/lib/chef/win32/security.rb +46 -0
- data/lib/chef/win32/security/token.rb +8 -0
- data/lib/chef/win32/version.rb +0 -4
- data/spec/data/recipes.tgz +0 -0
- data/spec/functional/application_spec.rb +1 -1
- data/spec/functional/audit/rspec_formatter_spec.rb +54 -0
- data/spec/functional/audit/runner_spec.rb +137 -0
- data/spec/functional/dsl/reboot_pending_spec.rb +10 -10
- data/spec/functional/dsl/registry_helper_spec.rb +6 -6
- data/spec/functional/event_loggers/windows_eventlog_spec.rb +5 -5
- data/spec/functional/file_content_management/deploy_strategies_spec.rb +12 -21
- data/spec/functional/http/simple_spec.rb +1 -1
- data/spec/functional/knife/cookbook_delete_spec.rb +24 -24
- data/spec/functional/knife/exec_spec.rb +2 -4
- data/spec/functional/knife/smoke_test.rb +1 -1
- data/spec/functional/knife/ssh_spec.rb +23 -23
- data/spec/functional/provider/remote_file/cache_control_data_spec.rb +8 -8
- data/spec/functional/provider/whyrun_safe_ruby_block_spec.rb +2 -2
- data/spec/functional/rebooter_spec.rb +1 -1
- data/spec/functional/resource/aix_service_spec.rb +3 -0
- data/spec/functional/resource/aixinit_service_spec.rb +3 -3
- data/spec/functional/resource/bash_spec.rb +88 -0
- data/spec/functional/resource/deploy_revision_spec.rb +99 -100
- data/spec/functional/resource/env_spec.rb +3 -3
- data/spec/functional/resource/execute_spec.rb +97 -63
- data/spec/functional/resource/file_spec.rb +7 -7
- data/spec/functional/resource/git_spec.rb +13 -13
- data/spec/functional/resource/group_spec.rb +28 -25
- data/spec/functional/resource/ifconfig_spec.rb +2 -2
- data/spec/functional/resource/link_spec.rb +77 -78
- data/spec/functional/resource/mount_spec.rb +5 -5
- data/spec/functional/resource/ohai_spec.rb +1 -1
- data/spec/functional/resource/package_spec.rb +22 -22
- data/spec/functional/resource/powershell_spec.rb +57 -42
- data/spec/functional/resource/reboot_spec.rb +2 -2
- data/spec/functional/resource/registry_spec.rb +91 -91
- data/spec/functional/resource/remote_directory_spec.rb +19 -19
- data/spec/functional/resource/remote_file_spec.rb +18 -18
- data/spec/functional/resource/template_spec.rb +4 -4
- data/spec/functional/resource/user/dscl_spec.rb +4 -4
- data/spec/functional/resource/user/useradd_spec.rb +64 -51
- data/spec/functional/resource/windows_service_spec.rb +98 -0
- data/spec/functional/run_lock_spec.rb +9 -9
- data/spec/functional/shell_spec.rb +3 -3
- data/spec/functional/tiny_server_spec.rb +12 -12
- data/spec/functional/util/path_helper_spec.rb +1 -1
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/registry_helper_spec.rb +125 -125
- data/spec/functional/win32/security_spec.rb +65 -2
- data/spec/functional/win32/service_manager_spec.rb +30 -84
- data/spec/functional/win32/versions_spec.rb +6 -6
- data/spec/integration/client/client_spec.rb +102 -9
- data/spec/integration/knife/chef_fs_data_store_spec.rb +12 -8
- data/spec/integration/knife/common_options_spec.rb +3 -3
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +2 -2
- data/spec/integration/knife/deps_spec.rb +4 -4
- data/spec/integration/knife/diff_spec.rb +6 -6
- data/spec/integration/knife/download_spec.rb +6 -6
- data/spec/integration/knife/list_spec.rb +2 -2
- data/spec/integration/knife/raw_spec.rb +5 -5
- data/spec/integration/knife/serve_spec.rb +3 -3
- data/spec/integration/knife/show_spec.rb +3 -3
- data/spec/integration/knife/upload_spec.rb +18 -18
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/integration/solo/solo_spec.rb +11 -12
- data/spec/spec_helper.rb +27 -15
- data/spec/stress/win32/file_spec.rb +4 -4
- data/spec/stress/win32/security_spec.rb +4 -4
- data/spec/support/chef_helpers.rb +3 -3
- data/spec/support/matchers/leak.rb +2 -2
- data/spec/support/mock/platform.rb +1 -1
- data/spec/support/pedant/Gemfile +3 -0
- data/spec/support/pedant/pedant_config.rb +9 -2
- data/spec/support/pedant/run_pedant.rb +15 -16
- data/spec/support/platform_helpers.rb +8 -12
- data/spec/support/shared/functional/directory_resource.rb +13 -13
- data/spec/support/shared/functional/file_resource.rb +83 -83
- data/spec/support/shared/functional/http.rb +1 -1
- data/spec/support/shared/functional/securable_resource.rb +64 -64
- data/spec/support/shared/functional/securable_resource_with_reporting.rb +43 -41
- data/spec/support/shared/functional/win32_service.rb +60 -0
- data/spec/support/shared/functional/windows_script.rb +8 -8
- data/spec/support/shared/integration/knife_support.rb +8 -5
- data/spec/support/shared/matchers/exit_with_code.rb +6 -2
- data/spec/support/shared/unit/api_error_inspector.rb +8 -8
- data/spec/support/shared/unit/execute_resource.rb +24 -20
- data/spec/support/shared/unit/file_system_support.rb +2 -2
- data/spec/support/shared/unit/platform_introspector.rb +21 -21
- data/spec/support/shared/unit/provider/file.rb +239 -210
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +69 -69
- data/spec/support/shared/unit/script_resource.rb +40 -32
- data/spec/support/shared/unit/windows_script_resource.rb +8 -8
- data/spec/unit/api_client/registration_spec.rb +47 -47
- data/spec/unit/api_client_spec.rb +107 -69
- data/spec/unit/application/apply_spec.rb +31 -15
- data/spec/unit/application/client_spec.rb +146 -45
- data/spec/unit/application/knife_spec.rb +31 -31
- data/spec/unit/application/solo_spec.rb +59 -43
- data/spec/unit/application_spec.rb +109 -74
- data/spec/unit/audit/audit_event_proxy_spec.rb +311 -0
- data/spec/unit/audit/audit_reporter_spec.rb +393 -0
- data/spec/unit/audit/control_group_data_spec.rb +478 -0
- data/{lib/chef/monkey_patches/file.rb → spec/unit/audit/rspec_formatter_spec.rb} +11 -8
- data/spec/unit/audit/runner_spec.rb +135 -0
- data/spec/unit/chef_fs/config_spec.rb +52 -0
- data/spec/unit/chef_fs/diff_spec.rb +12 -12
- data/spec/unit/chef_fs/file_pattern_spec.rb +276 -277
- data/spec/unit/chef_fs/file_system/operation_failed_error_spec.rb +6 -6
- data/spec/unit/chef_fs/file_system_spec.rb +26 -13
- data/spec/unit/chef_fs/parallelizer.rb +87 -87
- data/spec/unit/chef_spec.rb +1 -1
- data/spec/unit/client_spec.rb +263 -97
- data/spec/unit/config_fetcher_spec.rb +13 -13
- data/spec/unit/config_spec.rb +105 -66
- data/spec/unit/cookbook/chefignore_spec.rb +6 -6
- data/spec/unit/cookbook/cookbook_version_loader_spec.rb +3 -3
- data/spec/unit/cookbook/metadata_spec.rb +149 -149
- data/spec/unit/cookbook/syntax_check_spec.rb +36 -31
- data/spec/unit/cookbook_loader_spec.rb +62 -58
- data/spec/unit/cookbook_manifest_spec.rb +141 -468
- data/spec/unit/cookbook_site_streaming_uploader_spec.rb +27 -27
- data/spec/unit/cookbook_spec.rb +15 -15
- data/spec/unit/cookbook_uploader_spec.rb +37 -3
- data/spec/unit/cookbook_version_file_specificity_spec.rb +554 -0
- data/spec/unit/cookbook_version_spec.rb +98 -240
- data/spec/unit/daemon_spec.rb +31 -31
- data/spec/unit/data_bag_item_spec.rb +121 -89
- data/spec/unit/data_bag_spec.rb +35 -35
- data/spec/unit/deprecation_spec.rb +27 -14
- data/spec/unit/digester_spec.rb +3 -3
- data/spec/unit/dsl/audit_spec.rb +43 -0
- data/spec/unit/dsl/data_query_spec.rb +1 -1
- data/spec/unit/dsl/platform_introspection_spec.rb +14 -14
- data/spec/unit/dsl/reboot_pending_spec.rb +18 -18
- data/spec/unit/dsl/regsitry_helper_spec.rb +6 -6
- data/spec/unit/encrypted_data_bag_item_spec.rb +58 -82
- data/spec/unit/environment_spec.rb +105 -105
- data/spec/unit/exceptions_spec.rb +47 -1
- data/spec/unit/file_access_control_spec.rb +62 -56
- data/spec/unit/file_cache_spec.rb +11 -11
- data/spec/unit/file_content_management/deploy/cp_spec.rb +2 -2
- data/spec/unit/file_content_management/deploy/mv_unix_spec.rb +10 -10
- data/spec/unit/file_content_management/deploy/mv_windows_spec.rb +23 -23
- data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +14 -14
- data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +12 -12
- data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +1 -1
- data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +16 -16
- data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +4 -4
- data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +103 -13
- data/spec/unit/guard_interpreter_spec.rb +41 -0
- data/spec/unit/handler/json_file_spec.rb +10 -10
- data/spec/unit/handler_spec.rb +39 -39
- data/spec/unit/http/basic_client_spec.rb +3 -3
- data/spec/unit/http/http_request_spec.rb +10 -10
- data/spec/unit/http/simple_spec.rb +3 -3
- data/spec/unit/http/ssl_policies_spec.rb +15 -15
- data/spec/unit/http/validate_content_length_spec.rb +18 -13
- data/spec/unit/http_spec.rb +16 -9
- data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +153 -0
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +178 -0
- data/spec/unit/knife/bootstrap_spec.rb +144 -91
- data/spec/unit/knife/client_bulk_delete_spec.rb +24 -24
- data/spec/unit/knife/client_create_spec.rb +57 -43
- data/spec/unit/knife/client_delete_spec.rb +15 -15
- data/spec/unit/knife/client_edit_spec.rb +4 -4
- data/spec/unit/knife/client_list_spec.rb +2 -2
- data/spec/unit/knife/client_reregister_spec.rb +9 -9
- data/spec/unit/knife/configure_client_spec.rb +20 -20
- data/spec/unit/knife/configure_spec.rb +85 -85
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +15 -15
- data/spec/unit/knife/cookbook_create_spec.rb +59 -59
- data/spec/unit/knife/cookbook_delete_spec.rb +49 -49
- data/spec/unit/knife/cookbook_download_spec.rb +56 -56
- data/spec/unit/knife/cookbook_list_spec.rb +9 -9
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +8 -8
- data/spec/unit/knife/cookbook_metadata_spec.rb +44 -44
- data/spec/unit/knife/cookbook_show_spec.rb +29 -29
- data/spec/unit/knife/cookbook_site_download_spec.rb +26 -26
- data/spec/unit/knife/cookbook_site_install_spec.rb +5 -1
- data/spec/unit/knife/cookbook_site_share_spec.rb +68 -59
- data/spec/unit/knife/cookbook_site_unshare_spec.rb +15 -15
- data/spec/unit/knife/cookbook_test_spec.rb +16 -16
- data/spec/unit/knife/cookbook_upload_spec.rb +105 -71
- data/spec/unit/knife/core/bootstrap_context_spec.rb +37 -22
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +36 -36
- data/spec/unit/knife/core/object_loader_spec.rb +3 -3
- data/spec/unit/knife/core/subcommand_loader_spec.rb +107 -33
- data/spec/unit/knife/core/ui_spec.rb +84 -72
- data/spec/unit/knife/data_bag_from_file_spec.rb +1 -1
- data/spec/unit/knife/environment_compare_spec.rb +12 -12
- data/spec/unit/knife/environment_create_spec.rb +16 -16
- data/spec/unit/knife/environment_delete_spec.rb +14 -14
- data/spec/unit/knife/environment_edit_spec.rb +15 -15
- data/spec/unit/knife/environment_from_file_spec.rb +17 -17
- data/spec/unit/knife/environment_list_spec.rb +7 -7
- data/spec/unit/knife/environment_show_spec.rb +10 -10
- data/spec/unit/knife/index_rebuild_spec.rb +17 -17
- data/spec/unit/knife/knife_help.rb +24 -24
- data/spec/unit/knife/node_bulk_delete_spec.rb +14 -14
- data/spec/unit/knife/node_delete_spec.rb +11 -11
- data/spec/unit/knife/node_edit_spec.rb +17 -17
- data/spec/unit/knife/node_environment_set_spec.rb +12 -12
- data/spec/unit/knife/node_from_file_spec.rb +8 -8
- data/spec/unit/knife/node_list_spec.rb +9 -9
- data/spec/unit/knife/node_run_list_add_spec.rb +29 -29
- data/spec/unit/knife/node_run_list_remove_spec.rb +28 -13
- data/spec/unit/knife/node_run_list_set_spec.rb +27 -27
- data/spec/unit/knife/raw_spec.rb +43 -0
- data/spec/unit/knife/role_bulk_delete_spec.rb +12 -12
- data/spec/unit/knife/role_create_spec.rb +12 -12
- data/spec/unit/knife/role_delete_spec.rb +10 -10
- data/spec/unit/knife/role_edit_spec.rb +13 -13
- data/spec/unit/knife/role_env_run_list_add_spec.rb +217 -0
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +100 -0
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +108 -0
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +108 -0
- data/spec/unit/knife/role_env_run_list_set_spec.rb +102 -0
- data/spec/unit/knife/role_from_file_spec.rb +10 -10
- data/spec/unit/knife/role_list_spec.rb +7 -7
- data/spec/unit/knife/role_run_list_add_spec.rb +179 -0
- data/spec/unit/knife/role_run_list_clear_spec.rb +90 -0
- data/spec/unit/knife/role_run_list_remove_spec.rb +98 -0
- data/spec/unit/knife/role_run_list_replace_spec.rb +101 -0
- data/spec/unit/knife/role_run_list_set_spec.rb +92 -0
- data/spec/unit/knife/ssh_spec.rb +66 -66
- data/spec/unit/knife/ssl_check_spec.rb +27 -27
- data/spec/unit/knife/ssl_fetch_spec.rb +45 -12
- data/spec/unit/knife/status_spec.rb +5 -5
- data/spec/unit/knife/tag_create_spec.rb +5 -5
- data/spec/unit/knife/tag_delete_spec.rb +6 -6
- data/spec/unit/knife/tag_list_spec.rb +4 -4
- data/spec/unit/knife/user_create_spec.rb +18 -18
- data/spec/unit/knife/user_delete_spec.rb +4 -4
- data/spec/unit/knife/user_edit_spec.rb +7 -7
- data/spec/unit/knife/user_list_spec.rb +2 -2
- data/spec/unit/knife/user_reregister_spec.rb +10 -10
- data/spec/unit/knife/user_show_spec.rb +5 -5
- data/spec/unit/knife_spec.rb +36 -36
- data/spec/unit/lwrp_spec.rb +63 -39
- data/spec/unit/mash_spec.rb +6 -6
- data/spec/unit/mixin/checksum_spec.rb +2 -2
- data/spec/unit/mixin/command_spec.rb +13 -13
- data/spec/unit/mixin/convert_to_class_name_spec.rb +6 -6
- data/spec/unit/mixin/deep_merge_spec.rb +49 -49
- data/spec/unit/mixin/deprecation_spec.rb +5 -5
- data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +14 -14
- data/spec/unit/mixin/homebrew_user_spec.rb +3 -3
- data/spec/unit/mixin/params_validate_spec.rb +71 -71
- data/spec/unit/mixin/path_sanity_spec.rb +14 -14
- data/spec/unit/mixin/securable_spec.rb +177 -177
- data/spec/unit/mixin/shell_out_spec.rb +56 -27
- data/spec/unit/mixin/template_spec.rb +31 -31
- data/spec/unit/mixin/windows_architecture_helper_spec.rb +5 -5
- data/spec/unit/mixin/xml_escape_spec.rb +7 -7
- data/spec/unit/monkey_patches/uri_spec.rb +1 -1
- data/spec/unit/monologger_spec.rb +3 -3
- data/spec/unit/node/attribute_spec.rb +185 -136
- data/spec/unit/node/immutable_collections_spec.rb +22 -22
- data/spec/unit/node_spec.rb +210 -179
- data/spec/unit/org_spec.rb +196 -0
- data/spec/unit/platform/query_helpers_spec.rb +5 -5
- data/spec/unit/platform_spec.rb +46 -46
- data/spec/unit/policy_builder/expand_node_object_spec.rb +17 -18
- data/spec/unit/policy_builder/policyfile_spec.rb +159 -71
- data/spec/unit/provider/directory_spec.rb +5 -5
- data/spec/unit/provider/dsc_script_spec.rb +6 -6
- data/spec/unit/provider/env_spec.rb +27 -14
- data/spec/unit/provider/execute_spec.rb +139 -68
- data/spec/unit/provider/file/content_spec.rb +8 -8
- data/spec/unit/provider/git_spec.rb +10 -5
- data/spec/unit/provider/group/dscl_spec.rb +8 -11
- data/spec/unit/provider/group_spec.rb +13 -13
- data/spec/unit/provider/ifconfig/aix_spec.rb +3 -2
- data/spec/unit/provider/ifconfig/debian_spec.rb +19 -19
- data/spec/unit/provider/ifconfig_spec.rb +2 -2
- data/spec/unit/provider/mdadm_spec.rb +2 -2
- data/spec/unit/provider/mount/aix_spec.rb +5 -5
- data/spec/unit/provider/mount/mount_spec.rb +22 -22
- data/spec/unit/provider/mount/solaris_spec.rb +20 -20
- data/spec/unit/provider/package/aix_spec.rb +23 -22
- data/spec/unit/provider/package/apt_spec.rb +23 -4
- data/spec/unit/provider/package/dpkg_spec.rb +14 -15
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +1 -1
- data/spec/unit/provider/package/freebsd/port_spec.rb +1 -1
- data/spec/unit/provider/package/ips_spec.rb +1 -2
- data/spec/unit/provider/package/macports_spec.rb +14 -14
- data/spec/unit/provider/package/openbsd_spec.rb +66 -0
- data/spec/unit/provider/package/pacman_spec.rb +15 -14
- data/spec/unit/provider/package/portage_spec.rb +11 -11
- data/spec/unit/provider/package/rpm_spec.rb +132 -84
- data/spec/unit/provider/package/rubygems_spec.rb +54 -25
- data/spec/unit/provider/package/solaris_spec.rb +22 -25
- data/spec/unit/provider/package/yum_spec.rb +237 -36
- data/spec/unit/provider/package/zypper_spec.rb +9 -12
- data/spec/unit/provider/package_spec.rb +276 -2
- data/spec/unit/provider/package_spec.rbe +0 -0
- data/spec/unit/provider/remote_directory_spec.rb +25 -25
- data/spec/unit/provider/remote_file/ftp_spec.rb +3 -3
- data/spec/unit/provider/route_spec.rb +3 -3
- data/spec/unit/provider/script_spec.rb +61 -43
- data/spec/unit/provider/service/aix_service_spec.rb +5 -5
- data/spec/unit/provider/service/arch_service_spec.rb +5 -5
- data/spec/unit/provider/service/debian_service_spec.rb +8 -8
- data/spec/unit/provider/service/freebsd_service_spec.rb +16 -2
- data/spec/unit/provider/service/gentoo_service_spec.rb +8 -8
- data/spec/unit/provider/service/init_service_spec.rb +5 -5
- data/spec/unit/provider/service/insserv_service_spec.rb +2 -2
- data/spec/unit/provider/service/invokercd_service_spec.rb +5 -5
- data/spec/unit/provider/service/macosx_spec.rb +7 -7
- data/spec/unit/provider/service/openbsd_service_spec.rb +543 -0
- data/spec/unit/provider/service/redhat_spec.rb +4 -4
- data/spec/unit/provider/service/simple_service_spec.rb +2 -2
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +14 -14
- data/spec/unit/provider/service/systemd_service_spec.rb +15 -7
- data/spec/unit/provider/service/upstart_service_spec.rb +4 -4
- data/spec/unit/provider/service/windows_spec.rb +119 -25
- data/spec/unit/provider/service_spec.rb +1 -1
- data/spec/unit/provider/user/dscl_spec.rb +38 -30
- data/spec/unit/provider/user_spec.rb +1 -1
- data/spec/unit/provider_resolver_spec.rb +7 -7
- data/spec/unit/provider_spec.rb +23 -23
- data/spec/unit/recipe_spec.rb +194 -83
- data/spec/unit/registry_helper_spec.rb +143 -143
- data/spec/unit/resource/chef_gem_spec.rb +117 -3
- data/spec/unit/resource/conditional_action_not_nothing_spec.rb +2 -2
- data/spec/unit/resource/conditional_spec.rb +56 -15
- data/spec/unit/resource/deploy_spec.rb +2 -2
- data/spec/unit/resource/dsc_script_spec.rb +32 -0
- data/spec/unit/resource/execute_spec.rb +4 -0
- data/spec/unit/resource/file/verification_spec.rb +111 -0
- data/spec/unit/resource/file_spec.rb +14 -0
- data/spec/unit/resource/openbsd_package_spec.rb +49 -0
- data/spec/unit/resource/remote_file_spec.rb +12 -12
- data/spec/unit/resource/resource_notification_spec.rb +18 -18
- data/spec/unit/resource/rpm_package_spec.rb +12 -0
- data/spec/unit/resource/scm_spec.rb +4 -4
- data/spec/unit/resource/script_spec.rb +3 -5
- data/spec/unit/resource/subversion_spec.rb +1 -1
- data/spec/unit/resource_builder_spec.rb +1 -0
- data/spec/unit/resource_collection/resource_list_spec.rb +2 -2
- data/spec/unit/resource_collection/resource_set_spec.rb +3 -3
- data/spec/unit/resource_collection/stepable_iterator_spec.rb +24 -24
- data/spec/unit/resource_collection_spec.rb +52 -52
- data/spec/unit/resource_definition_spec.rb +1 -1
- data/spec/unit/resource_reporter_spec.rb +118 -118
- data/spec/unit/resource_spec.rb +131 -125
- data/spec/unit/rest/auth_credentials_spec.rb +73 -73
- data/spec/unit/rest_spec.rb +12 -12
- data/spec/unit/role_spec.rb +85 -84
- data/spec/unit/run_context/cookbook_compiler_spec.rb +18 -18
- data/spec/unit/run_context_spec.rb +39 -68
- data/spec/unit/run_list/run_list_expansion_spec.rb +21 -21
- data/spec/unit/run_list/run_list_item_spec.rb +28 -28
- data/spec/unit/run_list/versioned_recipe_list_spec.rb +14 -14
- data/spec/unit/run_list_spec.rb +55 -55
- data/spec/unit/run_lock_spec.rb +14 -14
- data/spec/unit/run_status_spec.rb +24 -24
- data/spec/unit/scan_access_control_spec.rb +23 -23
- data/spec/unit/search/query_spec.rb +54 -66
- data/spec/unit/shell/model_wrapper_spec.rb +13 -13
- data/spec/unit/shell/shell_ext_spec.rb +32 -32
- data/spec/unit/shell/shell_session_spec.rb +24 -24
- data/spec/unit/shell_out_spec.rb +4 -4
- data/spec/unit/shell_spec.rb +27 -27
- data/spec/unit/user_spec.rb +50 -50
- data/spec/unit/util/backup_spec.rb +32 -32
- data/spec/unit/util/diff_spec.rb +31 -31
- data/spec/unit/util/dsc/configuration_generator_spec.rb +38 -16
- data/spec/unit/util/dsc/lcm_output_parser_spec.rb +21 -26
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +10 -10
- data/spec/unit/util/editor_spec.rb +10 -10
- data/spec/unit/util/file_edit_spec.rb +10 -10
- data/spec/unit/util/path_helper_spec.rb +38 -46
- data/spec/unit/util/powershell/cmdlet_spec.rb +9 -9
- data/spec/unit/util/selinux_spec.rb +30 -30
- data/spec/unit/util/threaded_job_queue_spec.rb +6 -6
- data/spec/unit/version/platform_spec.rb +5 -5
- data/spec/unit/version_class_spec.rb +15 -15
- data/spec/unit/version_constraint/platform_spec.rb +7 -7
- data/spec/unit/version_constraint_spec.rb +43 -43
- data/spec/unit/windows_service_spec.rb +15 -15
- data/spec/unit/workstation_config_loader_spec.rb +2 -2
- data/tasks/rspec.rb +16 -18
- metadata +126 -49
- data/bin/shef +0 -35
- data/lib/chef/application/agent.rb +0 -18
- data/lib/chef/monkey_patches/fileutils.rb +0 -65
- data/lib/chef/monkey_patches/numeric.rb +0 -15
- data/lib/chef/monkey_patches/object.rb +0 -9
- data/lib/chef/monkey_patches/pathname.rb +0 -32
- data/lib/chef/monkey_patches/regexp.rb +0 -34
- data/lib/chef/monkey_patches/securerandom.rb +0 -44
- data/lib/chef/monkey_patches/string.rb +0 -49
- data/lib/chef/monkey_patches/tempfile.rb +0 -64
- data/lib/chef/monkey_patches/uri.rb +0 -70
data/lib/chef/formatters/doc.rb
CHANGED
@@ -8,7 +8,9 @@ class Chef
|
|
8
8
|
# "specdoc"
|
9
9
|
class Doc < Formatters::Base
|
10
10
|
|
11
|
-
attr_reader :start_time, :end_time
|
11
|
+
attr_reader :start_time, :end_time, :successful_audits, :failed_audits
|
12
|
+
private :successful_audits, :failed_audits
|
13
|
+
|
12
14
|
cli_name(:doc)
|
13
15
|
|
14
16
|
def initialize(out, err)
|
@@ -16,6 +18,8 @@ class Chef
|
|
16
18
|
|
17
19
|
@updated_resources = 0
|
18
20
|
@up_to_date_resources = 0
|
21
|
+
@successful_audits = 0
|
22
|
+
@failed_audits = 0
|
19
23
|
@start_time = Time.now
|
20
24
|
@end_time = @start_time
|
21
25
|
end
|
@@ -32,12 +36,19 @@ class Chef
|
|
32
36
|
@up_to_date_resources + @updated_resources
|
33
37
|
end
|
34
38
|
|
39
|
+
def total_audits
|
40
|
+
successful_audits + failed_audits
|
41
|
+
end
|
42
|
+
|
35
43
|
def run_completed(node)
|
36
44
|
@end_time = Time.now
|
37
45
|
if Chef::Config[:why_run]
|
38
46
|
puts_line "Chef Client finished, #{@updated_resources}/#{total_resources} resources would have been updated"
|
39
47
|
else
|
40
48
|
puts_line "Chef Client finished, #{@updated_resources}/#{total_resources} resources updated in #{elapsed_time} seconds"
|
49
|
+
if total_audits > 0
|
50
|
+
puts_line " #{successful_audits}/#{total_audits} Audits succeeded"
|
51
|
+
end
|
41
52
|
end
|
42
53
|
end
|
43
54
|
|
@@ -47,6 +58,9 @@ class Chef
|
|
47
58
|
puts_line "Chef Client failed. #{@updated_resources} resources would have been updated"
|
48
59
|
else
|
49
60
|
puts_line "Chef Client failed. #{@updated_resources} resources updated in #{elapsed_time} seconds"
|
61
|
+
if total_audits > 0
|
62
|
+
puts_line " #{successful_audits} Audits succeeded"
|
63
|
+
end
|
50
64
|
end
|
51
65
|
end
|
52
66
|
|
@@ -151,6 +165,38 @@ class Chef
|
|
151
165
|
unindent if @current_recipe
|
152
166
|
end
|
153
167
|
|
168
|
+
def converge_failed(e)
|
169
|
+
# Currently a failed converge is handled the same way as a successful converge
|
170
|
+
converge_complete
|
171
|
+
end
|
172
|
+
|
173
|
+
# Called before audit phase starts
|
174
|
+
def audit_phase_start(run_status)
|
175
|
+
puts_line "Starting audit phase"
|
176
|
+
end
|
177
|
+
|
178
|
+
def audit_phase_complete
|
179
|
+
puts_line "Auditing complete"
|
180
|
+
end
|
181
|
+
|
182
|
+
def audit_phase_failed(error)
|
183
|
+
puts_line ""
|
184
|
+
puts_line "Audit phase exception:"
|
185
|
+
indent
|
186
|
+
puts_line "#{error.message}"
|
187
|
+
error.backtrace.each do |l|
|
188
|
+
puts_line l
|
189
|
+
end
|
190
|
+
end
|
191
|
+
|
192
|
+
def control_example_success(control_group_name, example_data)
|
193
|
+
@successful_audits += 1
|
194
|
+
end
|
195
|
+
|
196
|
+
def control_example_failure(control_group_name, example_data, error)
|
197
|
+
@failed_audits += 1
|
198
|
+
end
|
199
|
+
|
154
200
|
# Called before action is executed on a resource.
|
155
201
|
def resource_action_start(resource, action, notification_type=nil, notifier=nil)
|
156
202
|
if resource.cookbook_name && resource.recipe_name
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#
|
2
|
-
# Author::
|
3
|
-
# Copyright:: Copyright (c)
|
2
|
+
# Author:: Steven Danna (<steve@chef.io>)
|
3
|
+
# Copyright:: Copyright (c) 2015 Chef Software, Inc.
|
4
4
|
# License:: Apache License, Version 2.0
|
5
5
|
#
|
6
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -16,22 +16,17 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
require '
|
20
|
-
require 'chef/
|
19
|
+
require 'chef/guard_interpreter/default_guard_interpreter'
|
20
|
+
require 'chef/guard_interpreter/resource_guard_interpreter'
|
21
21
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
ch.ord.should be_a_kind_of(Fixnum)
|
31
|
-
ch.ord.should == num
|
22
|
+
class Chef
|
23
|
+
class GuardInterpreter
|
24
|
+
def self.for_resource(resource, command, command_opts)
|
25
|
+
if resource.guard_interpreter == :default
|
26
|
+
Chef::GuardInterpreter::DefaultGuardInterpreter.new(command, command_opts)
|
27
|
+
else
|
28
|
+
Chef::GuardInterpreter::ResourceGuardInterpreter.new(resource, command, command_opts)
|
32
29
|
end
|
33
30
|
end
|
34
|
-
|
35
31
|
end
|
36
|
-
|
37
32
|
end
|
@@ -16,7 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
require 'chef/guard_interpreter
|
19
|
+
require 'chef/guard_interpreter'
|
20
20
|
|
21
21
|
class Chef
|
22
22
|
class GuardInterpreter
|
@@ -41,7 +41,7 @@ class Chef
|
|
41
41
|
# attribute by checking the type of the resources.
|
42
42
|
# We need to make sure we check for Script first because any resource
|
43
43
|
# that can get to here is an Execute resource.
|
44
|
-
if @
|
44
|
+
if @resource.is_a? Chef::Resource::Script
|
45
45
|
block_attributes = @command_opts.merge({:code => @command})
|
46
46
|
else
|
47
47
|
block_attributes = @command_opts.merge({:command => @command})
|
@@ -95,6 +95,7 @@ class Chef
|
|
95
95
|
empty_events = Chef::EventDispatch::Dispatcher.new
|
96
96
|
anonymous_run_context = Chef::RunContext.new(parent_resource.node, {}, empty_events)
|
97
97
|
interpreter_resource = resource_class.new('Guard resource', anonymous_run_context)
|
98
|
+
interpreter_resource.is_guard_interpreter = true
|
98
99
|
|
99
100
|
interpreter_resource
|
100
101
|
end
|
data/lib/chef/http.rb
CHANGED
@@ -25,7 +25,6 @@ require 'tempfile'
|
|
25
25
|
require 'net/https'
|
26
26
|
require 'uri'
|
27
27
|
require 'chef/http/basic_client'
|
28
|
-
require 'chef/monkey_patches/string'
|
29
28
|
require 'chef/monkey_patches/net_http'
|
30
29
|
require 'chef/config'
|
31
30
|
require 'chef/platform/query_helpers'
|
@@ -204,7 +203,7 @@ class Chef
|
|
204
203
|
|
205
204
|
def create_url(path)
|
206
205
|
return path if path.is_a?(URI)
|
207
|
-
if path =~ /^(http|https):\/\//
|
206
|
+
if path =~ /^(http|https):\/\//i
|
208
207
|
URI.parse(path)
|
209
208
|
elsif path.nil? or path.empty?
|
210
209
|
URI.parse(@url)
|
data/lib/chef/knife.rb
CHANGED
@@ -53,6 +53,7 @@ class Chef
|
|
53
53
|
def_delegator :@ui, :format_for_display
|
54
54
|
def_delegator :@ui, :format_cookbook_list_for_display
|
55
55
|
def_delegator :@ui, :edit_data
|
56
|
+
def_delegator :@ui, :edit_hash
|
56
57
|
def_delegator :@ui, :edit_object
|
57
58
|
def_delegator :@ui, :confirm
|
58
59
|
|
@@ -260,7 +261,7 @@ class Chef
|
|
260
261
|
OFFICIAL_PLUGINS = %w[ec2 rackspace windows openstack terremark bluebox]
|
261
262
|
|
262
263
|
# :nodoc:
|
263
|
-
# Error out and print usage. probably
|
264
|
+
# Error out and print usage. probably because the arguments given by the
|
264
265
|
# user could not be resolved to a subcommand.
|
265
266
|
def self.subcommand_not_found!(args)
|
266
267
|
ui.fatal("Cannot find sub command for: '#{args.join(' ')}'")
|
@@ -269,7 +270,8 @@ class Chef
|
|
269
270
|
list_commands(category_commands)
|
270
271
|
elsif missing_plugin = ( OFFICIAL_PLUGINS.find {|plugin| plugin == args[0]} )
|
271
272
|
ui.info("The #{missing_plugin} commands were moved to plugins in Chef 0.10")
|
272
|
-
ui.info("You can install the plugin with `(sudo) gem install knife-#{missing_plugin}")
|
273
|
+
ui.info("You can install the plugin with `(sudo) gem install knife-#{missing_plugin}`")
|
274
|
+
ui.info("Use `chef gem install knife-#{missing_plugin}` instead if using ChefDK")
|
273
275
|
else
|
274
276
|
list_commands
|
275
277
|
end
|
@@ -308,7 +310,7 @@ class Chef
|
|
308
310
|
exit 1
|
309
311
|
end
|
310
312
|
|
311
|
-
# copy Mixlib::CLI over so that it
|
313
|
+
# copy Mixlib::CLI over so that it can be configured in knife.rb
|
312
314
|
# config file
|
313
315
|
Chef::Config[:verbosity] = config[:verbosity]
|
314
316
|
end
|
data/lib/chef/knife/bootstrap.rb
CHANGED
@@ -19,12 +19,17 @@
|
|
19
19
|
require 'chef/knife'
|
20
20
|
require 'chef/knife/data_bag_secret_options'
|
21
21
|
require 'erubis'
|
22
|
+
require 'chef/knife/bootstrap/chef_vault_handler'
|
23
|
+
require 'chef/knife/bootstrap/client_builder'
|
22
24
|
|
23
25
|
class Chef
|
24
26
|
class Knife
|
25
27
|
class Bootstrap < Knife
|
26
28
|
include DataBagSecretOptions
|
27
29
|
|
30
|
+
attr_accessor :client_builder
|
31
|
+
attr_accessor :chef_vault_handler
|
32
|
+
|
28
33
|
deps do
|
29
34
|
require 'chef/knife/core/bootstrap_context'
|
30
35
|
require 'chef/json_compat'
|
@@ -194,10 +199,55 @@ class Chef
|
|
194
199
|
:description => "Verify the SSL cert for HTTPS requests to the Chef server API.",
|
195
200
|
:boolean => true
|
196
201
|
|
202
|
+
option :bootstrap_vault_file,
|
203
|
+
:long => '--bootstrap-vault-file VAULT_FILE',
|
204
|
+
:description => 'A JSON file with a list of vault(s) and item(s) to be updated'
|
205
|
+
|
206
|
+
option :bootstrap_vault_json,
|
207
|
+
:long => '--bootstrap-vault-json VAULT_JSON',
|
208
|
+
:description => 'A JSON string with the vault(s) and item(s) to be updated'
|
209
|
+
|
210
|
+
option :bootstrap_vault_item,
|
211
|
+
:long => '--bootstrap-vault-item VAULT_ITEM',
|
212
|
+
:description => 'A single vault and item to update as "vault:item"',
|
213
|
+
:proc => Proc.new { |i|
|
214
|
+
(vault, item) = i.split(/:/)
|
215
|
+
Chef::Config[:knife][:bootstrap_vault_item] ||= {}
|
216
|
+
Chef::Config[:knife][:bootstrap_vault_item][vault] ||= []
|
217
|
+
Chef::Config[:knife][:bootstrap_vault_item][vault].push(item)
|
218
|
+
Chef::Config[:knife][:bootstrap_vault_item]
|
219
|
+
}
|
220
|
+
|
221
|
+
def initialize(argv=[])
|
222
|
+
super
|
223
|
+
@client_builder = Chef::Knife::Bootstrap::ClientBuilder.new(
|
224
|
+
chef_config: Chef::Config,
|
225
|
+
knife_config: config,
|
226
|
+
ui: ui,
|
227
|
+
)
|
228
|
+
@chef_vault_handler = Chef::Knife::Bootstrap::ChefVaultHandler.new(
|
229
|
+
knife_config: config,
|
230
|
+
ui: ui
|
231
|
+
)
|
232
|
+
end
|
233
|
+
|
234
|
+
# The default bootstrap template to use to bootstrap a server This is a public API hook
|
235
|
+
# which knife plugins use or inherit and override.
|
236
|
+
#
|
237
|
+
# @return [String] Default bootstrap template
|
197
238
|
def default_bootstrap_template
|
198
239
|
"chef-full"
|
199
240
|
end
|
200
241
|
|
242
|
+
# The server_name is the DNS or IP we are going to connect to, it is not necessarily
|
243
|
+
# the node name, the fqdn, or the hostname of the server. This is a public API hook
|
244
|
+
# which knife plugins use or inherit and override.
|
245
|
+
#
|
246
|
+
# @return [String] The DNS or IP that bootstrap will connect to
|
247
|
+
def server_name
|
248
|
+
Array(@name_args).first
|
249
|
+
end
|
250
|
+
|
201
251
|
def bootstrap_template
|
202
252
|
# The order here is important. We want to check if we have the new Chef 12 option is set first.
|
203
253
|
# Knife cloud plugins unfortunately all set a default option for the :distro so it should be at
|
@@ -216,7 +266,7 @@ class Chef
|
|
216
266
|
|
217
267
|
# Otherwise search the template directories until we find the right one
|
218
268
|
bootstrap_files = []
|
219
|
-
bootstrap_files << File.join(File.dirname(__FILE__), 'bootstrap', "#{template}.erb")
|
269
|
+
bootstrap_files << File.join(File.dirname(__FILE__), 'bootstrap/templates', "#{template}.erb")
|
220
270
|
bootstrap_files << File.join(Knife.chef_config_dir, "bootstrap", "#{template}.erb") if Chef::Knife.chef_config_dir
|
221
271
|
bootstrap_files << File.join(ENV['HOME'], '.chef', 'bootstrap', "#{template}.erb") if ENV['HOME']
|
222
272
|
bootstrap_files << Gem.find_files(File.join("chef","knife","bootstrap","#{template}.erb"))
|
@@ -237,20 +287,45 @@ class Chef
|
|
237
287
|
template_file
|
238
288
|
end
|
239
289
|
|
290
|
+
def secret
|
291
|
+
@secret ||= encryption_secret_provided_ignore_encrypt_flag? ? read_secret : nil
|
292
|
+
end
|
293
|
+
|
294
|
+
def bootstrap_context
|
295
|
+
@bootstrap_context ||= Knife::Core::BootstrapContext.new(
|
296
|
+
config,
|
297
|
+
config[:run_list],
|
298
|
+
Chef::Config,
|
299
|
+
secret
|
300
|
+
)
|
301
|
+
end
|
302
|
+
|
240
303
|
def render_template
|
241
304
|
template_file = find_template
|
242
305
|
template = IO.read(template_file).chomp
|
243
|
-
|
244
|
-
context = Knife::Core::BootstrapContext.new(config, config[:run_list], Chef::Config, secret)
|
245
|
-
Erubis::Eruby.new(template).evaluate(context)
|
306
|
+
Erubis::Eruby.new(template).evaluate(bootstrap_context)
|
246
307
|
end
|
247
308
|
|
248
309
|
def run
|
249
310
|
validate_name_args!
|
250
|
-
@node_name = Array(@name_args).first
|
251
311
|
|
252
312
|
$stdout.sync = true
|
253
|
-
|
313
|
+
|
314
|
+
# chef-vault integration must use the new client-side hawtness, otherwise to use the
|
315
|
+
# new client-side hawtness, just delete your validation key.
|
316
|
+
if chef_vault_handler.doing_chef_vault? || !File.exist?(File.expand_path(Chef::Config[:validation_key]))
|
317
|
+
client_builder.run
|
318
|
+
|
319
|
+
chef_vault_handler.run(node_name: config[:chef_node_name])
|
320
|
+
|
321
|
+
bootstrap_context.client_pem = client_builder.client_path
|
322
|
+
else
|
323
|
+
ui.info("Doing old-style registration with the validation key at #{Chef::Config[:validation_key]}...")
|
324
|
+
ui.info("Delete your validation key in order to use your user credentials instead")
|
325
|
+
ui.info("")
|
326
|
+
end
|
327
|
+
|
328
|
+
ui.info("Connecting to #{ui.color(server_name, :bold)}")
|
254
329
|
|
255
330
|
begin
|
256
331
|
knife_ssh.run
|
@@ -265,24 +340,19 @@ class Chef
|
|
265
340
|
end
|
266
341
|
|
267
342
|
def validate_name_args!
|
268
|
-
if
|
343
|
+
if server_name.nil?
|
269
344
|
ui.error("Must pass an FQDN or ip to bootstrap")
|
270
345
|
exit 1
|
271
|
-
elsif
|
346
|
+
elsif server_name == "windows"
|
347
|
+
# catches "knife bootstrap windows" when that command is not installed
|
272
348
|
ui.warn("Hostname containing 'windows' specified. Please install 'knife-windows' if you are attempting to bootstrap a Windows node via WinRM.")
|
273
349
|
end
|
274
350
|
end
|
275
351
|
|
276
|
-
def server_name
|
277
|
-
Array(@name_args).first
|
278
|
-
end
|
279
|
-
|
280
352
|
def knife_ssh
|
281
353
|
ssh = Chef::Knife::Ssh.new
|
282
354
|
ssh.ui = ui
|
283
355
|
ssh.name_args = [ server_name, ssh_command ]
|
284
|
-
|
285
|
-
# command line arguments and config file values are now merged into config in Chef::Knife#merge_configs
|
286
356
|
ssh.config[:ssh_user] = config[:ssh_user]
|
287
357
|
ssh.config[:ssh_password] = config[:ssh_password]
|
288
358
|
ssh.config[:ssh_port] = config[:ssh_port]
|
@@ -311,7 +381,6 @@ class Chef
|
|
311
381
|
|
312
382
|
command
|
313
383
|
end
|
314
|
-
|
315
384
|
end
|
316
385
|
end
|
317
386
|
end
|
@@ -0,0 +1,165 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Lamont Granquist (<lamont@chef.io>)
|
3
|
+
# Copyright:: Copyright (c) 2015 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
|
+
class Chef
|
20
|
+
class Knife
|
21
|
+
class Bootstrap < Knife
|
22
|
+
class ChefVaultHandler
|
23
|
+
|
24
|
+
# @return [Hash] knife merged config, typically @config
|
25
|
+
attr_accessor :knife_config
|
26
|
+
|
27
|
+
# @return [Chef::Knife::UI] ui object for output
|
28
|
+
attr_accessor :ui
|
29
|
+
|
30
|
+
# @return [String] name of the node (technically name of the client)
|
31
|
+
attr_reader :node_name
|
32
|
+
|
33
|
+
# @param knife_config [Hash] knife merged config, typically @config
|
34
|
+
# @param ui [Chef::Knife::UI] ui object for output
|
35
|
+
def initialize(knife_config: {}, ui: nil)
|
36
|
+
@knife_config = knife_config
|
37
|
+
@ui = ui
|
38
|
+
end
|
39
|
+
|
40
|
+
# Updates the chef vault items for the newly created node.
|
41
|
+
#
|
42
|
+
# @param node_name [String] name of the node (technically name of the client)
|
43
|
+
# @todo: node_name should be mandatory (ruby 2.0 compat)
|
44
|
+
def run(node_name: nil)
|
45
|
+
return unless doing_chef_vault?
|
46
|
+
|
47
|
+
sanity_check
|
48
|
+
|
49
|
+
@node_name = node_name
|
50
|
+
|
51
|
+
ui.info("Updating Chef Vault, waiting for client to be searchable..") while wait_for_client
|
52
|
+
|
53
|
+
update_bootstrap_vault_json!
|
54
|
+
end
|
55
|
+
|
56
|
+
# Iterate through all the vault items to update. Items may be either a String
|
57
|
+
# or an Array of Strings:
|
58
|
+
#
|
59
|
+
# {
|
60
|
+
# "vault1": "item",
|
61
|
+
# "vault2": [ "item1", "item2", "item2" ]
|
62
|
+
# }
|
63
|
+
#
|
64
|
+
def update_bootstrap_vault_json!
|
65
|
+
vault_json.each do |vault, items|
|
66
|
+
[ items ].flatten.each do |item|
|
67
|
+
update_vault(vault, item)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
# @return [Boolean] if we've got chef vault options to act on or not
|
73
|
+
def doing_chef_vault?
|
74
|
+
!!(bootstrap_vault_json || bootstrap_vault_file || bootstrap_vault_item)
|
75
|
+
end
|
76
|
+
|
77
|
+
private
|
78
|
+
|
79
|
+
# warn if the user has given mutual conflicting options
|
80
|
+
def sanity_check
|
81
|
+
if bootstrap_vault_item && (bootstrap_vault_json || bootstrap_vault_file)
|
82
|
+
ui.warn "--vault-item given with --vault-list or --vault-file, ignoring the latter"
|
83
|
+
end
|
84
|
+
|
85
|
+
if bootstrap_vault_json && bootstrap_vault_file
|
86
|
+
ui.warn "--vault-list given with --vault-file, ignoring the latter"
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
# @return [String] string with serialized JSON representing the chef vault items
|
91
|
+
def bootstrap_vault_json
|
92
|
+
knife_config[:bootstrap_vault_json]
|
93
|
+
end
|
94
|
+
|
95
|
+
# @return [String] JSON text in a file representing the chef vault items
|
96
|
+
def bootstrap_vault_file
|
97
|
+
knife_config[:bootstrap_vault_file]
|
98
|
+
end
|
99
|
+
|
100
|
+
# @return [Hash] Ruby object representing the chef vault items to create
|
101
|
+
def bootstrap_vault_item
|
102
|
+
knife_config[:bootstrap_vault_item]
|
103
|
+
end
|
104
|
+
|
105
|
+
# Helper to return a ruby object represeting all the data bags and items
|
106
|
+
# to update via chef-vault.
|
107
|
+
#
|
108
|
+
# @return [Hash] deserialized ruby hash with all the vault items
|
109
|
+
def vault_json
|
110
|
+
@vault_json ||=
|
111
|
+
begin
|
112
|
+
if bootstrap_vault_item
|
113
|
+
bootstrap_vault_item
|
114
|
+
else
|
115
|
+
json = bootstrap_vault_json ? bootstrap_vault_json : File.read(bootstrap_vault_file)
|
116
|
+
Chef::JSONCompat.from_json(json)
|
117
|
+
end
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
# Update an individual vault item and save it
|
122
|
+
#
|
123
|
+
# @param vault [String] name of the chef-vault encrypted data bag
|
124
|
+
# @param item [String] name of the chef-vault encrypted item
|
125
|
+
def update_vault(vault, item)
|
126
|
+
require_chef_vault!
|
127
|
+
bootstrap_vault_item = load_chef_bootstrap_vault_item(vault, item)
|
128
|
+
bootstrap_vault_item.clients("name:#{node_name}")
|
129
|
+
bootstrap_vault_item.save
|
130
|
+
end
|
131
|
+
|
132
|
+
# Hook to stub out ChefVault
|
133
|
+
#
|
134
|
+
# @param vault [String] name of the chef-vault encrypted data bag
|
135
|
+
# @param item [String] name of the chef-vault encrypted item
|
136
|
+
# @returns [ChefVault::Item] ChefVault::Item object
|
137
|
+
def load_chef_bootstrap_vault_item(vault, item)
|
138
|
+
ChefVault::Item.load(vault, item)
|
139
|
+
end
|
140
|
+
|
141
|
+
public :load_chef_bootstrap_vault_item # for stubbing
|
142
|
+
|
143
|
+
# Helper used to spin waiting for the client to appear in search.
|
144
|
+
#
|
145
|
+
# @return [Boolean] true if the client is searchable
|
146
|
+
def wait_for_client
|
147
|
+
sleep 1
|
148
|
+
!Chef::Search::Query.new.search(:client, "name:#{node_name}")[0]
|
149
|
+
end
|
150
|
+
|
151
|
+
# Helper to very lazily require the chef-vault gem
|
152
|
+
def require_chef_vault!
|
153
|
+
@require_chef_vault ||=
|
154
|
+
begin
|
155
|
+
require 'chef-vault'
|
156
|
+
true
|
157
|
+
rescue LoadError
|
158
|
+
raise "Knife bootstrap cannot configure chef vault items when the chef-vault gem is not installed"
|
159
|
+
end
|
160
|
+
end
|
161
|
+
|
162
|
+
end
|
163
|
+
end
|
164
|
+
end
|
165
|
+
end
|