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
@@ -30,35 +30,33 @@ class Chef
|
|
30
30
|
found_interface = false
|
31
31
|
interface = {}
|
32
32
|
|
33
|
-
@status =
|
34
|
-
|
35
|
-
|
36
|
-
if
|
37
|
-
if
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
@current_resource.metric($1) if line =~ /metric\s(\S+)/
|
47
|
-
end
|
33
|
+
@status = shell_out("ifconfig -a")
|
34
|
+
@status.stdout.each_line do |line|
|
35
|
+
if !found_interface
|
36
|
+
if line =~ /^(\S+):\sflags=(\S+)/
|
37
|
+
# We have interface name, if this is the interface for @current_resource, load info else skip till next interface is found.
|
38
|
+
if $1 == @new_resource.device
|
39
|
+
# Found interface
|
40
|
+
found_interface = true
|
41
|
+
@interface_exists = true
|
42
|
+
@current_resource.target(@new_resource.target)
|
43
|
+
@current_resource.device($1)
|
44
|
+
interface[:flags] = $2
|
45
|
+
@current_resource.metric($1) if line =~ /metric\s(\S+)/
|
48
46
|
end
|
47
|
+
end
|
48
|
+
else
|
49
|
+
# parse interface related information, stop when next interface is found.
|
50
|
+
if line =~ /^(\S+):\sflags=(\S+)/
|
51
|
+
# we are done parsing interface info and hit another one, so stop.
|
52
|
+
found_interface = false
|
53
|
+
break
|
49
54
|
else
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
else
|
56
|
-
if found_interface
|
57
|
-
# read up interface info
|
58
|
-
@current_resource.inet_addr($1) if line =~ /inet\s(\S+)\s/
|
59
|
-
@current_resource.bcast($1) if line =~ /broadcast\s(\S+)/
|
60
|
-
@current_resource.mask(hex_to_dec_netmask($1)) if line =~ /netmask\s(\S+)\s/
|
61
|
-
end
|
55
|
+
if found_interface
|
56
|
+
# read up interface info
|
57
|
+
@current_resource.inet_addr($1) if line =~ /inet\s(\S+)\s/
|
58
|
+
@current_resource.bcast($1) if line =~ /broadcast\s(\S+)/
|
59
|
+
@current_resource.mask(hex_to_dec_netmask($1)) if line =~ /netmask\s(\S+)\s/
|
62
60
|
end
|
63
61
|
end
|
64
62
|
end
|
@@ -86,7 +86,7 @@ class Chef
|
|
86
86
|
|
87
87
|
class_name = convert_to_class_name(provider_name)
|
88
88
|
|
89
|
-
if Chef::Provider.const_defined?(class_name)
|
89
|
+
if Chef::Provider.const_defined?(class_name, false)
|
90
90
|
Chef::Log.info("#{class_name} light-weight provider is already initialized -- Skipping loading #{filename}!")
|
91
91
|
Chef::Log.debug("Overriding already defined LWRPs is not supported anymore starting with Chef 12.")
|
92
92
|
provider_class = Chef::Provider.const_get(class_name)
|
data/lib/chef/provider/mount.rb
CHANGED
@@ -18,14 +18,14 @@
|
|
18
18
|
#
|
19
19
|
|
20
20
|
require 'chef/log'
|
21
|
-
require 'chef/mixin/
|
21
|
+
require 'chef/mixin/shell_out'
|
22
22
|
require 'chef/provider'
|
23
23
|
|
24
24
|
class Chef
|
25
25
|
class Provider
|
26
26
|
class Mount < Chef::Provider
|
27
27
|
|
28
|
-
include Chef::Mixin::
|
28
|
+
include Chef::Mixin::ShellOut
|
29
29
|
|
30
30
|
attr_accessor :unmount_retries
|
31
31
|
|
@@ -213,10 +213,9 @@ class Chef
|
|
213
213
|
@real_device = @new_resource.device
|
214
214
|
else
|
215
215
|
@real_device = ""
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
end
|
216
|
+
ret = shell_out("/sbin/findfs #{device_fstab}")
|
217
|
+
device_line = ret.stdout.lines.first # stdout.first consumes
|
218
|
+
@real_device = device_line.chomp unless device_line.nil?
|
220
219
|
end
|
221
220
|
end
|
222
221
|
@real_device
|
@@ -88,7 +88,7 @@ class Chef
|
|
88
88
|
# FIXME: Should remount always do the remount or only if the options change?
|
89
89
|
actual_options = options || []
|
90
90
|
actual_options.delete('noauto')
|
91
|
-
mount_options = actual_options.empty? ? '' : ",#{actual_options.join(',')}"
|
91
|
+
mount_options = actual_options.empty? ? '' : ",#{actual_options.join(',')}"
|
92
92
|
shell_out!("mount -o remount#{mount_options} #{mount_point}")
|
93
93
|
end
|
94
94
|
|
@@ -16,6 +16,7 @@
|
|
16
16
|
# limitations under the License.
|
17
17
|
#
|
18
18
|
|
19
|
+
require 'chef/mixin/shell_out'
|
19
20
|
require 'chef/mixin/command'
|
20
21
|
require 'chef/log'
|
21
22
|
require 'chef/file_cache'
|
@@ -24,10 +25,14 @@ require 'chef/platform'
|
|
24
25
|
class Chef
|
25
26
|
class Provider
|
26
27
|
class Package < Chef::Provider
|
28
|
+
include Chef::Mixin::ShellOut
|
27
29
|
|
28
|
-
|
29
|
-
|
30
|
+
#
|
31
|
+
# Hook that subclasses use to populate the candidate_version(s)
|
32
|
+
#
|
33
|
+
# @return [Array, String] candidate_version(s) may be a string or array
|
30
34
|
attr_accessor :candidate_version
|
35
|
+
|
31
36
|
def initialize(new_resource, run_context)
|
32
37
|
super
|
33
38
|
@candidate_version = nil
|
@@ -41,63 +46,89 @@ class Chef
|
|
41
46
|
end
|
42
47
|
|
43
48
|
def define_resource_requirements
|
49
|
+
# XXX: upgrade with a specific version doesn't make a whole lot of sense, but why don't we throw this anyway if it happens?
|
50
|
+
# if not, shouldn't we raise to tell the user to use install instead of upgrade if they want to pin a version?
|
44
51
|
requirements.assert(:install) do |a|
|
45
|
-
a.assertion {
|
46
|
-
|
47
|
-
a.
|
48
|
-
a.whyrun("Assuming a repository that offers #{@new_resource.package_name} would have been configured")
|
52
|
+
a.assertion { candidates_exist_for_all_forced_changes? }
|
53
|
+
a.failure_message(Chef::Exceptions::Package, "No version specified, and no candidate version available for #{forced_packages_missing_candidates.join(", ")}")
|
54
|
+
a.whyrun("Assuming a repository that offers #{forced_packages_missing_candidates.join(", ")} would have been configured")
|
49
55
|
end
|
50
56
|
|
51
|
-
requirements.assert(:upgrade) do |a|
|
52
|
-
|
53
|
-
a.
|
54
|
-
a.
|
55
|
-
a.whyrun("Assuming a repository that offers #{@new_resource.package_name} would have been configured")
|
57
|
+
requirements.assert(:upgrade, :install) do |a|
|
58
|
+
a.assertion { candidates_exist_for_all_uninstalled? }
|
59
|
+
a.failure_message(Chef::Exceptions::Package, "No candidate version available for #{packages_missing_candidates.join(", ")}")
|
60
|
+
a.whyrun("Assuming a repository that offers #{packages_missing_candidates.join(", ")} would have been configured")
|
56
61
|
end
|
57
62
|
end
|
58
63
|
|
59
64
|
def action_install
|
60
|
-
|
61
|
-
if !@new_resource.version.nil? && !(target_version_already_installed?)
|
62
|
-
install_version = @new_resource.version
|
63
|
-
# If it's not installed at all, install it
|
64
|
-
elsif @current_resource.version.nil?
|
65
|
-
install_version = candidate_version
|
66
|
-
else
|
65
|
+
unless target_version_array.any?
|
67
66
|
Chef::Log.debug("#{@new_resource} is already installed - nothing to do")
|
68
67
|
return
|
69
68
|
end
|
70
69
|
|
71
|
-
#
|
70
|
+
# @todo: move the preseed code out of the base class (and complete the fix for Array of preseeds? ugh...)
|
72
71
|
if @new_resource.response_file
|
73
|
-
if preseed_file = get_preseed_file(
|
74
|
-
converge_by("preseed package #{
|
72
|
+
if preseed_file = get_preseed_file(package_names_for_targets, versions_for_targets)
|
73
|
+
converge_by("preseed package #{package_names_for_targets}") do
|
75
74
|
preseed_package(preseed_file)
|
76
75
|
end
|
77
76
|
end
|
78
77
|
end
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
78
|
+
|
79
|
+
# XXX: mutating the new resource is generally bad
|
80
|
+
@new_resource.version(versions_for_new_resource)
|
81
|
+
|
82
|
+
converge_by(install_description) do
|
83
|
+
install_package(package_names_for_targets, versions_for_targets)
|
84
|
+
Chef::Log.info("#{@new_resource} installed #{package_names_for_targets} at #{versions_for_targets}")
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
def install_description
|
89
|
+
description = []
|
90
|
+
target_version_array.each_with_index do |target_version, i|
|
91
|
+
next if target_version.nil?
|
92
|
+
package_name = package_name_array[i]
|
93
|
+
description << "install version #{target_version} of package #{package_name}"
|
83
94
|
end
|
95
|
+
description
|
84
96
|
end
|
85
97
|
|
98
|
+
private :install_description
|
99
|
+
|
86
100
|
def action_upgrade
|
87
|
-
if
|
88
|
-
Chef::Log.debug("#{@new_resource} no
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
101
|
+
if !target_version_array.any?
|
102
|
+
Chef::Log.debug("#{@new_resource} no versions to upgrade - nothing to do")
|
103
|
+
return
|
104
|
+
end
|
105
|
+
|
106
|
+
# XXX: mutating the new resource is generally bad
|
107
|
+
@new_resource.version(versions_for_new_resource)
|
108
|
+
|
109
|
+
converge_by(upgrade_description) do
|
110
|
+
upgrade_package(package_names_for_targets, versions_for_targets)
|
111
|
+
log_allow_downgrade = allow_downgrade ? '(allow_downgrade)' : ''
|
112
|
+
Chef::Log.info("#{@new_resource} upgraded#{log_allow_downgrade} #{package_names_for_targets} to #{versions_for_targets}")
|
98
113
|
end
|
99
114
|
end
|
100
115
|
|
116
|
+
def upgrade_description
|
117
|
+
log_allow_downgrade = allow_downgrade ? '(allow_downgrade)' : ''
|
118
|
+
description = []
|
119
|
+
target_version_array.each_with_index do |target_version, i|
|
120
|
+
next if target_version.nil?
|
121
|
+
package_name = package_name_array[i]
|
122
|
+
candidate_version = candidate_version_array[i]
|
123
|
+
current_version = current_version_array[i] || "uninstalled"
|
124
|
+
description << "upgrade#{log_allow_downgrade} package #{package_name} from #{current_version} to #{candidate_version}"
|
125
|
+
end
|
126
|
+
description
|
127
|
+
end
|
128
|
+
|
129
|
+
private :upgrade_description
|
130
|
+
|
131
|
+
# @todo: ability to remove an array of packages
|
101
132
|
def action_remove
|
102
133
|
if removing_package?
|
103
134
|
description = @new_resource.version ? "version #{@new_resource.version} of " : ""
|
@@ -110,18 +141,28 @@ class Chef
|
|
110
141
|
end
|
111
142
|
end
|
112
143
|
|
144
|
+
def have_any_matching_version?
|
145
|
+
f = []
|
146
|
+
new_version_array.each_with_index do |item, index|
|
147
|
+
f << (item == current_version_array[index])
|
148
|
+
end
|
149
|
+
f.any?
|
150
|
+
end
|
151
|
+
|
113
152
|
def removing_package?
|
114
|
-
if
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
153
|
+
if !current_version_array.any?
|
154
|
+
# ! any? means it's all nil's, which means nothing is installed
|
155
|
+
false
|
156
|
+
elsif !new_version_array.any?
|
157
|
+
true # remove any version of all packages
|
158
|
+
elsif have_any_matching_version?
|
119
159
|
true # remove the version we have
|
120
160
|
else
|
121
161
|
false # we don't have the version we want to remove
|
122
162
|
end
|
123
163
|
end
|
124
164
|
|
165
|
+
# @todo: ability to purge an array of packages
|
125
166
|
def action_purge
|
126
167
|
if removing_package?
|
127
168
|
description = @new_resource.version ? "version #{@new_resource.version} of" : ""
|
@@ -132,6 +173,7 @@ class Chef
|
|
132
173
|
end
|
133
174
|
end
|
134
175
|
|
176
|
+
# @todo: ability to reconfigure an array of packages
|
135
177
|
def action_reconfig
|
136
178
|
if @current_resource.version == nil then
|
137
179
|
Chef::Log.debug("#{@new_resource} is NOT installed - nothing to do")
|
@@ -154,6 +196,7 @@ class Chef
|
|
154
196
|
end
|
155
197
|
end
|
156
198
|
|
199
|
+
# @todo use composition rather than inheritance
|
157
200
|
def install_package(name, version)
|
158
201
|
raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :install"
|
159
202
|
end
|
@@ -178,6 +221,17 @@ class Chef
|
|
178
221
|
raise( Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :reconfig" )
|
179
222
|
end
|
180
223
|
|
224
|
+
# this is heavily used by subclasses
|
225
|
+
def expand_options(options)
|
226
|
+
options ? " #{options}" : ""
|
227
|
+
end
|
228
|
+
|
229
|
+
# this is public and overridden by subclasses (rubygems package implements '>=' and '~>' operators)
|
230
|
+
def target_version_already_installed?(current_version, new_version)
|
231
|
+
new_version == current_version
|
232
|
+
end
|
233
|
+
|
234
|
+
# @todo: extract apt/dpkg specific preseeding to a helper class
|
181
235
|
def get_preseed_file(name, version)
|
182
236
|
resource = preseed_resource(name, version)
|
183
237
|
resource.run_action(:create)
|
@@ -190,6 +244,7 @@ class Chef
|
|
190
244
|
end
|
191
245
|
end
|
192
246
|
|
247
|
+
# @todo: extract apt/dpkg specific preseeding to a helper class
|
193
248
|
def preseed_resource(name, version)
|
194
249
|
# A directory in our cache to store this cookbook's preseed files in
|
195
250
|
file_cache_dir = Chef::FileCache.create_cache_path("preseed/#{@new_resource.cookbook_name}")
|
@@ -216,24 +271,218 @@ class Chef
|
|
216
271
|
remote_file
|
217
272
|
end
|
218
273
|
|
219
|
-
|
220
|
-
|
274
|
+
# helper method used by subclasses
|
275
|
+
#
|
276
|
+
def as_array(thing)
|
277
|
+
[ thing ].flatten
|
221
278
|
end
|
222
279
|
|
223
|
-
|
224
|
-
|
280
|
+
private
|
281
|
+
|
282
|
+
# Returns the package names which need to be modified. If the resource was called with an array of packages
|
283
|
+
# then this will return an array of packages to update (may have 0 or 1 entries). If the resource was called
|
284
|
+
# with a non-array package_name to manage then this will return a string rather than an Array. The output
|
285
|
+
# of this is meant to be fed into subclass interfaces to install/upgrade packages and not all of them are
|
286
|
+
# Array-aware.
|
287
|
+
#
|
288
|
+
# @return [String, Array<String>] package_name(s) to actually update/install
|
289
|
+
def package_names_for_targets
|
290
|
+
package_names_for_targets = []
|
291
|
+
target_version_array.each_with_index do |target_version, i|
|
292
|
+
next if target_version.nil?
|
293
|
+
package_name = package_name_array[i]
|
294
|
+
package_names_for_targets.push(package_name)
|
295
|
+
end
|
296
|
+
multipackage? ? package_names_for_targets : package_names_for_targets[0]
|
225
297
|
end
|
226
298
|
|
227
|
-
|
299
|
+
# Returns the package versions which need to be modified. If the resource was called with an array of packages
|
300
|
+
# then this will return an array of versions to update (may have 0 or 1 entries). If the resource was called
|
301
|
+
# with a non-array package_name to manage then this will return a string rather than an Array. The output
|
302
|
+
# of this is meant to be fed into subclass interfaces to install/upgrade packages and not all of them are
|
303
|
+
# Array-aware.
|
304
|
+
#
|
305
|
+
# @return [String, Array<String>] package version(s) to actually update/install
|
306
|
+
def versions_for_targets
|
307
|
+
versions_for_targets = []
|
308
|
+
target_version_array.each_with_index do |target_version, i|
|
309
|
+
next if target_version.nil?
|
310
|
+
versions_for_targets.push(target_version)
|
311
|
+
end
|
312
|
+
multipackage? ? versions_for_targets : versions_for_targets[0]
|
313
|
+
end
|
314
|
+
|
315
|
+
# We need to mutate @new_resource.version() for some reason and this is a helper so that we inject the right
|
316
|
+
# class (String or Array) into that attribute based on if we're handling an array of package names or not.
|
317
|
+
#
|
318
|
+
# @return [String, Array<String>] target_versions coerced into the correct type for back-compat
|
319
|
+
def versions_for_new_resource
|
320
|
+
if multipackage?
|
321
|
+
target_version_array
|
322
|
+
else
|
323
|
+
target_version_array[0]
|
324
|
+
end
|
325
|
+
end
|
326
|
+
|
327
|
+
# Return an array indexed the same as *_version_array which contains either the target version to install/upgrade to
|
328
|
+
# or else nil if the package is not being modified.
|
329
|
+
#
|
330
|
+
# @return [Array<String,NilClass>] array of package versions which need to be upgraded (nil = not being upgraded)
|
331
|
+
def target_version_array
|
332
|
+
@target_version_array ||=
|
333
|
+
begin
|
334
|
+
target_version_array = []
|
335
|
+
|
336
|
+
each_package do |package_name, new_version, current_version, candidate_version|
|
337
|
+
case action
|
338
|
+
when :upgrade
|
339
|
+
|
340
|
+
if !candidate_version
|
341
|
+
Chef::Log.debug("#{new_resource} #{package_name} has no candidate_version to upgrade to")
|
342
|
+
target_version_array.push(nil)
|
343
|
+
elsif current_version == candidate_version
|
344
|
+
Chef::Log.debug("#{new_resource} #{package_name} the #{candidate_version} is already installed")
|
345
|
+
target_version_array.push(nil)
|
346
|
+
else
|
347
|
+
Chef::Log.debug("#{new_resource} #{package_name} is out of date, will upgrade to #{candidate_version}")
|
348
|
+
target_version_array.push(candidate_version)
|
349
|
+
end
|
350
|
+
|
351
|
+
when :install
|
352
|
+
|
353
|
+
if new_version
|
354
|
+
if target_version_already_installed?(current_version, new_version)
|
355
|
+
Chef::Log.debug("#{new_resource} #{package_name} #{current_version} satisifies #{new_version} requirement")
|
356
|
+
target_version_array.push(nil)
|
357
|
+
else
|
358
|
+
Chef::Log.debug("#{new_resource} #{package_name} #{current_version} needs updating to #{new_version}")
|
359
|
+
target_version_array.push(new_version)
|
360
|
+
end
|
361
|
+
elsif current_version.nil?
|
362
|
+
Chef::Log.debug("#{new_resource} #{package_name} not installed, installing #{candidate_version}")
|
363
|
+
target_version_array.push(candidate_version)
|
364
|
+
else
|
365
|
+
Chef::Log.debug("#{new_resource} #{package_name} #{current_version} already installed")
|
366
|
+
target_version_array.push(nil)
|
367
|
+
end
|
368
|
+
|
369
|
+
else
|
370
|
+
# in specs please test the public interface provider.run_action(:install) instead of provider.action_install
|
371
|
+
raise "internal error - target_version_array in package provider does not understand this action"
|
372
|
+
end
|
373
|
+
end
|
374
|
+
|
375
|
+
target_version_array
|
376
|
+
end
|
377
|
+
end
|
378
|
+
|
379
|
+
# Check the list of current_version_array and candidate_version_array. For any of the
|
380
|
+
# packages if both versions are missing (uninstalled and no candidate) this will be an
|
381
|
+
# unsolvable error.
|
382
|
+
#
|
383
|
+
# @return [Boolean] valid candidates exist for all uninstalled packages
|
384
|
+
def candidates_exist_for_all_uninstalled?
|
385
|
+
packages_missing_candidates.empty?
|
386
|
+
end
|
387
|
+
|
388
|
+
# Returns array of all packages which are missing candidate versions.
|
389
|
+
#
|
390
|
+
# @return [Array<String>] names of packages missing candidates
|
391
|
+
def packages_missing_candidates
|
392
|
+
@packages_missing_candidates ||=
|
393
|
+
begin
|
394
|
+
missing = []
|
395
|
+
each_package do |package_name, new_version, current_version, candidate_version|
|
396
|
+
missing.push(package_name) if candidate_version.nil? && current_version.nil?
|
397
|
+
end
|
398
|
+
missing
|
399
|
+
end
|
400
|
+
end
|
401
|
+
|
402
|
+
# This looks for packages which have a new_version and a current_version, and they are
|
403
|
+
# different (a "forced change") and for which there is no candidate. This is an edge
|
404
|
+
# condition that candidates_exist_for_all_uninstalled? does not catch since in this case
|
405
|
+
# it is not uninstalled but must be installed anyway and no version exists.
|
406
|
+
#
|
407
|
+
# @return [Boolean] valid candidates exist for all uninstalled packages
|
408
|
+
def candidates_exist_for_all_forced_changes?
|
409
|
+
forced_packages_missing_candidates.empty?
|
410
|
+
end
|
411
|
+
|
412
|
+
# Returns an array of all forced packages which are missing candidate versions
|
413
|
+
#
|
414
|
+
# @return [Array] names of packages missing candidates
|
415
|
+
def forced_packages_missing_candidates
|
416
|
+
@forced_packages_missing_candidates ||=
|
417
|
+
begin
|
418
|
+
missing = []
|
419
|
+
each_package do |package_name, new_version, current_version, candidate_version|
|
420
|
+
next if new_version.nil? || current_version.nil?
|
421
|
+
if candidate_version.nil? && !target_version_already_installed?(current_version, new_version)
|
422
|
+
missing.push(package_name)
|
423
|
+
end
|
424
|
+
end
|
425
|
+
missing
|
426
|
+
end
|
427
|
+
end
|
428
|
+
|
429
|
+
# Helper to iterate over all the indexed *_array's in sync
|
430
|
+
#
|
431
|
+
# @yield [package_name, new_version, current_version, candidate_version] Description of block
|
432
|
+
def each_package
|
433
|
+
package_name_array.each_with_index do |package_name, i|
|
434
|
+
candidate_version = candidate_version_array[i]
|
435
|
+
current_version = current_version_array[i]
|
436
|
+
new_version = new_version_array[i]
|
437
|
+
yield package_name, new_version, current_version, candidate_version
|
438
|
+
end
|
439
|
+
end
|
440
|
+
|
441
|
+
# @return [Boolean] if we're doing a multipackage install or not
|
442
|
+
def multipackage?
|
443
|
+
new_resource.package_name.is_a?(Array)
|
444
|
+
end
|
445
|
+
|
446
|
+
# @return [Array] package_name(s) as an array
|
447
|
+
def package_name_array
|
448
|
+
[ new_resource.package_name ].flatten
|
449
|
+
end
|
450
|
+
|
451
|
+
# @return [Array] candidate_version(s) as an array
|
452
|
+
def candidate_version_array
|
453
|
+
[ candidate_version ].flatten
|
454
|
+
end
|
228
455
|
|
456
|
+
# @return [Array] current_version(s) as an array
|
457
|
+
def current_version_array
|
458
|
+
[ current_resource.version ].flatten
|
459
|
+
end
|
460
|
+
|
461
|
+
# @return [Array] new_version(s) as an array
|
462
|
+
def new_version_array
|
463
|
+
@new_version_array ||=
|
464
|
+
[ new_resource.version ].flatten.map do |v|
|
465
|
+
( v.nil? || v.empty? ) ? nil : v
|
466
|
+
end
|
467
|
+
end
|
468
|
+
|
469
|
+
# @todo: extract apt/dpkg specific preseeding to a helper class
|
229
470
|
def template_available?(path)
|
230
|
-
run_context.has_template_in_cookbook?(
|
471
|
+
run_context.has_template_in_cookbook?(new_resource.cookbook_name, path)
|
231
472
|
end
|
232
473
|
|
474
|
+
# @todo: extract apt/dpkg specific preseeding to a helper class
|
233
475
|
def cookbook_file_available?(path)
|
234
|
-
run_context.has_cookbook_file_in_cookbook?(
|
476
|
+
run_context.has_cookbook_file_in_cookbook?(new_resource.cookbook_name, path)
|
235
477
|
end
|
236
478
|
|
479
|
+
def allow_downgrade
|
480
|
+
if @new_resource.respond_to?("allow_downgrade")
|
481
|
+
@new_resource.allow_downgrade
|
482
|
+
else
|
483
|
+
false
|
484
|
+
end
|
485
|
+
end
|
237
486
|
end
|
238
487
|
end
|
239
488
|
end
|