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/knife/search.rb
CHANGED
@@ -53,7 +53,7 @@ class Chef
|
|
53
53
|
:short => "-R INT",
|
54
54
|
:long => "--rows INT",
|
55
55
|
:description => "The number of rows to return",
|
56
|
-
:default =>
|
56
|
+
:default => nil,
|
57
57
|
:proc => lambda { |i| i.to_i }
|
58
58
|
|
59
59
|
option :run_list,
|
@@ -92,9 +92,9 @@ class Chef
|
|
92
92
|
result_count = 0
|
93
93
|
|
94
94
|
search_args = Hash.new
|
95
|
-
search_args[:sort] = config[:sort]
|
96
|
-
search_args[:start] = config[:start]
|
97
|
-
search_args[:rows] = config[:rows]
|
95
|
+
search_args[:sort] = config[:sort] if config[:sort]
|
96
|
+
search_args[:start] = config[:start] if config[:start]
|
97
|
+
search_args[:rows] = config[:rows] if config[:rows]
|
98
98
|
if config[:filter_result]
|
99
99
|
search_args[:filter_result] = create_result_filter(config[:filter_result])
|
100
100
|
elsif (not ui.config[:attribute].nil?) && (not ui.config[:attribute].empty?)
|
data/lib/chef/knife/serve.rb
CHANGED
@@ -4,6 +4,9 @@ require 'chef/local_mode'
|
|
4
4
|
class Chef
|
5
5
|
class Knife
|
6
6
|
class Serve < Knife
|
7
|
+
|
8
|
+
banner 'knife serve (options)'
|
9
|
+
|
7
10
|
option :repo_mode,
|
8
11
|
:long => '--repo-mode MODE',
|
9
12
|
:description => "Specifies the local repository layout. Values: static (only environments/roles/data_bags/cookbooks), everything (includes nodes/clients/users), hosted_everything (includes acls/groups/etc. for Enterprise/Hosted Chef). Default: everything/hosted_everything"
|
data/lib/chef/knife/ssh.rb
CHANGED
data/lib/chef/knife/ssl_check.rb
CHANGED
@@ -162,7 +162,7 @@ We are working on documentation for resolving common issues uncovered here.
|
|
162
162
|
server's certificate. By default, the certificate is stored in the following
|
163
163
|
location on the host where your chef-server runs:
|
164
164
|
|
165
|
-
/var/opt/
|
165
|
+
/var/opt/opscode/nginx/ca/SERVER_HOSTNAME.crt
|
166
166
|
|
167
167
|
Copy that file to your trusted_certs_dir (currently: #{configuration.trusted_certs_dir})
|
168
168
|
using SSH/SCP or some other secure method, then re-run this command to confirm
|
@@ -191,7 +191,7 @@ configure chef to trust that server's certificate.
|
|
191
191
|
By default, the certificate is stored in the following location on the host
|
192
192
|
where your chef-server runs:
|
193
193
|
|
194
|
-
/var/opt/
|
194
|
+
/var/opt/opscode/nginx/ca/SERVER_HOSTNAME.crt
|
195
195
|
|
196
196
|
Copy that file to your trusted_certs_dir (currently: #{configuration.trusted_certs_dir})
|
197
197
|
using SSH/SCP or some other secure method, then re-run this command to confirm
|
data/lib/chef/knife/ssl_fetch.rb
CHANGED
@@ -16,7 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
-
require 'chef/knife
|
19
|
+
require 'chef/knife'
|
20
20
|
require 'chef/config'
|
21
21
|
|
22
22
|
class Chef
|
@@ -136,6 +136,19 @@ TRUST_TRUST
|
|
136
136
|
remote_cert_chain.each do |cert|
|
137
137
|
write_cert(cert)
|
138
138
|
end
|
139
|
+
rescue OpenSSL::SSL::SSLError => e
|
140
|
+
# 'unknown protocol' usually means you tried to connect to a non-ssl
|
141
|
+
# service. We handle that specially here, any other error we let bubble
|
142
|
+
# up (probably a bug of some sort).
|
143
|
+
raise unless e.message.include?("unknown protocol")
|
144
|
+
|
145
|
+
ui.error("The service at the given URI (#{uri}) does not accept SSL connections")
|
146
|
+
|
147
|
+
if uri.scheme == "http"
|
148
|
+
https_uri = uri.to_s.sub(/^http/, 'https')
|
149
|
+
ui.error("Perhaps you meant to connect to '#{https_uri}'?")
|
150
|
+
end
|
151
|
+
exit 1
|
139
152
|
end
|
140
153
|
|
141
154
|
|
data/lib/chef/log.rb
CHANGED
@@ -19,6 +19,7 @@
|
|
19
19
|
|
20
20
|
require 'logger'
|
21
21
|
require 'chef/monologger'
|
22
|
+
require 'chef/exceptions'
|
22
23
|
require 'mixlib/log'
|
23
24
|
|
24
25
|
class Chef
|
@@ -34,6 +35,14 @@ class Chef
|
|
34
35
|
end
|
35
36
|
end
|
36
37
|
|
38
|
+
def self.deprecation(msg=nil, &block)
|
39
|
+
if Chef::Config[:treat_deprecation_warnings_as_errors]
|
40
|
+
error(msg, &block)
|
41
|
+
raise Chef::Exceptions::DeprecatedFeatureError.new(msg)
|
42
|
+
else
|
43
|
+
warn(msg, &block)
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
37
47
|
end
|
38
48
|
end
|
39
|
-
|
data/lib/chef/mixin/command.rb
CHANGED
@@ -82,7 +82,7 @@ class Chef
|
|
82
82
|
end
|
83
83
|
|
84
84
|
# works same as above, except that it returns stdout and stderr
|
85
|
-
# requirement => platforms like solaris 9,10 has
|
85
|
+
# requirement => platforms like solaris 9,10 has weird issues where
|
86
86
|
# even in command failure the exit code is zero, so we need to lookup stderr.
|
87
87
|
def run_command_and_return_stdout_stderr(args={})
|
88
88
|
command_output = ""
|
@@ -29,6 +29,7 @@ class Chef
|
|
29
29
|
module GetSourceFromPackage
|
30
30
|
def initialize(new_resource, run_context)
|
31
31
|
super
|
32
|
+
return if new_resource.package_name.is_a?(Array)
|
32
33
|
# if we're passed something that looks like a filesystem path, with no source, use it
|
33
34
|
# - require at least one '/' in the path to avoid gem_package "foo" breaking if a file named 'foo' exists in the cwd
|
34
35
|
if new_resource.source.nil? && new_resource.package_name.match(/#{::File::SEPARATOR}/) && ::File.exists?(new_resource.package_name)
|
@@ -42,8 +42,8 @@ class Chef
|
|
42
42
|
# method names.
|
43
43
|
# :required:: Raise an exception if this parameter is missing. Valid values are true or false,
|
44
44
|
# by default, options are not required.
|
45
|
-
# :regex:: Match the value of the
|
46
|
-
# :equal_to:: Match the value of the
|
45
|
+
# :regex:: Match the value of the parameter against a regular expression.
|
46
|
+
# :equal_to:: Match the value of the parameter with ==. An array means it can be equal to any
|
47
47
|
# of the values.
|
48
48
|
def validate(opts, map)
|
49
49
|
#--
|
data/lib/chef/mixin/securable.rb
CHANGED
@@ -111,13 +111,7 @@ class Chef
|
|
111
111
|
|
112
112
|
# equivalent to something like:
|
113
113
|
# def rights(permissions=nil, principals=nil, args_hash=nil)
|
114
|
-
define_method(name) do
|
115
|
-
# Ruby 1.8 compat: default the arguments
|
116
|
-
permissions = args.length >= 1 ? args[0] : nil
|
117
|
-
principals = args.length >= 2 ? args[1] : nil
|
118
|
-
args_hash = args.length >= 3 ? args[2] : nil
|
119
|
-
raise ArgumentError.new("wrong number of arguments (#{args.length} for 3)") if args.length >= 4
|
120
|
-
|
114
|
+
define_method(name) do |permissions=nil, principals=nil, args_hash=nil|
|
121
115
|
rights = self.instance_variable_get("@#{name.to_s}".to_sym)
|
122
116
|
unless permissions.nil?
|
123
117
|
input = {
|
data/lib/chef/mixin/shell_out.rb
CHANGED
@@ -36,9 +36,15 @@ class Chef
|
|
36
36
|
options[env_key] ||= {}
|
37
37
|
options[env_key] = options[env_key].dup
|
38
38
|
options[env_key]['LC_ALL'] ||= Chef::Config[:internal_locale] unless options[env_key].has_key?('LC_ALL')
|
39
|
+
options[env_key]['LANGUAGE'] ||= Chef::Config[:internal_locale] unless options[env_key].has_key?('LANGUAGE')
|
40
|
+
options[env_key]['LANG'] ||= Chef::Config[:internal_locale] unless options[env_key].has_key?('LANG')
|
39
41
|
args << options
|
40
42
|
else
|
41
|
-
args << { :environment => {
|
43
|
+
args << { :environment => {
|
44
|
+
'LC_ALL' => Chef::Config[:internal_locale],
|
45
|
+
'LANGUAGE' => Chef::Config[:internal_locale],
|
46
|
+
'LANG' => Chef::Config[:internal_locale],
|
47
|
+
} }
|
42
48
|
end
|
43
49
|
|
44
50
|
shell_out_command(*args)
|
data/lib/chef/mixin/template.rb
CHANGED
@@ -23,18 +23,6 @@ class Chef
|
|
23
23
|
module Mixin
|
24
24
|
module Template
|
25
25
|
|
26
|
-
# A compatibility wrapper around IO.binread so it works on Ruby 1.8.7.
|
27
|
-
# --
|
28
|
-
# Used in the TemplateContext class, but that method namespace is shared
|
29
|
-
# with user code, so we want to avoid adding methods there when possible.
|
30
|
-
def self.binread(file)
|
31
|
-
if IO.respond_to?(:binread)
|
32
|
-
IO.binread(file)
|
33
|
-
else
|
34
|
-
File.open(file, "rb") {|f| f.read }
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
26
|
# == ChefContext
|
39
27
|
# ChefContext was previously used to mix behavior into Erubis::Context so
|
40
28
|
# that it would be available to templates. This behavior has now moved to
|
@@ -105,11 +93,11 @@ class Chef
|
|
105
93
|
partial_context._extend_modules(@_extension_modules)
|
106
94
|
|
107
95
|
template_location = @template_finder.find(partial_name, options)
|
108
|
-
_render_template(
|
96
|
+
_render_template(IO.binread(template_location), partial_context)
|
109
97
|
end
|
110
98
|
|
111
99
|
def render_template(template_location)
|
112
|
-
_render_template(
|
100
|
+
_render_template(IO.binread(template_location), self)
|
113
101
|
end
|
114
102
|
|
115
103
|
def render_template_from_string(template)
|
data/lib/chef/mixin/why_run.rb
CHANGED
@@ -48,7 +48,7 @@ class Chef
|
|
48
48
|
# block/proc that implements the action.
|
49
49
|
def add_action(descriptions, &block)
|
50
50
|
@actions << [descriptions, block]
|
51
|
-
if !Chef::Config[:why_run]
|
51
|
+
if (@resource.respond_to?(:is_guard_interpreter) && @resource.is_guard_interpreter) || !Chef::Config[:why_run]
|
52
52
|
block.call
|
53
53
|
end
|
54
54
|
events.resource_update_applied(@resource, @action, descriptions)
|
@@ -42,6 +42,10 @@ if Net::HTTP.instance_methods.map {|m| m.to_s}.include?("proxy_uri")
|
|
42
42
|
# from -e:1:in `<main>'
|
43
43
|
#
|
44
44
|
# https://bugs.ruby-lang.org/issues/9129
|
45
|
+
#
|
46
|
+
# NOTE: This should be fixed in Ruby 2.2.0, and backported to Ruby 2.0 and
|
47
|
+
# 2.1 (not yet released so the version/patchlevel required isn't known
|
48
|
+
# yet).
|
45
49
|
Net::HTTP.new("::1", 80).proxy_uri
|
46
50
|
rescue URI::InvalidURIError
|
47
51
|
class Net::HTTP
|
data/lib/chef/monologger.rb
CHANGED
data/lib/chef/node.rb
CHANGED
@@ -47,6 +47,8 @@ class Chef
|
|
47
47
|
|
48
48
|
attr_accessor :recipe_list, :run_state, :override_runlist
|
49
49
|
|
50
|
+
attr_accessor :chef_server_rest
|
51
|
+
|
50
52
|
# RunContext will set itself as run_context via this setter when
|
51
53
|
# initialized. This is needed so DSL::IncludeAttribute (in particular,
|
52
54
|
# #include_recipe) can access the run_context to determine if an attributes
|
@@ -62,7 +64,8 @@ class Chef
|
|
62
64
|
include Chef::Mixin::ParamsValidate
|
63
65
|
|
64
66
|
# Create a new Chef::Node object.
|
65
|
-
def initialize
|
67
|
+
def initialize(chef_server_rest: nil)
|
68
|
+
@chef_server_rest = chef_server_rest
|
66
69
|
@name = nil
|
67
70
|
|
68
71
|
@chef_environment = '_default'
|
@@ -80,7 +83,7 @@ class Chef
|
|
80
83
|
end
|
81
84
|
|
82
85
|
def chef_server_rest
|
83
|
-
Chef::REST.new(Chef::Config[:chef_server_url])
|
86
|
+
@chef_server_rest ||= Chef::REST.new(Chef::Config[:chef_server_url])
|
84
87
|
end
|
85
88
|
|
86
89
|
# Set the name of this Node, or return the current name.
|
data/lib/chef/node/attribute.rb
CHANGED
@@ -138,11 +138,9 @@ class Chef
|
|
138
138
|
:values,
|
139
139
|
:values_at,
|
140
140
|
:zip].each do |delegated_method|
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
end
|
145
|
-
METHOD_DEFN
|
141
|
+
define_method(delegated_method) do |*args, &block|
|
142
|
+
merged_attributes.send(delegated_method, *args, &block)
|
143
|
+
end
|
146
144
|
end
|
147
145
|
|
148
146
|
# return the cookbook level default attribute component
|
@@ -253,7 +251,7 @@ class Chef
|
|
253
251
|
if path.nil?
|
254
252
|
@deep_merge_cache = {}
|
255
253
|
else
|
256
|
-
deep_merge_cache.delete(path)
|
254
|
+
deep_merge_cache.delete(path.to_s)
|
257
255
|
end
|
258
256
|
end
|
259
257
|
|
@@ -436,12 +434,12 @@ class Chef
|
|
436
434
|
end
|
437
435
|
|
438
436
|
def [](key)
|
439
|
-
if deep_merge_cache.has_key?(key)
|
437
|
+
if deep_merge_cache.has_key?(key.to_s)
|
440
438
|
# return the cache of the deep merged values by top-level key
|
441
|
-
deep_merge_cache[key]
|
439
|
+
deep_merge_cache[key.to_s]
|
442
440
|
else
|
443
441
|
# save all the work of computing node[key]
|
444
|
-
deep_merge_cache[key] = merged_attributes(key)
|
442
|
+
deep_merge_cache[key.to_s] = merged_attributes(key)
|
445
443
|
end
|
446
444
|
end
|
447
445
|
|
@@ -477,6 +475,10 @@ class Chef
|
|
477
475
|
end
|
478
476
|
end
|
479
477
|
|
478
|
+
def to_s
|
479
|
+
merged_attributes.to_s
|
480
|
+
end
|
481
|
+
|
480
482
|
def inspect
|
481
483
|
"#<#{self.class} " << (COMPONENTS + [:@merged_attributes, :@properties]).map{|iv|
|
482
484
|
"#{iv}=#{instance_variable_get(iv).inspect}"
|
@@ -61,12 +61,10 @@ class Chef
|
|
61
61
|
# also invalidate the cached merged_attributes on the root
|
62
62
|
# Node::Attribute object.
|
63
63
|
MUTATOR_METHODS.each do |mutator|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
end
|
69
|
-
METHOD_DEFN
|
64
|
+
define_method(mutator) do |*args, &block|
|
65
|
+
root.reset_cache(root.top_level_breadcrumb)
|
66
|
+
super(*args, &block)
|
67
|
+
end
|
70
68
|
end
|
71
69
|
|
72
70
|
attr_reader :root
|
@@ -126,12 +124,10 @@ class Chef
|
|
126
124
|
# also invalidate the cached `merged_attributes` on the root Attribute
|
127
125
|
# object.
|
128
126
|
MUTATOR_METHODS.each do |mutator|
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
end
|
134
|
-
METHOD_DEFN
|
127
|
+
define_method(mutator) do |*args, &block|
|
128
|
+
root.reset_cache(root.top_level_breadcrumb)
|
129
|
+
super(*args, &block)
|
130
|
+
end
|
135
131
|
end
|
136
132
|
|
137
133
|
def initialize(root, data={})
|
@@ -75,12 +75,9 @@ class Chef
|
|
75
75
|
# Redefine all of the methods that mutate a Hash to raise an error when called.
|
76
76
|
# This is the magic that makes this object "Immutable"
|
77
77
|
DISALLOWED_MUTATOR_METHODS.each do |mutator_method_name|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
raise Exceptions::ImmutableAttributeModification
|
82
|
-
end
|
83
|
-
METHOD_DEFN
|
78
|
+
define_method(mutator_method_name) do |*args, &block|
|
79
|
+
raise Exceptions::ImmutableAttributeModification
|
80
|
+
end
|
84
81
|
end
|
85
82
|
|
86
83
|
# For elements like Fixnums, true, nil...
|
@@ -164,12 +161,9 @@ class Chef
|
|
164
161
|
# Redefine all of the methods that mutate a Hash to raise an error when called.
|
165
162
|
# This is the magic that makes this object "Immutable"
|
166
163
|
DISALLOWED_MUTATOR_METHODS.each do |mutator_method_name|
|
167
|
-
|
168
|
-
class_eval(<<-METHOD_DEFN, __FILE__, __LINE__)
|
169
|
-
def #{mutator_method_name}(*args, &block)
|
164
|
+
define_method(mutator_method_name) do |*args, &block|
|
170
165
|
raise Exceptions::ImmutableAttributeModification
|
171
166
|
end
|
172
|
-
METHOD_DEFN
|
173
167
|
end
|
174
168
|
|
175
169
|
def method_missing(symbol, *args)
|
data/lib/chef/org.rb
ADDED
@@ -0,0 +1,148 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Steven Danna (steve@opscode.com)
|
3
|
+
# Copyright:: Copyright (c) 2014 Chef Software, Inc
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'chef/json_compat'
|
20
|
+
require 'chef/mixin/params_validate'
|
21
|
+
require 'chef/rest'
|
22
|
+
|
23
|
+
class Chef
|
24
|
+
class Org
|
25
|
+
|
26
|
+
include Chef::Mixin::ParamsValidate
|
27
|
+
|
28
|
+
def initialize(name)
|
29
|
+
@name = name
|
30
|
+
@full_name = ''
|
31
|
+
# The Chef API returns the private key of the validator
|
32
|
+
# client on create
|
33
|
+
@private_key = nil
|
34
|
+
@guid = nil
|
35
|
+
end
|
36
|
+
|
37
|
+
def chef_rest
|
38
|
+
@chef_rest ||= Chef::REST.new(Chef::Config[:chef_server_root])
|
39
|
+
end
|
40
|
+
|
41
|
+
def name(arg=nil)
|
42
|
+
set_or_return(:name, arg,
|
43
|
+
:regex => /^[a-z0-9\-_]+$/)
|
44
|
+
end
|
45
|
+
|
46
|
+
def full_name(arg=nil)
|
47
|
+
set_or_return(:full_name,
|
48
|
+
arg, :kind_of => String)
|
49
|
+
end
|
50
|
+
|
51
|
+
def private_key(arg=nil)
|
52
|
+
set_or_return(:private_key,
|
53
|
+
arg, :kind_of => String)
|
54
|
+
end
|
55
|
+
|
56
|
+
def guid(arg=nil)
|
57
|
+
set_or_return(:guid,
|
58
|
+
arg, :kind_of => String)
|
59
|
+
end
|
60
|
+
|
61
|
+
def to_hash
|
62
|
+
result = {
|
63
|
+
"name" => @name,
|
64
|
+
"full_name" => @full_name
|
65
|
+
}
|
66
|
+
result["private_key"] = @private_key if @private_key
|
67
|
+
result["guid"] = @guid if @guid
|
68
|
+
result
|
69
|
+
end
|
70
|
+
|
71
|
+
def to_json(*a)
|
72
|
+
Chef::JSONCompat.to_json(to_hash, *a)
|
73
|
+
end
|
74
|
+
|
75
|
+
def create
|
76
|
+
payload = {:name => self.name, :full_name => self.full_name}
|
77
|
+
new_org = chef_rest.post_rest("organizations", payload)
|
78
|
+
Chef::Org.from_hash(self.to_hash.merge(new_org))
|
79
|
+
end
|
80
|
+
|
81
|
+
def update
|
82
|
+
payload = {:name => self.name, :full_name => self.full_name}
|
83
|
+
new_org = chef_rest.put_rest("organizations/#{name}", payload)
|
84
|
+
Chef::Org.from_hash(self.to_hash.merge(new_org))
|
85
|
+
end
|
86
|
+
|
87
|
+
def destroy
|
88
|
+
chef_rest.delete_rest("organizations/#{@name}")
|
89
|
+
end
|
90
|
+
|
91
|
+
def save
|
92
|
+
begin
|
93
|
+
create
|
94
|
+
rescue Net::HTTPServerException => e
|
95
|
+
if e.response.code == "409"
|
96
|
+
update
|
97
|
+
else
|
98
|
+
raise e
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
def associate_user(username)
|
104
|
+
request_body = {:user => username}
|
105
|
+
response = chef_rest.post_rest "organizations/#{@name}/association_requests", request_body
|
106
|
+
association_id = response["uri"].split("/").last
|
107
|
+
chef_rest.put_rest "users/#{username}/association_requests/#{association_id}", { :response => 'accept' }
|
108
|
+
end
|
109
|
+
|
110
|
+
def dissociate_user(username)
|
111
|
+
chef_rest.delete_rest "organizations/#{name}/users/#{username}"
|
112
|
+
end
|
113
|
+
|
114
|
+
# Class methods
|
115
|
+
def self.from_hash(org_hash)
|
116
|
+
org = Chef::Org.new(org_hash['name'])
|
117
|
+
org.full_name org_hash['full_name']
|
118
|
+
org.private_key org_hash['private_key'] if org_hash.key?('private_key')
|
119
|
+
org.guid org_hash['guid'] if org_hash.key?('guid')
|
120
|
+
org
|
121
|
+
end
|
122
|
+
|
123
|
+
def self.from_json(json)
|
124
|
+
Chef::Org.from_hash(Chef::JSONCompat.from_json(json))
|
125
|
+
end
|
126
|
+
|
127
|
+
class <<self
|
128
|
+
alias_method :json_create, :from_json
|
129
|
+
end
|
130
|
+
|
131
|
+
def self.load(org_name)
|
132
|
+
response = Chef::REST.new(Chef::Config[:chef_server_root]).get_rest("organizations/#{org_name}")
|
133
|
+
Chef::Org.from_hash(response)
|
134
|
+
end
|
135
|
+
|
136
|
+
def self.list(inflate=false)
|
137
|
+
orgs = Chef::REST.new(Chef::Config[:chef_server_root]).get_rest('organizations')
|
138
|
+
if inflate
|
139
|
+
orgs.inject({}) do |org_map, (name, _url)|
|
140
|
+
org_map[name] = Chef::Org.load(name)
|
141
|
+
org_map
|
142
|
+
end
|
143
|
+
else
|
144
|
+
orgs
|
145
|
+
end
|
146
|
+
end
|
147
|
+
end
|
148
|
+
end
|