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,7 +131,7 @@ module ChefHTTPShared
|
|
131
131
|
}
|
132
132
|
|
133
133
|
#
|
134
|
-
# in the
|
134
|
+
# in the presence of a transfer-encoding header, we must ignore the content-length (this bad content-length should work)
|
135
135
|
#
|
136
136
|
|
137
137
|
# (expected_content should be uncompressed)
|
@@ -163,8 +163,8 @@ shared_examples_for "a securable resource with existing target" do
|
|
163
163
|
let(:desired_gid) { 1337 }
|
164
164
|
let(:expected_gid) { 1337 }
|
165
165
|
|
166
|
-
|
167
|
-
|
166
|
+
skip "should set an owner (Rerun specs under root)", :requires_unprivileged_user => true
|
167
|
+
skip "should set a group (Rerun specs under root)", :requires_unprivileged_user => true
|
168
168
|
|
169
169
|
describe "when setting the owner", :requires_root do
|
170
170
|
before do
|
@@ -173,11 +173,11 @@ shared_examples_for "a securable resource with existing target" do
|
|
173
173
|
end
|
174
174
|
|
175
175
|
it "should set an owner" do
|
176
|
-
File.lstat(path).uid.
|
176
|
+
expect(File.lstat(path).uid).to eq(expected_uid)
|
177
177
|
end
|
178
178
|
|
179
179
|
it "is marked as updated only if changes are made" do
|
180
|
-
resource.updated_by_last_action
|
180
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
181
181
|
end
|
182
182
|
|
183
183
|
end
|
@@ -189,11 +189,11 @@ shared_examples_for "a securable resource with existing target" do
|
|
189
189
|
end
|
190
190
|
|
191
191
|
it "should set a group" do
|
192
|
-
File.lstat(path).gid.
|
192
|
+
expect(File.lstat(path).gid).to eq(expected_gid)
|
193
193
|
end
|
194
194
|
|
195
195
|
it "is marked as updated only if changes are made" do
|
196
|
-
resource.updated_by_last_action
|
196
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
197
197
|
end
|
198
198
|
|
199
199
|
end
|
@@ -206,13 +206,12 @@ shared_examples_for "a securable resource with existing target" do
|
|
206
206
|
end
|
207
207
|
|
208
208
|
it "should set permissions as specified" do
|
209
|
-
pending(
|
210
|
-
|
211
|
-
end
|
209
|
+
pending("Linux does not support lchmod")
|
210
|
+
expect{ File.lstat(path).mode & 007777 }.to eq(@mode_string.oct & 007777)
|
212
211
|
end
|
213
212
|
|
214
213
|
it "is marked as updated only if changes are made" do
|
215
|
-
resource.updated_by_last_action
|
214
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
216
215
|
end
|
217
216
|
end
|
218
217
|
|
@@ -224,13 +223,12 @@ shared_examples_for "a securable resource with existing target" do
|
|
224
223
|
end
|
225
224
|
|
226
225
|
it "should set permissions in numeric form as a ruby-interpreted octal" do
|
227
|
-
pending('Linux does not support lchmod'
|
228
|
-
|
229
|
-
end
|
226
|
+
pending('Linux does not support lchmod')
|
227
|
+
expect{ File.lstat(path).mode & 007777 }.to eq(@mode_integer & 007777)
|
230
228
|
end
|
231
229
|
|
232
230
|
it "is marked as updated only if changes are made" do
|
233
|
-
resource.updated_by_last_action
|
231
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
234
232
|
end
|
235
233
|
end
|
236
234
|
end
|
@@ -245,11 +243,11 @@ shared_examples_for "a securable resource with existing target" do
|
|
245
243
|
end
|
246
244
|
|
247
245
|
it "should set the owner" do
|
248
|
-
descriptor.owner.
|
246
|
+
expect(descriptor.owner).to eq(SID.Administrator)
|
249
247
|
end
|
250
248
|
|
251
249
|
it "is marked as updated only if changes are made" do
|
252
|
-
resource.updated_by_last_action
|
250
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
253
251
|
end
|
254
252
|
end
|
255
253
|
|
@@ -260,11 +258,11 @@ shared_examples_for "a securable resource with existing target" do
|
|
260
258
|
end
|
261
259
|
|
262
260
|
it "should set the group" do
|
263
|
-
descriptor.group.
|
261
|
+
expect(descriptor.group).to eq(SID.Administrators)
|
264
262
|
end
|
265
263
|
|
266
264
|
it "is marked as updated only if changes are made" do
|
267
|
-
resource.updated_by_last_action
|
265
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
268
266
|
end
|
269
267
|
end
|
270
268
|
|
@@ -276,11 +274,11 @@ shared_examples_for "a securable resource with existing target" do
|
|
276
274
|
end
|
277
275
|
|
278
276
|
it "should set the rights and deny_rights" do
|
279
|
-
explicit_aces.
|
277
|
+
expect(explicit_aces).to eq(denied_acl(SID.Guest, expected_modify_perms) + allowed_acl(SID.Guest, expected_read_perms))
|
280
278
|
end
|
281
279
|
|
282
280
|
it "is marked as updated only if changes are made" do
|
283
|
-
resource.updated_by_last_action
|
281
|
+
expect(resource.updated_by_last_action?).to eq(expect_updated?)
|
284
282
|
end
|
285
283
|
end
|
286
284
|
end
|
@@ -291,81 +289,80 @@ shared_examples_for "a securable resource without existing target" do
|
|
291
289
|
include_context "diff disabled"
|
292
290
|
|
293
291
|
context "on Unix", :unix_only do
|
294
|
-
|
292
|
+
skip "if we need any securable resource tests on Unix without existing target resource."
|
295
293
|
end
|
296
294
|
|
297
295
|
context "on Windows", :windows_only do
|
298
296
|
include_context "use Windows permissions"
|
299
297
|
|
300
298
|
it "sets owner to Administrators on create if owner is not specified" do
|
301
|
-
File.exist?(path).
|
299
|
+
expect(File.exist?(path)).to eq(false)
|
302
300
|
resource.run_action(:create)
|
303
|
-
descriptor.owner.
|
301
|
+
expect(descriptor.owner).to eq(SID.Administrators)
|
304
302
|
end
|
305
303
|
|
306
304
|
it "sets owner when owner is specified" do
|
307
305
|
resource.owner 'Guest'
|
308
306
|
resource.run_action(:create)
|
309
|
-
descriptor.owner.
|
307
|
+
expect(descriptor.owner).to eq(SID.Guest)
|
310
308
|
end
|
311
309
|
|
312
310
|
it "fails to set owner when owner has invalid characters" do
|
313
|
-
|
311
|
+
expect { resource.owner 'Lance "The Nose" Glindenberry III' }.to raise_error#(Chef::Exceptions::ValidationFailed)
|
314
312
|
end
|
315
313
|
|
316
314
|
it "sets owner when owner is specified with a \\" do
|
317
315
|
resource.owner "#{ENV['USERDOMAIN']}\\Guest"
|
318
316
|
resource.run_action(:create)
|
319
|
-
descriptor.owner.
|
317
|
+
expect(descriptor.owner).to eq(SID.Guest)
|
320
318
|
end
|
321
319
|
|
322
320
|
it "leaves owner alone if owner is not specified and resource already exists" do
|
323
321
|
# Set owner to Guest so it's not the same as the current user (which is the default on create)
|
324
322
|
resource.owner 'Guest'
|
325
323
|
resource.run_action(:create)
|
326
|
-
descriptor.owner.
|
324
|
+
expect(descriptor.owner).to eq(SID.Guest)
|
327
325
|
|
328
326
|
new_resource = create_resource
|
329
|
-
new_resource.owner.
|
327
|
+
expect(new_resource.owner).to eq(nil)
|
330
328
|
new_resource.run_action(:create)
|
331
|
-
descriptor.owner.
|
329
|
+
expect(descriptor.owner).to eq(SID.Guest)
|
332
330
|
end
|
333
331
|
|
334
332
|
it "sets group to None on create if group is not specified" do
|
335
|
-
resource.group.
|
336
|
-
File.exist?(path).
|
333
|
+
expect(resource.group).to eq(nil)
|
334
|
+
expect(File.exist?(path)).to eq(false)
|
337
335
|
resource.run_action(:create)
|
338
|
-
descriptor.group.
|
336
|
+
expect(descriptor.group).to eq(SID.None)
|
339
337
|
end
|
340
338
|
|
341
339
|
it "sets group when group is specified" do
|
342
340
|
resource.group 'Everyone'
|
343
341
|
resource.run_action(:create)
|
344
|
-
descriptor.group.
|
342
|
+
expect(descriptor.group).to eq(SID.Everyone)
|
345
343
|
end
|
346
344
|
|
347
345
|
it "fails to set group when group has invalid characters" do
|
348
|
-
|
346
|
+
expect { resource.group 'Lance "The Nose" Glindenberry III' }.to raise_error(Chef::Exceptions::ValidationFailed)
|
349
347
|
end
|
350
348
|
|
351
349
|
it "sets group when group is specified with a \\" do
|
352
|
-
pending
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
end
|
350
|
+
pending("Need to find a group containing a backslash that is on most peoples' machines")
|
351
|
+
resource.group "#{ENV['COMPUTERNAME']}\\Administrators"
|
352
|
+
resource.run_action(:create)
|
353
|
+
expect{ descriptor.group }.to eq(SID.Everyone)
|
357
354
|
end
|
358
355
|
|
359
356
|
it "leaves group alone if group is not specified and resource already exists" do
|
360
357
|
# Set group to Everyone so it's not the default (None)
|
361
358
|
resource.group 'Everyone'
|
362
359
|
resource.run_action(:create)
|
363
|
-
descriptor.group.
|
360
|
+
expect(descriptor.group).to eq(SID.Everyone)
|
364
361
|
|
365
362
|
new_resource = create_resource
|
366
|
-
new_resource.group.
|
363
|
+
expect(new_resource.group).to eq(nil)
|
367
364
|
new_resource.run_action(:create)
|
368
|
-
descriptor.group.
|
365
|
+
expect(descriptor.group).to eq(SID.Everyone)
|
369
366
|
end
|
370
367
|
|
371
368
|
describe "with rights and deny_rights attributes" do
|
@@ -373,38 +370,38 @@ shared_examples_for "a securable resource without existing target" do
|
|
373
370
|
it "correctly sets :read rights" do
|
374
371
|
resource.rights(:read, 'Guest')
|
375
372
|
resource.run_action(:create)
|
376
|
-
explicit_aces.
|
373
|
+
expect(explicit_aces).to eq(allowed_acl(SID.Guest, expected_read_perms))
|
377
374
|
end
|
378
375
|
|
379
376
|
it "correctly sets :read_execute rights" do
|
380
377
|
resource.rights(:read_execute, 'Guest')
|
381
378
|
resource.run_action(:create)
|
382
|
-
explicit_aces.
|
379
|
+
expect(explicit_aces).to eq(allowed_acl(SID.Guest, expected_read_execute_perms))
|
383
380
|
end
|
384
381
|
|
385
382
|
it "correctly sets :write rights" do
|
386
383
|
resource.rights(:write, 'Guest')
|
387
384
|
resource.run_action(:create)
|
388
|
-
explicit_aces.
|
385
|
+
expect(explicit_aces).to eq(allowed_acl(SID.Guest, expected_write_perms))
|
389
386
|
end
|
390
387
|
|
391
388
|
it "correctly sets :modify rights" do
|
392
389
|
resource.rights(:modify, 'Guest')
|
393
390
|
resource.run_action(:create)
|
394
|
-
explicit_aces.
|
391
|
+
expect(explicit_aces).to eq(allowed_acl(SID.Guest, expected_modify_perms))
|
395
392
|
end
|
396
393
|
|
397
394
|
it "correctly sets :full_control rights" do
|
398
395
|
resource.rights(:full_control, 'Guest')
|
399
396
|
resource.run_action(:create)
|
400
|
-
explicit_aces.
|
397
|
+
expect(explicit_aces).to eq(allowed_acl(SID.Guest, expected_full_control_perms))
|
401
398
|
end
|
402
399
|
|
403
400
|
it "correctly sets deny_rights" do
|
404
401
|
# deny is an ACE with full rights, but is a deny type ace, not an allow type
|
405
402
|
resource.deny_rights(:full_control, 'Guest')
|
406
403
|
resource.run_action(:create)
|
407
|
-
explicit_aces.
|
404
|
+
expect(explicit_aces).to eq(denied_acl(SID.Guest, expected_full_control_perms))
|
408
405
|
end
|
409
406
|
|
410
407
|
it "Sets multiple rights" do
|
@@ -412,9 +409,10 @@ shared_examples_for "a securable resource without existing target" do
|
|
412
409
|
resource.rights(:modify, 'Guest')
|
413
410
|
resource.run_action(:create)
|
414
411
|
|
415
|
-
explicit_aces.
|
412
|
+
expect(explicit_aces).to eq(
|
416
413
|
allowed_acl(SID.Everyone, expected_read_perms) +
|
417
414
|
allowed_acl(SID.Guest, expected_modify_perms)
|
415
|
+
)
|
418
416
|
end
|
419
417
|
|
420
418
|
it "Sets deny_rights ahead of rights" do
|
@@ -422,9 +420,10 @@ shared_examples_for "a securable resource without existing target" do
|
|
422
420
|
resource.deny_rights(:modify, 'Guest')
|
423
421
|
resource.run_action(:create)
|
424
422
|
|
425
|
-
explicit_aces.
|
423
|
+
expect(explicit_aces).to eq(
|
426
424
|
denied_acl(SID.Guest, expected_modify_perms) +
|
427
425
|
allowed_acl(SID.Everyone, expected_read_perms)
|
426
|
+
)
|
428
427
|
end
|
429
428
|
|
430
429
|
it "Sets deny_rights ahead of rights when specified in reverse order" do
|
@@ -432,9 +431,10 @@ shared_examples_for "a securable resource without existing target" do
|
|
432
431
|
resource.rights(:read, 'Everyone')
|
433
432
|
resource.run_action(:create)
|
434
433
|
|
435
|
-
explicit_aces.
|
434
|
+
expect(explicit_aces).to eq(
|
436
435
|
denied_acl(SID.Guest, expected_modify_perms) +
|
437
436
|
allowed_acl(SID.Everyone, expected_read_perms)
|
437
|
+
)
|
438
438
|
end
|
439
439
|
|
440
440
|
end
|
@@ -452,7 +452,7 @@ shared_examples_for "a securable resource without existing target" do
|
|
452
452
|
resource.group 'Everyone'
|
453
453
|
resource.run_action(:create)
|
454
454
|
|
455
|
-
explicit_aces.
|
455
|
+
expect(explicit_aces).to eq([ ACE.access_allowed(SID.Guest, Security::FILE_GENERIC_READ) ])
|
456
456
|
end
|
457
457
|
|
458
458
|
it "respects mode in numeric form as a ruby-interpreted octal" do
|
@@ -460,7 +460,7 @@ shared_examples_for "a securable resource without existing target" do
|
|
460
460
|
resource.owner 'Guest'
|
461
461
|
resource.run_action(:create)
|
462
462
|
|
463
|
-
explicit_aces.
|
463
|
+
expect(explicit_aces).to eq([ ACE.access_allowed(SID.Guest, Security::FILE_GENERIC_READ | Security::FILE_GENERIC_WRITE | Security::FILE_GENERIC_EXECUTE | Security::DELETE) ])
|
464
464
|
end
|
465
465
|
|
466
466
|
it "respects the owner, group and everyone bits of mode" do
|
@@ -469,11 +469,11 @@ shared_examples_for "a securable resource without existing target" do
|
|
469
469
|
resource.group 'Administrators'
|
470
470
|
resource.run_action(:create)
|
471
471
|
|
472
|
-
explicit_aces.
|
472
|
+
expect(explicit_aces).to eq([
|
473
473
|
ACE.access_allowed(SID.Guest, Security::FILE_GENERIC_READ | Security::FILE_GENERIC_WRITE | Security::FILE_GENERIC_EXECUTE | Security::DELETE),
|
474
474
|
ACE.access_allowed(SID.Administrators, Security::FILE_GENERIC_READ | Security::FILE_GENERIC_EXECUTE),
|
475
475
|
ACE.access_allowed(SID.Everyone, Security::FILE_GENERIC_READ)
|
476
|
-
]
|
476
|
+
])
|
477
477
|
end
|
478
478
|
|
479
479
|
it "respects the individual read, write and execute bits of mode" do
|
@@ -482,31 +482,31 @@ shared_examples_for "a securable resource without existing target" do
|
|
482
482
|
resource.group 'Administrators'
|
483
483
|
resource.run_action(:create)
|
484
484
|
|
485
|
-
explicit_aces.
|
485
|
+
expect(explicit_aces).to eq([
|
486
486
|
ACE.access_allowed(SID.Guest, Security::FILE_GENERIC_READ),
|
487
487
|
ACE.access_allowed(SID.Administrators, Security::FILE_GENERIC_WRITE | Security::DELETE),
|
488
488
|
ACE.access_allowed(SID.Everyone, Security::FILE_GENERIC_EXECUTE)
|
489
|
-
]
|
489
|
+
])
|
490
490
|
end
|
491
491
|
|
492
492
|
it 'warns when mode tries to set owner bits but owner is not specified' do
|
493
493
|
@warn = []
|
494
|
-
Chef::Log.
|
494
|
+
allow(Chef::Log).to receive(:warn) { |msg| @warn << msg }
|
495
495
|
|
496
496
|
resource.mode 0400
|
497
497
|
resource.run_action(:create)
|
498
498
|
|
499
|
-
@warn.include?("Mode 400 includes bits for the owner, but owner is not specified").
|
499
|
+
expect(@warn.include?("Mode 400 includes bits for the owner, but owner is not specified")).to be_truthy
|
500
500
|
end
|
501
501
|
|
502
502
|
it 'warns when mode tries to set group bits but group is not specified' do
|
503
503
|
@warn = []
|
504
|
-
Chef::Log.
|
504
|
+
allow(Chef::Log).to receive(:warn) { |msg| @warn << msg }
|
505
505
|
|
506
506
|
resource.mode 0040
|
507
507
|
resource.run_action(:create)
|
508
508
|
|
509
|
-
@warn.include?("Mode 040 includes bits for the group, but group is not specified").
|
509
|
+
expect(@warn.include?("Mode 040 includes bits for the group, but group is not specified")).to be_truthy
|
510
510
|
end
|
511
511
|
end
|
512
512
|
|
@@ -518,12 +518,12 @@ shared_examples_for "a securable resource without existing target" do
|
|
518
518
|
resource.run_action(:create)
|
519
519
|
|
520
520
|
descriptor.dacl.each do | ace |
|
521
|
-
ace.inherited
|
521
|
+
expect(ace.inherited?).to eq(false)
|
522
522
|
end
|
523
523
|
end
|
524
524
|
|
525
525
|
it "has the inheritable acls of parent directory if no acl is specified" do
|
526
|
-
File.exist?(path).
|
526
|
+
expect(File.exist?(path)).to eq(false)
|
527
527
|
|
528
528
|
# Collect the inheritable acls form the parent by creating a file without
|
529
529
|
# any specific ACLs
|
@@ -542,7 +542,7 @@ shared_examples_for "a securable resource without existing target" do
|
|
542
542
|
ace.inherited?
|
543
543
|
end
|
544
544
|
|
545
|
-
resource_inherited_acls.
|
545
|
+
expect(resource_inherited_acls).to eq(parent_inherited_acls)
|
546
546
|
end
|
547
547
|
|
548
548
|
end
|
@@ -56,18 +56,18 @@ shared_examples_for "a securable resource with reporting" do
|
|
56
56
|
end
|
57
57
|
|
58
58
|
it "has empty values for file metadata in 'current_resource'" do
|
59
|
-
current_resource.owner.
|
60
|
-
current_resource.group.
|
61
|
-
current_resource.mode.
|
59
|
+
expect(current_resource.owner).to be_nil
|
60
|
+
expect(current_resource.group).to be_nil
|
61
|
+
expect(current_resource.mode).to be_nil
|
62
62
|
end
|
63
63
|
|
64
64
|
context "and no security metadata is specified in new_resource" do
|
65
65
|
it "sets the metadata values on the new_resource as strings after creating" do
|
66
66
|
resource.run_action(:create)
|
67
67
|
# TODO: most stable way to specify?
|
68
|
-
resource.owner.
|
69
|
-
resource.group.
|
70
|
-
resource.mode.
|
68
|
+
expect(resource.owner).to eq(Etc.getpwuid(Process.uid).name)
|
69
|
+
expect(resource.group).to eq(@expected_group_name)
|
70
|
+
expect(resource.mode).to eq("0#{default_mode}")
|
71
71
|
end
|
72
72
|
end
|
73
73
|
|
@@ -87,7 +87,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
87
87
|
end
|
88
88
|
|
89
89
|
it "sets the owner on new_resource to the username (String) of the desired owner" do
|
90
|
-
resource.owner.
|
90
|
+
expect(resource.owner).to eq(expected_user_name)
|
91
91
|
end
|
92
92
|
|
93
93
|
end
|
@@ -110,7 +110,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
110
110
|
end
|
111
111
|
|
112
112
|
it "sets the owner on new_resource to the uid (Integer) of the desired owner" do
|
113
|
-
resource.owner.
|
113
|
+
expect(resource.owner).to eq(expected_uid)
|
114
114
|
end
|
115
115
|
end
|
116
116
|
|
@@ -124,7 +124,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
124
124
|
end
|
125
125
|
|
126
126
|
it "sets the group on new_resource to the group name (String) of the group" do
|
127
|
-
resource.group.
|
127
|
+
expect(resource.group).to eq(expected_group_name)
|
128
128
|
end
|
129
129
|
|
130
130
|
end
|
@@ -138,7 +138,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
138
138
|
end
|
139
139
|
|
140
140
|
it "sets the group on new_resource to the gid (Integer)" do
|
141
|
-
resource.group.
|
141
|
+
expect(resource.group).to eq(expected_gid)
|
142
142
|
end
|
143
143
|
|
144
144
|
end
|
@@ -155,7 +155,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
155
155
|
end
|
156
156
|
|
157
157
|
it "sets mode on the new_resource as a String" do
|
158
|
-
resource.mode.
|
158
|
+
expect(resource.mode).to eq(expected_mode)
|
159
159
|
end
|
160
160
|
end
|
161
161
|
|
@@ -169,7 +169,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
169
169
|
end
|
170
170
|
|
171
171
|
it "sets mode on the new resource as a String" do
|
172
|
-
resource.mode.
|
172
|
+
expect(resource.mode).to eq(expected_mode)
|
173
173
|
end
|
174
174
|
end
|
175
175
|
end
|
@@ -183,9 +183,9 @@ shared_examples_for "a securable resource with reporting" do
|
|
183
183
|
context "and no security metadata is specified in new_resource" do
|
184
184
|
it "sets the current values on current resource as strings" do
|
185
185
|
# TODO: most stable way to specify?
|
186
|
-
current_resource.owner.
|
187
|
-
current_resource.group.
|
188
|
-
current_resource.mode.
|
186
|
+
expect(current_resource.owner).to eq(Etc.getpwuid(Process.uid).name)
|
187
|
+
expect(current_resource.group).to eq(@expected_group_name)
|
188
|
+
expect(current_resource.mode).to eq("0#{((0100666 - File.umask) & 07777).to_s(8)}")
|
189
189
|
end
|
190
190
|
end
|
191
191
|
|
@@ -198,7 +198,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
198
198
|
end
|
199
199
|
|
200
200
|
it "sets the owner on new_resource to the username (String) of the desired owner" do
|
201
|
-
current_resource.owner.
|
201
|
+
expect(current_resource.owner).to eq(expected_user_name)
|
202
202
|
end
|
203
203
|
|
204
204
|
end
|
@@ -212,7 +212,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
212
212
|
end
|
213
213
|
|
214
214
|
it "sets the owner on new_resource to the uid (Integer) of the desired owner" do
|
215
|
-
current_resource.owner.
|
215
|
+
expect(current_resource.owner).to eq(expected_uid)
|
216
216
|
end
|
217
217
|
end
|
218
218
|
|
@@ -222,7 +222,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
222
222
|
end
|
223
223
|
|
224
224
|
it "sets the group on new_resource to the group name (String) of the group" do
|
225
|
-
current_resource.group.
|
225
|
+
expect(current_resource.group).to eq(@expected_group_name)
|
226
226
|
end
|
227
227
|
|
228
228
|
end
|
@@ -233,7 +233,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
233
233
|
end
|
234
234
|
|
235
235
|
it "sets the group on new_resource to the gid (Integer)" do
|
236
|
-
current_resource.group.
|
236
|
+
expect(current_resource.group).to eq(@expected_gid)
|
237
237
|
end
|
238
238
|
|
239
239
|
end
|
@@ -247,7 +247,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
247
247
|
end
|
248
248
|
|
249
249
|
it "sets mode on the new_resource as a String" do
|
250
|
-
current_resource.mode.
|
250
|
+
expect(current_resource.mode).to eq(expected_mode)
|
251
251
|
end
|
252
252
|
end
|
253
253
|
|
@@ -260,7 +260,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
260
260
|
end
|
261
261
|
|
262
262
|
it "sets mode on the new resource as a String" do
|
263
|
-
current_resource.mode.
|
263
|
+
expect(current_resource.mode).to eq(expected_mode)
|
264
264
|
end
|
265
265
|
end
|
266
266
|
end
|
@@ -268,11 +268,6 @@ shared_examples_for "a securable resource with reporting" do
|
|
268
268
|
|
269
269
|
describe "reading file security metadata for reporting on windows", :windows_only do
|
270
270
|
|
271
|
-
before do
|
272
|
-
pending "windows reporting not yet fully supported"
|
273
|
-
end
|
274
|
-
|
275
|
-
|
276
271
|
context "when the target file doesn't exist" do
|
277
272
|
|
278
273
|
# Windows reporting data should look like this (+/- ish):
|
@@ -284,23 +279,28 @@ shared_examples_for "a securable resource with reporting" do
|
|
284
279
|
end
|
285
280
|
|
286
281
|
it "has empty values for file metadata in 'current_resource'" do
|
287
|
-
|
288
|
-
current_resource.
|
282
|
+
pending "windows reporting not yet fully supported"
|
283
|
+
expect(current_resource.owner).to be_nil
|
284
|
+
expect(current_resource.expanded_rights).to be_nil
|
289
285
|
end
|
290
286
|
|
291
287
|
context "and no security metadata is specified in new_resource" do
|
288
|
+
before do
|
289
|
+
pending "windows reporting not yet fully supported"
|
290
|
+
end
|
291
|
+
|
292
292
|
it "sets the metadata values on the new_resource as strings after creating" do
|
293
293
|
resource.run_action(:create)
|
294
294
|
# TODO: most stable way to specify?
|
295
|
-
resource.owner.
|
296
|
-
resource.state[:expanded_rights].
|
297
|
-
resource.state[:expanded_deny_rights].
|
298
|
-
resource.state[:inherits].
|
295
|
+
expect(resource.owner).to eq(etc.getpwuid(process.uid).name)
|
296
|
+
expect(resource.state[:expanded_rights]).to eq({ "CURRENTUSER" => { "permissions" => ALL_EXPANDED_PERMISSIONS, "flags" => [] }})
|
297
|
+
expect(resource.state[:expanded_deny_rights]).to eq({})
|
298
|
+
expect(resource.state[:inherits]).to be_truthy
|
299
299
|
end
|
300
300
|
end
|
301
301
|
|
302
302
|
|
303
|
-
context "and owner is specified with a string (username) in new_resource"
|
303
|
+
context "and owner is specified with a string (username) in new_resource" do
|
304
304
|
|
305
305
|
# TODO/bug: duplicated from the "securable resource" tests
|
306
306
|
let(:expected_user_name) { 'Guest' }
|
@@ -311,7 +311,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
311
311
|
end
|
312
312
|
|
313
313
|
it "sets the owner on new_resource to the username (string) of the desired owner" do
|
314
|
-
resource.owner.
|
314
|
+
expect(resource.owner).to eq(expected_user_name)
|
315
315
|
end
|
316
316
|
|
317
317
|
end
|
@@ -322,12 +322,13 @@ shared_examples_for "a securable resource with reporting" do
|
|
322
322
|
let(:expected_user_name) { 'domain\user' }
|
323
323
|
|
324
324
|
before do
|
325
|
+
pending "windows reporting not yet fully supported"
|
325
326
|
resource.owner(expected_user_name)
|
326
327
|
resource.run_action(:create)
|
327
328
|
end
|
328
329
|
|
329
330
|
it "sets the owner on new_resource to the fully qualified name of the desired owner" do
|
330
|
-
resource.owner.
|
331
|
+
expect(resource.owner).to eq(expected_user_name)
|
331
332
|
end
|
332
333
|
end
|
333
334
|
|
@@ -335,6 +336,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
335
336
|
|
336
337
|
context "when the target file exists" do
|
337
338
|
before do
|
339
|
+
pending "windows reporting not yet fully supported"
|
338
340
|
FileUtils.touch(resource.path)
|
339
341
|
resource.action(:create)
|
340
342
|
end
|
@@ -342,8 +344,8 @@ shared_examples_for "a securable resource with reporting" do
|
|
342
344
|
context "and no security metadata is specified in new_resource" do
|
343
345
|
it "sets the current values on current resource as strings" do
|
344
346
|
# TODO: most stable way to specify?
|
345
|
-
current_resource.owner.
|
346
|
-
current_resource.expanded_rights.
|
347
|
+
expect(current_resource.owner).to eq(etc.getpwuid(process.uid).name)
|
348
|
+
expect(current_resource.expanded_rights).to eq({ "CURRENTUSER" => ALL_EXPANDED_PERMISSIONS })
|
347
349
|
end
|
348
350
|
end
|
349
351
|
|
@@ -356,7 +358,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
356
358
|
end
|
357
359
|
|
358
360
|
it "sets the owner on current_resource to the username (string) of the desired owner" do
|
359
|
-
current_resource.owner.
|
361
|
+
expect(current_resource.owner).to eq(expected_user_name)
|
360
362
|
end
|
361
363
|
|
362
364
|
end
|
@@ -370,7 +372,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
370
372
|
end
|
371
373
|
|
372
374
|
it "sets the owner on current_resource to the fully qualified name of the desired owner" do
|
373
|
-
current_resource.owner.
|
375
|
+
expect(current_resource.owner).to eq(expected_uid)
|
374
376
|
end
|
375
377
|
end
|
376
378
|
|
@@ -378,7 +380,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
378
380
|
# TODO: before do blah
|
379
381
|
|
380
382
|
it "sets the expanded_rights on the current resource" do
|
381
|
-
|
383
|
+
skip
|
382
384
|
end
|
383
385
|
end
|
384
386
|
|
@@ -386,7 +388,7 @@ shared_examples_for "a securable resource with reporting" do
|
|
386
388
|
# TODO: before do blah
|
387
389
|
|
388
390
|
it "sets the expanded rights on the current resource" do
|
389
|
-
|
391
|
+
skip
|
390
392
|
end
|
391
393
|
end
|
392
394
|
|