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
@@ -131,12 +131,12 @@ describe Chef::Resource::Env, :windows_only do
|
|
131
131
|
let!(:env_path_before) { ENV['PATH'] }
|
132
132
|
|
133
133
|
it 'should expand PATH' do
|
134
|
-
path_before.
|
134
|
+
expect(path_before).not_to include(env_val)
|
135
135
|
test_resource.key_name('PATH')
|
136
136
|
test_resource.value("#{path_before};#{env_val}")
|
137
137
|
test_resource.run_action(:create)
|
138
|
-
ENV['PATH'].
|
139
|
-
ENV['PATH'].
|
138
|
+
expect(ENV['PATH']).not_to include(env_val)
|
139
|
+
expect(ENV['PATH']).to include("#{random_name}")
|
140
140
|
end
|
141
141
|
|
142
142
|
after(:each) do
|
@@ -18,96 +18,130 @@
|
|
18
18
|
|
19
19
|
require 'spec_helper'
|
20
20
|
require 'functional/resource/base'
|
21
|
+
require 'timeout'
|
21
22
|
|
22
23
|
describe Chef::Resource::Execute do
|
23
|
-
let(:
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
exec_resource.cwd(resource_cwd) if resource_cwd
|
28
|
-
exec_resource.command("echo hello")
|
29
|
-
if guard
|
30
|
-
if guard_options
|
31
|
-
exec_resource.only_if(guard, guard_options)
|
32
|
-
else
|
33
|
-
exec_resource.only_if(guard)
|
34
|
-
end
|
35
|
-
end
|
36
|
-
exec_resource
|
24
|
+
let(:resource) {
|
25
|
+
resource = Chef::Resource::Execute.new("foo_resource", run_context)
|
26
|
+
resource.command("echo hello")
|
27
|
+
resource
|
37
28
|
}
|
38
29
|
|
39
|
-
let(:resource_environment) { nil }
|
40
|
-
let(:resource_cwd) { nil }
|
41
|
-
let(:guard) { nil }
|
42
|
-
let(:guard_options) { nil }
|
43
|
-
|
44
30
|
describe "when guard is ruby block" do
|
45
31
|
it "guard can still run" do
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
execute_resource.run_action(:run)
|
50
|
-
execute_resource.should be_updated_by_last_action
|
32
|
+
resource.only_if { true }
|
33
|
+
resource.run_action(:run)
|
34
|
+
expect(resource).to be_updated_by_last_action
|
51
35
|
end
|
52
36
|
end
|
53
37
|
|
54
|
-
describe "when
|
55
|
-
|
38
|
+
describe "when why_run is enabled" do
|
39
|
+
before do
|
40
|
+
Chef::Config[:why_run] = true
|
41
|
+
end
|
42
|
+
|
43
|
+
let(:guard) { "ruby -e 'exit 0'" }
|
44
|
+
let!(:guard_resource) {
|
45
|
+
interpreter = Chef::GuardInterpreter::ResourceGuardInterpreter.new(resource, guard, nil)
|
46
|
+
interpreter.send(:get_interpreter_resource, resource)
|
47
|
+
}
|
48
|
+
|
49
|
+
it "executes the guard and not the regular resource" do
|
50
|
+
expect_any_instance_of(Chef::GuardInterpreter::ResourceGuardInterpreter).to receive(:get_interpreter_resource).and_return(guard_resource)
|
51
|
+
|
52
|
+
# why_run mode doesn't disable the updated_by_last_action logic, so we really have to look at the provider action
|
53
|
+
# to see if why_run correctly disabled the resource. It should shell_out! for the guard but not the resource.
|
54
|
+
expect_any_instance_of(Chef::Provider::Execute).to receive(:shell_out!).once
|
56
55
|
|
56
|
+
resource.only_if guard
|
57
|
+
resource.run_action(:run)
|
58
|
+
|
59
|
+
expect(resource).to be_updated_by_last_action
|
60
|
+
expect(guard_resource).to be_updated_by_last_action
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
describe "when parent resource sets :cwd" do
|
57
65
|
let(:guard) { %{ruby -e 'exit 1 unless File.exists?("./big_json_plus_one.json")'} }
|
58
66
|
|
59
|
-
it "guard inherits :cwd from resource" do
|
60
|
-
|
61
|
-
|
67
|
+
it "guard inherits :cwd from resource and runs" do
|
68
|
+
resource.cwd CHEF_SPEC_DATA
|
69
|
+
resource.only_if guard
|
70
|
+
resource.run_action(:run)
|
71
|
+
expect(resource).to be_updated_by_last_action
|
72
|
+
end
|
73
|
+
|
74
|
+
it "guard inherits :cwd from resource and does not run" do
|
75
|
+
resource.cwd CHEF_SPEC_DATA
|
76
|
+
resource.not_if guard
|
77
|
+
resource.run_action(:run)
|
78
|
+
expect(resource).not_to be_updated_by_last_action
|
62
79
|
end
|
63
80
|
end
|
64
81
|
|
82
|
+
# We use ruby command so that we don't need to deal with platform specific
|
83
|
+
# commands while testing execute resource. We set it so that the resource
|
84
|
+
# will be updated if the ENV variable is set to what we are intending
|
85
|
+
#
|
86
|
+
# FIXME: yeah, but invoking ruby is slow...
|
65
87
|
describe "when parent resource sets :environment" do
|
66
|
-
|
67
|
-
{
|
88
|
+
before do
|
89
|
+
resource.environment({
|
68
90
|
"SAWS_SECRET" => "supersecret",
|
69
|
-
"SAWS_KEY" => "qwerty"
|
70
|
-
}
|
91
|
+
"SAWS_KEY" => "qwerty",
|
92
|
+
})
|
71
93
|
end
|
72
94
|
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
it "guard inherits :environment value from resource" do
|
79
|
-
execute_resource.run_action(:run)
|
80
|
-
execute_resource.should be_updated_by_last_action
|
95
|
+
it "guard inherits :environment value from resource and runs" do
|
96
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SAWS_SECRET"] != "supersecret"'}
|
97
|
+
resource.run_action(:run)
|
98
|
+
expect(resource).to be_updated_by_last_action
|
81
99
|
end
|
82
100
|
|
83
|
-
|
84
|
-
|
101
|
+
it "guard inherits :environment value from resource and does not run" do
|
102
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SAWS_SECRET"] == "supersecret"'}
|
103
|
+
resource.run_action(:run)
|
104
|
+
expect(resource).not_to be_updated_by_last_action
|
105
|
+
end
|
85
106
|
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
107
|
+
it "guard adds additional values in its :environment and runs" do
|
108
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SGCE_SECRET"] != "regularsecret"'}, {
|
109
|
+
:environment => { 'SGCE_SECRET' => "regularsecret" }
|
110
|
+
}
|
111
|
+
resource.run_action(:run)
|
112
|
+
expect(resource).to be_updated_by_last_action
|
113
|
+
end
|
91
114
|
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
115
|
+
it "guard adds additional values in its :environment and does not run" do
|
116
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SGCE_SECRET"] == "regularsecret"'}, {
|
117
|
+
:environment => { 'SGCE_SECRET' => "regularsecret" }
|
118
|
+
}
|
119
|
+
resource.run_action(:run)
|
120
|
+
expect(resource).not_to be_updated_by_last_action
|
96
121
|
end
|
97
122
|
|
98
|
-
|
99
|
-
|
123
|
+
it "guard overwrites value with its :environment and runs" do
|
124
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SAWS_SECRET"] != "regularsecret"'}, {
|
125
|
+
:environment => { 'SAWS_SECRET' => "regularsecret" }
|
126
|
+
}
|
127
|
+
resource.run_action(:run)
|
128
|
+
expect(resource).to be_updated_by_last_action
|
129
|
+
end
|
100
130
|
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
131
|
+
it "guard overwrites value with its :environment and does not runs" do
|
132
|
+
resource.only_if %{ruby -e 'exit 1 if ENV["SAWS_SECRET"] == "regularsecret"'}, {
|
133
|
+
:environment => { 'SAWS_SECRET' => "regularsecret" }
|
134
|
+
}
|
135
|
+
resource.run_action(:run)
|
136
|
+
expect(resource).not_to be_updated_by_last_action
|
137
|
+
end
|
138
|
+
end
|
106
139
|
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
140
|
+
it "times out when a timeout is set on the resource" do
|
141
|
+
Timeout::timeout(5) do
|
142
|
+
resource.command %{ruby -e 'sleep 600'}
|
143
|
+
resource.timeout 0.1
|
144
|
+
expect { resource.run_action(:run) }.to raise_error(Mixlib::ShellOut::CommandTimeout)
|
111
145
|
end
|
112
146
|
end
|
113
147
|
end
|
@@ -77,11 +77,11 @@ describe Chef::Resource::File do
|
|
77
77
|
|
78
78
|
context "and the target file does not exist" do
|
79
79
|
it "creates the file" do
|
80
|
-
File.
|
80
|
+
expect(File).to exist(path)
|
81
81
|
end
|
82
82
|
|
83
83
|
it "is marked updated by last action" do
|
84
|
-
resource_without_content.
|
84
|
+
expect(resource_without_content).to be_updated_by_last_action
|
85
85
|
end
|
86
86
|
end
|
87
87
|
end
|
@@ -106,11 +106,11 @@ describe Chef::Resource::File do
|
|
106
106
|
end
|
107
107
|
|
108
108
|
it "it creates the file" do
|
109
|
-
File.
|
109
|
+
expect(File).to exist(path)
|
110
110
|
end
|
111
111
|
|
112
112
|
it "is marked updated by last action" do
|
113
|
-
resource.
|
113
|
+
expect(resource).to be_updated_by_last_action
|
114
114
|
end
|
115
115
|
end
|
116
116
|
|
@@ -128,15 +128,15 @@ describe Chef::Resource::File do
|
|
128
128
|
end
|
129
129
|
|
130
130
|
it "updates the mtime of the file" do
|
131
|
-
File.stat(path).mtime.
|
131
|
+
expect(File.stat(path).mtime).to be > @expected_mtime
|
132
132
|
end
|
133
133
|
|
134
134
|
it "does not change the content" do
|
135
|
-
sha256_checksum(path).
|
135
|
+
expect(sha256_checksum(path)).to eq(@expected_checksum)
|
136
136
|
end
|
137
137
|
|
138
138
|
it "is marked as updated by last action" do
|
139
|
-
resource.
|
139
|
+
expect(resource).to be_updated_by_last_action
|
140
140
|
end
|
141
141
|
end
|
142
142
|
end
|
@@ -92,7 +92,7 @@ E
|
|
92
92
|
|
93
93
|
before(:all) do
|
94
94
|
@ohai = Ohai::System.new
|
95
|
-
@ohai.all_plugins("os")
|
95
|
+
@ohai.all_plugins(["platform", "os"])
|
96
96
|
end
|
97
97
|
|
98
98
|
context "working with pathes with special characters" do
|
@@ -130,10 +130,10 @@ E
|
|
130
130
|
it "checks out the revision pointed to by the tag commit, not the tag commit itself" do
|
131
131
|
basic_git_resource.run_action(:sync)
|
132
132
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
133
|
-
head_rev.
|
133
|
+
expect(head_rev).to eq(v1_commit)
|
134
134
|
# also verify the tag commit itself is what we expect as an extra sanity check
|
135
135
|
rev = shell_out!('git rev-parse v1.0.0', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
136
|
-
rev.
|
136
|
+
expect(rev).to eq(v1_tag)
|
137
137
|
end
|
138
138
|
|
139
139
|
it "doesn't update if up-to-date" do
|
@@ -141,10 +141,10 @@ E
|
|
141
141
|
# properly to the pointed to commit.
|
142
142
|
basic_git_resource.run_action(:sync)
|
143
143
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
144
|
-
head_rev.
|
144
|
+
expect(head_rev).to eq(v1_commit)
|
145
145
|
|
146
146
|
copy_git_resource.run_action(:sync)
|
147
|
-
copy_git_resource.
|
147
|
+
expect(copy_git_resource).not_to be_updated
|
148
148
|
end
|
149
149
|
end
|
150
150
|
|
@@ -167,25 +167,25 @@ E
|
|
167
167
|
basic_git_resource.revision rev_foo
|
168
168
|
basic_git_resource.run_action(:sync)
|
169
169
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
170
|
-
head_rev.
|
170
|
+
expect(head_rev).to eq(rev_foo)
|
171
171
|
end
|
172
172
|
|
173
173
|
it "doesn't update if up-to-date" do
|
174
174
|
basic_git_resource.revision rev_foo
|
175
175
|
basic_git_resource.run_action(:sync)
|
176
176
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
177
|
-
head_rev.
|
177
|
+
expect(head_rev).to eq(rev_foo)
|
178
178
|
|
179
179
|
copy_git_resource.revision rev_foo
|
180
180
|
copy_git_resource.run_action(:sync)
|
181
|
-
copy_git_resource.
|
181
|
+
expect(copy_git_resource).not_to be_updated
|
182
182
|
end
|
183
183
|
|
184
184
|
it "checks out the expected revision 972d" do
|
185
185
|
basic_git_resource.revision rev_testing
|
186
186
|
basic_git_resource.run_action(:sync)
|
187
187
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
188
|
-
head_rev.
|
188
|
+
expect(head_rev).to eq(rev_testing)
|
189
189
|
end
|
190
190
|
end
|
191
191
|
|
@@ -200,7 +200,7 @@ E
|
|
200
200
|
it "checks out the expected revision" do
|
201
201
|
basic_git_resource.run_action(:sync)
|
202
202
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
203
|
-
head_rev.
|
203
|
+
expect(head_rev).to eq(rev_head)
|
204
204
|
end
|
205
205
|
end
|
206
206
|
|
@@ -215,7 +215,7 @@ E
|
|
215
215
|
it "checks out HEAD as the default revision" do
|
216
216
|
basic_git_resource.run_action(:sync)
|
217
217
|
head_rev = shell_out!('git rev-parse HEAD', :cwd => deploy_directory, :returns => [0]).stdout.strip
|
218
|
-
head_rev.
|
218
|
+
expect(head_rev).to eq(rev_head)
|
219
219
|
end
|
220
220
|
end
|
221
221
|
|
@@ -244,7 +244,7 @@ E
|
|
244
244
|
head_rev = shell_out!('git rev-parse HEAD',
|
245
245
|
:cwd => deploy_directory,
|
246
246
|
:returns => [0]).stdout.strip
|
247
|
-
head_rev.
|
247
|
+
expect(head_rev).to eq(rev_head)
|
248
248
|
end
|
249
249
|
|
250
250
|
it "checks out the (master) HEAD revision when no revision is specified (ignores tag)" do
|
@@ -252,7 +252,7 @@ E
|
|
252
252
|
head_rev = shell_out!('git rev-parse HEAD',
|
253
253
|
:cwd => deploy_directory,
|
254
254
|
:returns => [0]).stdout.strip
|
255
|
-
head_rev.
|
255
|
+
expect(head_rev).to eq(rev_head)
|
256
256
|
end
|
257
257
|
|
258
258
|
end
|
@@ -19,12 +19,15 @@
|
|
19
19
|
|
20
20
|
require 'spec_helper'
|
21
21
|
require 'functional/resource/base'
|
22
|
+
require 'chef/mixin/shell_out'
|
22
23
|
|
23
24
|
# Chef::Resource::Group are turned off on Mac OS X 10.6 due to caching
|
24
25
|
# issues around Etc.getgrnam() not picking up the group membership
|
25
26
|
# changes that are done on the system. Etc.endgrent is not functioning
|
26
27
|
# correctly on certain 10.6 boxes.
|
27
28
|
describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supported_on_mac_osx_106 do
|
29
|
+
include Chef::Mixin::ShellOut
|
30
|
+
|
28
31
|
def group_should_exist(group)
|
29
32
|
case ohai[:platform_family]
|
30
33
|
when "debian", "fedora", "rhel", "suse", "gentoo", "slackware", "arch"
|
@@ -108,7 +111,7 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
108
111
|
temp_resource.append(true)
|
109
112
|
temp_resource.run_action(:modify)
|
110
113
|
members.each do |member|
|
111
|
-
user_exist_in_group?(member).
|
114
|
+
expect(user_exist_in_group?(member)).to eq(true)
|
112
115
|
end
|
113
116
|
end
|
114
117
|
|
@@ -119,7 +122,7 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
119
122
|
temp_resource.run_action(:create)
|
120
123
|
group_should_exist(group_name)
|
121
124
|
included_members.each do |member|
|
122
|
-
user_exist_in_group?(member).
|
125
|
+
expect(user_exist_in_group?(member)).to eq(false)
|
123
126
|
end
|
124
127
|
end
|
125
128
|
|
@@ -149,8 +152,8 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
149
152
|
it "should remove the existing users and add the new users to the group" do
|
150
153
|
group_resource.run_action(tested_action)
|
151
154
|
|
152
|
-
user_exist_in_group?(spec_members[1]).
|
153
|
-
user_exist_in_group?(spec_members[0]).
|
155
|
+
expect(user_exist_in_group?(spec_members[1])).to eq(true)
|
156
|
+
expect(user_exist_in_group?(spec_members[0])).to eq(false)
|
154
157
|
end
|
155
158
|
end
|
156
159
|
|
@@ -176,10 +179,10 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
176
179
|
group_resource.run_action(tested_action)
|
177
180
|
|
178
181
|
included_members.each do |member|
|
179
|
-
user_exist_in_group?(member).
|
182
|
+
expect(user_exist_in_group?(member)).to eq(true)
|
180
183
|
end
|
181
184
|
excluded_members.each do |member|
|
182
|
-
user_exist_in_group?(member).
|
185
|
+
expect(user_exist_in_group?(member)).to eq(false)
|
183
186
|
end
|
184
187
|
end
|
185
188
|
|
@@ -192,10 +195,10 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
192
195
|
group_resource.run_action(tested_action)
|
193
196
|
|
194
197
|
included_members.each do |member|
|
195
|
-
user_exist_in_group?(member).
|
198
|
+
expect(user_exist_in_group?(member)).to eq(true)
|
196
199
|
end
|
197
200
|
excluded_members.each do |member|
|
198
|
-
user_exist_in_group?(member).
|
201
|
+
expect(user_exist_in_group?(member)).to eq(false)
|
199
202
|
end
|
200
203
|
end
|
201
204
|
end
|
@@ -204,13 +207,13 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
204
207
|
describe "when the users doesn't exist" do
|
205
208
|
describe "when append is not set" do
|
206
209
|
it "should raise an error" do
|
207
|
-
|
210
|
+
expect { @grp_resource.run_action(tested_action) }.to raise_error
|
208
211
|
end
|
209
212
|
end
|
210
213
|
|
211
214
|
describe "when append is set" do
|
212
215
|
it "should raise an error" do
|
213
|
-
|
216
|
+
expect { @grp_resource.run_action(tested_action) }.to raise_error
|
214
217
|
end
|
215
218
|
end
|
216
219
|
end
|
@@ -231,24 +234,24 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
231
234
|
describe "when updating membership" do
|
232
235
|
it "raises an error for a non well-formed domain name" do
|
233
236
|
group_resource.members [invalid_domain_user_name]
|
234
|
-
|
237
|
+
expect { group_resource.run_action(tested_action) }.to raise_error Chef::Exceptions::Win32APIError
|
235
238
|
end
|
236
239
|
|
237
240
|
it "raises an error for a nonexistent domain" do
|
238
241
|
group_resource.members [nonexistent_domain_user_name]
|
239
|
-
|
242
|
+
expect { group_resource.run_action(tested_action) }.to raise_error Chef::Exceptions::Win32APIError
|
240
243
|
end
|
241
244
|
end
|
242
245
|
|
243
246
|
describe "when removing members" do
|
244
247
|
it "raises an error for a non well-formed domain name" do
|
245
248
|
group_resource.excluded_members [invalid_domain_user_name]
|
246
|
-
|
249
|
+
expect { group_resource.run_action(tested_action) }.to raise_error Chef::Exceptions::Win32APIError
|
247
250
|
end
|
248
251
|
|
249
252
|
it "raises an error for a nonexistent domain" do
|
250
253
|
group_resource.excluded_members [nonexistent_domain_user_name]
|
251
|
-
|
254
|
+
expect { group_resource.run_action(tested_action) }.to raise_error Chef::Exceptions::Win32APIError
|
252
255
|
end
|
253
256
|
end
|
254
257
|
end
|
@@ -264,7 +267,7 @@ describe Chef::Resource::Group, :requires_root_or_running_windows, :not_supporte
|
|
264
267
|
}
|
265
268
|
|
266
269
|
it "append should be false by default" do
|
267
|
-
group_resource.append.
|
270
|
+
expect(group_resource.append).to eq(false)
|
268
271
|
end
|
269
272
|
|
270
273
|
describe "group create action" do
|
@@ -297,7 +300,7 @@ theoldmanwalkingdownthestreetalwayshadagoodsmileonhisfacetheoldmanwalking\
|
|
297
300
|
downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
298
301
|
|
299
302
|
it "should not create a group" do
|
300
|
-
|
303
|
+
expect { group_resource.run_action(:create) }.to raise_error
|
301
304
|
group_should_not_exist(group_name)
|
302
305
|
end
|
303
306
|
end
|
@@ -308,7 +311,7 @@ downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
|
308
311
|
invalid_resource = group_resource.dup
|
309
312
|
invalid_resource.members(["Jack"])
|
310
313
|
invalid_resource.excluded_members(["Jack"])
|
311
|
-
|
314
|
+
expect { invalid_resource.run_action(:create)}.to raise_error(Chef::Exceptions::ConflictingMembersInGroup)
|
312
315
|
end
|
313
316
|
end
|
314
317
|
end
|
@@ -342,7 +345,7 @@ downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
|
342
345
|
|
343
346
|
describe "when there is no group" do
|
344
347
|
it "should raise an error" do
|
345
|
-
|
348
|
+
expect { group_resource.run_action(:modify) }.to raise_error
|
346
349
|
end
|
347
350
|
end
|
348
351
|
|
@@ -370,11 +373,11 @@ downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
|
370
373
|
|
371
374
|
describe "when there is no group" do
|
372
375
|
it "raises an error on modify" do
|
373
|
-
|
376
|
+
expect { group_resource.run_action(:modify) }.to raise_error
|
374
377
|
end
|
375
378
|
|
376
379
|
it "does not raise an error on manage" do
|
377
|
-
|
380
|
+
expect { group_resource.run_action(:manage) }.not_to raise_error
|
378
381
|
end
|
379
382
|
end
|
380
383
|
|
@@ -399,15 +402,15 @@ downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
|
399
402
|
let(:excluded_members) { ["Anthony"] }
|
400
403
|
|
401
404
|
it ":manage should raise an error" do
|
402
|
-
|
405
|
+
expect {group_resource.run_action(:manage) }.to raise_error
|
403
406
|
end
|
404
407
|
|
405
408
|
it ":modify should raise an error" do
|
406
|
-
|
409
|
+
expect {group_resource.run_action(:modify) }.to raise_error
|
407
410
|
end
|
408
411
|
|
409
412
|
it ":create should raise an error" do
|
410
|
-
|
413
|
+
expect {group_resource.run_action(:create) }.to raise_error
|
411
414
|
end
|
412
415
|
end
|
413
416
|
|
@@ -419,11 +422,11 @@ downthestreetalwayshadagoodsmileonhisfacetheoldmanwalkingdownthestreeQQQQQQ" }
|
|
419
422
|
end
|
420
423
|
|
421
424
|
it ":manage should raise an error" do
|
422
|
-
|
425
|
+
expect {group_resource.run_action(:manage) }.to raise_error
|
423
426
|
end
|
424
427
|
|
425
428
|
it ":modify should raise an error" do
|
426
|
-
|
429
|
+
expect {group_resource.run_action(:modify) }.to raise_error
|
427
430
|
end
|
428
431
|
end
|
429
432
|
end
|