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
@@ -72,7 +72,7 @@ describe Chef::Exceptions do
|
|
72
72
|
|
73
73
|
exception_to_super_class.each do |exception, expected_super_class|
|
74
74
|
it "should have an exception class of #{exception} which inherits from #{expected_super_class}" do
|
75
|
-
|
75
|
+
expect{ raise exception }.to raise_error(expected_super_class)
|
76
76
|
end
|
77
77
|
|
78
78
|
if exception.methods.include?(:to_json)
|
@@ -81,4 +81,50 @@ describe Chef::Exceptions do
|
|
81
81
|
end
|
82
82
|
end
|
83
83
|
end
|
84
|
+
|
85
|
+
describe Chef::Exceptions::RunFailedWrappingError do
|
86
|
+
shared_examples "RunFailedWrappingError expectations" do
|
87
|
+
it "should initialize with a default message" do
|
88
|
+
expect(e.message).to eq("Found #{num_errors} errors, they are stored in the backtrace")
|
89
|
+
end
|
90
|
+
|
91
|
+
it "should provide a modified backtrace when requested" do
|
92
|
+
e.fill_backtrace
|
93
|
+
expect(e.backtrace).to eq(backtrace)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
context "initialized with nothing" do
|
98
|
+
let(:e) { Chef::Exceptions::RunFailedWrappingError.new }
|
99
|
+
let(:num_errors) { 0 }
|
100
|
+
let(:backtrace) { [] }
|
101
|
+
|
102
|
+
include_examples "RunFailedWrappingError expectations"
|
103
|
+
end
|
104
|
+
|
105
|
+
context "initialized with nil" do
|
106
|
+
let(:e) { Chef::Exceptions::RunFailedWrappingError.new(nil, nil) }
|
107
|
+
let(:num_errors) { 0 }
|
108
|
+
let(:backtrace) { [] }
|
109
|
+
|
110
|
+
include_examples "RunFailedWrappingError expectations"
|
111
|
+
end
|
112
|
+
|
113
|
+
context "initialized with 1 error and nil" do
|
114
|
+
let(:e) { Chef::Exceptions::RunFailedWrappingError.new(RuntimeError.new("foo"), nil) }
|
115
|
+
let(:num_errors) { 1 }
|
116
|
+
let(:backtrace) { ["1) RuntimeError - foo", ""] }
|
117
|
+
|
118
|
+
include_examples "RunFailedWrappingError expectations"
|
119
|
+
end
|
120
|
+
|
121
|
+
context "initialized with 2 errors" do
|
122
|
+
let(:e) { Chef::Exceptions::RunFailedWrappingError.new(RuntimeError.new("foo"), RuntimeError.new("bar")) }
|
123
|
+
let(:num_errors) { 2 }
|
124
|
+
let(:backtrace) { ["1) RuntimeError - foo", "", "2) RuntimeError - bar", ""] }
|
125
|
+
|
126
|
+
include_examples "RunFailedWrappingError expectations"
|
127
|
+
end
|
128
|
+
|
129
|
+
end
|
84
130
|
end
|
@@ -42,48 +42,54 @@ describe Chef::FileAccessControl do
|
|
42
42
|
end
|
43
43
|
end
|
44
44
|
|
45
|
+
describe 'class methods' do
|
46
|
+
it 'responds to #writable?' do
|
47
|
+
expect(Chef::FileAccessControl).to respond_to(:writable?)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
45
51
|
it "has a resource" do
|
46
|
-
@fac.resource.
|
52
|
+
expect(@fac.resource).to equal(@resource)
|
47
53
|
end
|
48
54
|
|
49
55
|
it "has a file to manage" do
|
50
|
-
@fac.file.
|
56
|
+
expect(@fac.file).to eq('/tmp/different_file.txt')
|
51
57
|
end
|
52
58
|
|
53
59
|
it "is not modified yet" do
|
54
|
-
@fac.
|
60
|
+
expect(@fac).not_to be_modified
|
55
61
|
end
|
56
62
|
|
57
63
|
it "determines the uid of the owner specified by the resource" do
|
58
|
-
Etc.
|
59
|
-
@fac.target_uid.
|
64
|
+
expect(Etc).to receive(:getpwnam).with('toor').and_return(OpenStruct.new(:uid => 2342))
|
65
|
+
expect(@fac.target_uid).to eq(2342)
|
60
66
|
end
|
61
67
|
|
62
68
|
it "raises a Chef::Exceptions::UserIDNotFound error when Etc can't find the user's name" do
|
63
|
-
Etc.
|
64
|
-
|
69
|
+
expect(Etc).to receive(:getpwnam).with('toor').and_raise(ArgumentError)
|
70
|
+
expect { @fac.target_uid ; @provider_requirements.run(:create) }.to raise_error(Chef::Exceptions::UserIDNotFound, "cannot determine user id for 'toor', does the user exist on this system?")
|
65
71
|
end
|
66
72
|
|
67
73
|
it "does not attempt to resolve the uid if the user is not specified" do
|
68
74
|
resource = Chef::Resource::File.new("a file")
|
69
75
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
70
|
-
fac.target_uid.
|
76
|
+
expect(fac.target_uid).to be_nil
|
71
77
|
end
|
72
78
|
|
73
79
|
it "does not want to update the owner if none is specified" do
|
74
80
|
resource = Chef::Resource::File.new("a file")
|
75
81
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
76
|
-
fac.should_update_owner
|
82
|
+
expect(fac.should_update_owner?).to be_falsey
|
77
83
|
end
|
78
84
|
|
79
85
|
it "raises an ArgumentError if the resource's owner is set to something wack" do
|
80
86
|
@resource.instance_variable_set(:@owner, :diaf)
|
81
|
-
|
87
|
+
expect { @fac.target_uid ; @provider_requirements.run(:create) }.to raise_error(ArgumentError)
|
82
88
|
end
|
83
89
|
|
84
90
|
it "uses the resource's uid for the target uid when the resource's owner is specified by an integer" do
|
85
91
|
@resource.owner(2342)
|
86
|
-
@fac.target_uid.
|
92
|
+
expect(@fac.target_uid).to eq(2342)
|
87
93
|
end
|
88
94
|
|
89
95
|
it "wraps uids to their negative complements to correctly handle negative uids" do
|
@@ -93,28 +99,28 @@ describe Chef::FileAccessControl do
|
|
93
99
|
# uids. So we have to get ruby and negative uids to smoke the peace pipe
|
94
100
|
# with each other.
|
95
101
|
@resource.owner('nobody')
|
96
|
-
Etc.
|
97
|
-
@fac.target_uid.
|
102
|
+
expect(Etc).to receive(:getpwnam).with('nobody').and_return(OpenStruct.new(:uid => (4294967294)))
|
103
|
+
expect(@fac.target_uid).to eq(-2)
|
98
104
|
end
|
99
105
|
|
100
106
|
it "does not wrap uids to their negative complements beyond -9" do
|
101
107
|
# More: when OSX userIDs are created by ActiveDirectory sync, it tends to use huge numbers
|
102
108
|
# which had been incorrectly wrapped. It does not look like the OSX IDs go below -2
|
103
109
|
@resource.owner('bigdude')
|
104
|
-
Etc.
|
105
|
-
@fac.target_uid.
|
110
|
+
expect(Etc).to receive(:getpwnam).with('bigdude').and_return(OpenStruct.new(:uid => (4294967286)))
|
111
|
+
expect(@fac.target_uid).to eq(4294967286)
|
106
112
|
end
|
107
113
|
|
108
114
|
it "wants to update the owner when the current owner is nil (creating a file)" do
|
109
115
|
@current_resource.owner(nil)
|
110
116
|
@resource.owner(2342)
|
111
|
-
@fac.should_update_owner
|
117
|
+
expect(@fac.should_update_owner?).to be_truthy
|
112
118
|
end
|
113
119
|
|
114
120
|
it "wants to update the owner when the current owner doesn't match desired" do
|
115
121
|
@current_resource.owner(3224)
|
116
122
|
@resource.owner(2342)
|
117
|
-
@fac.should_update_owner
|
123
|
+
expect(@fac.should_update_owner?).to be_truthy
|
118
124
|
end
|
119
125
|
|
120
126
|
it "includes updating ownership in its list of desired changes" do
|
@@ -122,72 +128,72 @@ describe Chef::FileAccessControl do
|
|
122
128
|
resource.owner(2342)
|
123
129
|
@current_resource.owner(100)
|
124
130
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
125
|
-
fac.describe_changes.
|
131
|
+
expect(fac.describe_changes).to eq(["change owner from '100' to '2342'"])
|
126
132
|
end
|
127
133
|
|
128
134
|
it "sets the file's owner as specified in the resource when the current owner is incorrect" do
|
129
135
|
@resource.owner(2342)
|
130
|
-
File.
|
136
|
+
expect(File).to receive(:chown).with(2342, nil, '/tmp/different_file.txt')
|
131
137
|
@fac.set_owner
|
132
|
-
@fac.
|
138
|
+
expect(@fac).to be_modified
|
133
139
|
end
|
134
140
|
|
135
141
|
it "doesn't set the file's owner if it already matches" do
|
136
142
|
@resource.owner(2342)
|
137
143
|
@current_resource.owner(2342)
|
138
|
-
File.
|
144
|
+
expect(File).not_to receive(:chown)
|
139
145
|
@fac.set_owner
|
140
|
-
@fac.
|
146
|
+
expect(@fac).not_to be_modified
|
141
147
|
end
|
142
148
|
|
143
149
|
it "doesn't want to update a file's owner when it's already correct" do
|
144
150
|
@resource.owner(2342)
|
145
151
|
@current_resource.owner(2342)
|
146
|
-
@fac.should_update_owner
|
152
|
+
expect(@fac.should_update_owner?).to be_falsey
|
147
153
|
end
|
148
154
|
|
149
155
|
it "determines the gid of the group specified by the resource" do
|
150
|
-
Etc.
|
151
|
-
@fac.target_gid.
|
156
|
+
expect(Etc).to receive(:getgrnam).with('wheel').and_return(OpenStruct.new(:gid => 2342))
|
157
|
+
expect(@fac.target_gid).to eq(2342)
|
152
158
|
end
|
153
159
|
|
154
160
|
it "uses a user specified gid as the gid" do
|
155
161
|
@resource.group(2342)
|
156
|
-
@fac.target_gid.
|
162
|
+
expect(@fac.target_gid).to eq(2342)
|
157
163
|
end
|
158
164
|
|
159
165
|
it "raises a Chef::Exceptions::GroupIDNotFound error when Etc can't find the user's name" do
|
160
|
-
Etc.
|
161
|
-
|
166
|
+
expect(Etc).to receive(:getgrnam).with('wheel').and_raise(ArgumentError)
|
167
|
+
expect { @fac.target_gid; @provider_requirements.run(:create) }.to raise_error(Chef::Exceptions::GroupIDNotFound, "cannot determine group id for 'wheel', does the group exist on this system?")
|
162
168
|
end
|
163
169
|
|
164
170
|
it "does not attempt to resolve a gid when none is supplied" do
|
165
171
|
resource = Chef::Resource::File.new('crab')
|
166
172
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
167
|
-
fac.target_gid.
|
173
|
+
expect(fac.target_gid).to be_nil
|
168
174
|
end
|
169
175
|
|
170
176
|
it "does not want to update the group when no target group is specified" do
|
171
177
|
resource = Chef::Resource::File.new('crab')
|
172
178
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
173
|
-
fac.should_update_group
|
179
|
+
expect(fac.should_update_group?).to be_falsey
|
174
180
|
end
|
175
181
|
|
176
182
|
it "raises an error when the supplied group name is an alien" do
|
177
183
|
@resource.instance_variable_set(:@group, :failburger)
|
178
|
-
|
184
|
+
expect { @fac.target_gid; @provider_requirements.run(:create) }.to raise_error(ArgumentError)
|
179
185
|
end
|
180
186
|
|
181
187
|
it "wants to update the group when the current group is nil (creating a file)" do
|
182
188
|
@resource.group(2342)
|
183
189
|
@current_resource.group(nil)
|
184
|
-
@fac.should_update_group
|
190
|
+
expect(@fac.should_update_group?).to be_truthy
|
185
191
|
end
|
186
192
|
|
187
193
|
it "wants to update the group when the current group doesn't match the target group" do
|
188
194
|
@resource.group(2342)
|
189
195
|
@current_resource.group(815)
|
190
|
-
@fac.should_update_group
|
196
|
+
expect(@fac.should_update_group?).to be_truthy
|
191
197
|
end
|
192
198
|
|
193
199
|
it "includes updating the group in the list of changes" do
|
@@ -195,22 +201,22 @@ describe Chef::FileAccessControl do
|
|
195
201
|
resource.group(2342)
|
196
202
|
@current_resource.group(815)
|
197
203
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
198
|
-
fac.describe_changes.
|
204
|
+
expect(fac.describe_changes).to eq(["change group from '815' to '2342'"])
|
199
205
|
end
|
200
206
|
|
201
207
|
it "sets the file's group as specified in the resource when the group is not correct" do
|
202
208
|
@resource.group(2342)
|
203
209
|
@current_resource.group(815)
|
204
210
|
|
205
|
-
File.
|
211
|
+
expect(File).to receive(:chown).with(nil, 2342, '/tmp/different_file.txt')
|
206
212
|
@fac.set_group
|
207
|
-
@fac.
|
213
|
+
expect(@fac).to be_modified
|
208
214
|
end
|
209
215
|
|
210
216
|
it "doesn't want to modify the file's group when the current group is correct" do
|
211
217
|
@resource.group(2342)
|
212
218
|
@current_resource.group(2342)
|
213
|
-
@fac.should_update_group
|
219
|
+
expect(@fac.should_update_group?).to be_falsey
|
214
220
|
end
|
215
221
|
|
216
222
|
it "doesnt set the file's group if it is already correct" do
|
@@ -218,43 +224,43 @@ describe Chef::FileAccessControl do
|
|
218
224
|
@current_resource.group(2342)
|
219
225
|
|
220
226
|
# @fac.stub(:stat).and_return(OpenStruct.new(:gid => 2342))
|
221
|
-
File.
|
227
|
+
expect(File).not_to receive(:chown)
|
222
228
|
@fac.set_group
|
223
|
-
@fac.
|
229
|
+
expect(@fac).not_to be_modified
|
224
230
|
end
|
225
231
|
|
226
232
|
it "uses the supplied mode as octal when it's a string" do
|
227
233
|
@resource.mode('444')
|
228
|
-
@fac.target_mode.
|
234
|
+
expect(@fac.target_mode).to eq(292) # octal 444 => decimal 292
|
229
235
|
end
|
230
236
|
|
231
237
|
it "uses the supplied mode verbatim when it's an integer" do
|
232
238
|
@resource.mode(00444)
|
233
|
-
@fac.target_mode.
|
239
|
+
expect(@fac.target_mode).to eq(292)
|
234
240
|
end
|
235
241
|
|
236
242
|
it "does not try to determine the mode when none is given" do
|
237
243
|
resource = Chef::Resource::File.new('blahblah')
|
238
244
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
239
|
-
fac.target_mode.
|
245
|
+
expect(fac.target_mode).to be_nil
|
240
246
|
end
|
241
247
|
|
242
248
|
it "doesn't want to update the mode when no target mode is given" do
|
243
249
|
resource = Chef::Resource::File.new('blahblah')
|
244
250
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
245
|
-
fac.should_update_mode
|
251
|
+
expect(fac.should_update_mode?).to be_falsey
|
246
252
|
end
|
247
253
|
|
248
254
|
it "wants to update the mode when the current mode is nil (creating a file)" do
|
249
255
|
@resource.mode("0400")
|
250
256
|
@current_resource.mode(nil)
|
251
|
-
@fac.should_update_mode
|
257
|
+
expect(@fac.should_update_mode?).to be_truthy
|
252
258
|
end
|
253
259
|
|
254
260
|
it "wants to update the mode when the desired mode does not match the current mode" do
|
255
261
|
@resource.mode("0400")
|
256
262
|
@current_resource.mode("0644")
|
257
|
-
@fac.should_update_mode
|
263
|
+
expect(@fac.should_update_mode?).to be_truthy
|
258
264
|
end
|
259
265
|
|
260
266
|
it "includes changing the mode in the list of desired changes" do
|
@@ -262,41 +268,41 @@ describe Chef::FileAccessControl do
|
|
262
268
|
resource.mode("0750")
|
263
269
|
@current_resource.mode("0444")
|
264
270
|
fac = Chef::FileAccessControl.new(@current_resource, resource, @provider)
|
265
|
-
fac.describe_changes.
|
271
|
+
expect(fac.describe_changes).to eq(["change mode from '0444' to '0750'"])
|
266
272
|
end
|
267
273
|
|
268
274
|
it "sets the file's mode as specified in the resource when the current modes are incorrect" do
|
269
275
|
# stat returns modes like 0100644 (octal) => 33188 (decimal)
|
270
276
|
#@fac.stub(:stat).and_return(OpenStruct.new(:mode => 33188))
|
271
277
|
@current_resource.mode("0644")
|
272
|
-
File.
|
278
|
+
expect(File).to receive(:chmod).with(256, '/tmp/different_file.txt')
|
273
279
|
@fac.set_mode
|
274
|
-
@fac.
|
280
|
+
expect(@fac).to be_modified
|
275
281
|
end
|
276
282
|
|
277
283
|
it "does not want to update the mode when the current mode is correct" do
|
278
284
|
@current_resource.mode("0400")
|
279
|
-
@fac.should_update_mode
|
285
|
+
expect(@fac.should_update_mode?).to be_falsey
|
280
286
|
end
|
281
287
|
|
282
288
|
it "does not set the file's mode when the current modes are correct" do
|
283
289
|
#@fac.stub(:stat).and_return(OpenStruct.new(:mode => 0100400))
|
284
290
|
@current_resource.mode("0400")
|
285
|
-
File.
|
291
|
+
expect(File).not_to receive(:chmod)
|
286
292
|
@fac.set_mode
|
287
|
-
@fac.
|
293
|
+
expect(@fac).not_to be_modified
|
288
294
|
end
|
289
295
|
|
290
296
|
it "sets all access controls on a file" do
|
291
|
-
@fac.
|
297
|
+
allow(@fac).to receive(:stat).and_return(OpenStruct.new(:owner => 99, :group => 99, :mode => 0100444))
|
292
298
|
@resource.mode(0400)
|
293
299
|
@resource.owner(0)
|
294
300
|
@resource.group(0)
|
295
|
-
File.
|
296
|
-
File.
|
297
|
-
File.
|
301
|
+
expect(File).to receive(:chmod).with(0400, '/tmp/different_file.txt')
|
302
|
+
expect(File).to receive(:chown).with(0, nil, '/tmp/different_file.txt')
|
303
|
+
expect(File).to receive(:chown).with(nil, 0, '/tmp/different_file.txt')
|
298
304
|
@fac.set_all
|
299
|
-
@fac.
|
305
|
+
expect(@fac).to be_modified
|
300
306
|
end
|
301
307
|
end
|
302
308
|
end
|
@@ -32,11 +32,11 @@ describe Chef::FileCache do
|
|
32
32
|
describe "when the relative path to the cache file doesn't exist" do
|
33
33
|
it "creates intermediate directories as needed" do
|
34
34
|
Chef::FileCache.store("whiz/bang", "I found a poop")
|
35
|
-
File.
|
35
|
+
expect(File).to exist(File.join(@file_cache_path, 'whiz'))
|
36
36
|
end
|
37
37
|
|
38
38
|
it "creates the cached file at the correct relative path" do
|
39
|
-
File.
|
39
|
+
expect(File).to receive(:open).with(File.join(@file_cache_path, 'whiz', 'bang'), "w",416).and_yield(@io)
|
40
40
|
Chef::FileCache.store("whiz/bang", "borkborkbork")
|
41
41
|
end
|
42
42
|
|
@@ -44,12 +44,12 @@ describe Chef::FileCache do
|
|
44
44
|
|
45
45
|
describe "when storing a file" do
|
46
46
|
before do
|
47
|
-
File.
|
47
|
+
allow(File).to receive(:open).and_yield(@io)
|
48
48
|
end
|
49
49
|
|
50
50
|
it "should print the contents to the file" do
|
51
51
|
Chef::FileCache.store("whiz/bang", "borkborkbork")
|
52
|
-
@io.string.
|
52
|
+
expect(@io.string).to eq("borkborkbork")
|
53
53
|
end
|
54
54
|
|
55
55
|
end
|
@@ -58,11 +58,11 @@ describe Chef::FileCache do
|
|
58
58
|
it "finds and reads the cached file" do
|
59
59
|
FileUtils.mkdir_p(File.join(@file_cache_path, 'whiz'))
|
60
60
|
File.open(File.join(@file_cache_path, 'whiz', 'bang'), 'w') { |f| f.print("borkborkbork") }
|
61
|
-
Chef::FileCache.load('whiz/bang').
|
61
|
+
expect(Chef::FileCache.load('whiz/bang')).to eq('borkborkbork')
|
62
62
|
end
|
63
63
|
|
64
64
|
it "should raise a Chef::Exceptions::FileNotFound if the file doesn't exist" do
|
65
|
-
|
65
|
+
expect { Chef::FileCache.load('whiz/bang') }.to raise_error(Chef::Exceptions::FileNotFound)
|
66
66
|
end
|
67
67
|
end
|
68
68
|
|
@@ -74,7 +74,7 @@ describe Chef::FileCache do
|
|
74
74
|
|
75
75
|
it "unlinks the file" do
|
76
76
|
Chef::FileCache.delete("whiz/bang")
|
77
|
-
File.
|
77
|
+
expect(File).not_to exist(File.join(@file_cache_path, 'whiz', 'bang'))
|
78
78
|
end
|
79
79
|
|
80
80
|
end
|
@@ -88,11 +88,11 @@ describe Chef::FileCache do
|
|
88
88
|
end
|
89
89
|
|
90
90
|
it "should return the relative paths" do
|
91
|
-
Chef::FileCache.list.sort.
|
91
|
+
expect(Chef::FileCache.list.sort).to eq(%w{snappy/patter whiz/bang})
|
92
92
|
end
|
93
93
|
|
94
94
|
it "searches for cached files by globbing" do
|
95
|
-
Chef::FileCache.find('snappy/**/*').
|
95
|
+
expect(Chef::FileCache.find('snappy/**/*')).to eq(%w{snappy/patter})
|
96
96
|
end
|
97
97
|
|
98
98
|
end
|
@@ -104,11 +104,11 @@ describe Chef::FileCache do
|
|
104
104
|
|
105
105
|
it "has a key if the corresponding cache file exists" do
|
106
106
|
FileUtils.touch(File.join(@file_cache_path, 'whiz', 'bang'))
|
107
|
-
Chef::FileCache.
|
107
|
+
expect(Chef::FileCache).to have_key("whiz/bang")
|
108
108
|
end
|
109
109
|
|
110
110
|
it "doesn't have a key if the corresponding cache file doesn't exist" do
|
111
|
-
Chef::FileCache.
|
111
|
+
expect(Chef::FileCache).not_to have_key("whiz/bang")
|
112
112
|
end
|
113
113
|
end
|
114
114
|
end
|