chef 16.13.16-universal-mingw32 → 17.3.48-universal-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +11 -22
- data/README.md +1 -1
- data/Rakefile +2 -2
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +12 -24
- data/lib/chef/action_collection.rb +6 -26
- data/lib/chef/application.rb +1 -1
- data/lib/chef/application/base.rb +16 -1
- data/lib/chef/applications.rb +0 -1
- data/lib/chef/chef_fs/command_line.rb +5 -2
- data/lib/chef/chef_fs/file_pattern.rb +2 -2
- data/lib/chef/chef_fs/file_system.rb +9 -10
- data/lib/chef/client.rb +9 -3
- data/lib/chef/compliance/default_attributes.rb +5 -4
- data/lib/chef/compliance/fetcher/automate.rb +0 -7
- data/lib/chef/compliance/reporter/automate.rb +17 -7
- data/lib/chef/compliance/reporter/chef_server_automate.rb +11 -6
- data/lib/chef/compliance/reporter/cli.rb +77 -0
- data/lib/chef/compliance/reporter/compliance_enforcer.rb +4 -0
- data/lib/chef/compliance/reporter/json_file.rb +8 -1
- data/lib/chef/compliance/runner.rb +65 -27
- data/lib/chef/cookbook/cookbook_version_loader.rb +3 -3
- data/lib/chef/cookbook/gem_installer.rb +5 -1
- data/lib/chef/cookbook/synchronizer.rb +3 -5
- data/lib/chef/cookbook_loader.rb +2 -4
- data/lib/chef/cookbook_uploader.rb +0 -1
- data/lib/chef/cookbook_version.rb +26 -4
- data/lib/chef/data_bag_item.rb +11 -2
- data/lib/chef/data_collector.rb +0 -1
- data/lib/chef/data_collector/run_end_message.rb +1 -1
- data/lib/chef/delayed_evaluator.rb +4 -0
- data/lib/chef/deprecated.rb +18 -4
- data/lib/chef/dsl.rb +1 -0
- data/lib/chef/dsl/chef_vault.rb +6 -6
- data/lib/chef/dsl/declare_resource.rb +5 -10
- data/lib/chef/dsl/reboot_pending.rb +1 -2
- data/lib/chef/{knife/group_list.rb → dsl/render_helpers.rb} +18 -17
- data/lib/chef/dsl/secret.rb +64 -0
- data/lib/chef/dsl/toml.rb +116 -0
- data/lib/chef/dsl/universal.rb +5 -0
- data/lib/chef/event_dispatch/base.rb +2 -1
- data/lib/chef/exceptions.rb +25 -0
- data/lib/chef/formatters/doc.rb +2 -1
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +20 -22
- data/lib/chef/group.rb +75 -0
- data/lib/chef/handler.rb +46 -8
- data/lib/chef/handler/slow_report.rb +66 -0
- data/lib/chef/json_compat.rb +1 -1
- data/lib/chef/mixin/get_source_from_package.rb +1 -1
- data/lib/chef/node.rb +21 -20
- data/lib/chef/node/attribute.rb +6 -4
- data/lib/chef/node/immutable_collections.rb +13 -0
- data/lib/chef/node/mixin/deep_merge_cache.rb +11 -7
- data/lib/chef/org.rb +3 -2
- data/lib/chef/policy_builder/policyfile.rb +88 -45
- data/lib/chef/property.rb +18 -0
- data/lib/chef/provider.rb +1 -1
- data/lib/chef/provider/cron.rb +1 -1
- data/lib/chef/provider/directory.rb +6 -6
- data/lib/chef/provider/execute.rb +2 -1
- data/lib/chef/provider/file.rb +3 -3
- data/lib/chef/provider/git.rb +5 -7
- data/lib/chef/provider/group/groupadd.rb +3 -3
- data/lib/chef/provider/group/groupmod.rb +3 -3
- data/lib/chef/provider/group/pw.rb +3 -3
- data/lib/chef/provider/ifconfig.rb +2 -2
- data/lib/chef/provider/link.rb +3 -3
- data/lib/chef/provider/lwrp_base.rb +1 -1
- data/lib/chef/provider/mount.rb +5 -5
- data/lib/chef/provider/mount/aix.rb +3 -3
- data/lib/chef/provider/mount/mount.rb +5 -5
- data/lib/chef/provider/mount/windows.rb +1 -1
- data/lib/chef/provider/package.rb +17 -21
- data/lib/chef/provider/package/apt.rb +27 -1
- data/lib/chef/provider/package/deb.rb +3 -3
- data/lib/chef/provider/package/dnf/dnf_helper.py +12 -11
- data/lib/chef/provider/package/dnf/python_helper.rb +9 -8
- data/lib/chef/provider/package/habitat.rb +168 -0
- data/lib/chef/provider/package/portage.rb +2 -2
- data/lib/chef/provider/package/powershell.rb +5 -0
- data/lib/chef/provider/package/rubygems.rb +11 -17
- data/lib/chef/provider/package/windows.rb +2 -4
- data/lib/chef/provider/package/yum.rb +1 -4
- data/lib/chef/provider/package/yum/python_helper.rb +15 -10
- data/lib/chef/provider/package/yum/yum_helper.py +47 -63
- data/lib/chef/provider/registry_key.rb +1 -1
- data/lib/chef/provider/route.rb +2 -2
- data/lib/chef/provider/service.rb +6 -6
- data/lib/chef/provider/service/aixinit.rb +1 -1
- data/lib/chef/provider/service/debian.rb +1 -1
- data/lib/chef/provider/service/freebsd.rb +15 -21
- data/lib/chef/provider/service/macosx.rb +4 -4
- data/lib/chef/provider/service/systemd.rb +43 -14
- data/lib/chef/provider/service/upstart.rb +2 -13
- data/lib/chef/provider/service/windows.rb +12 -12
- data/lib/chef/provider/subversion.rb +10 -12
- data/lib/chef/provider/support/zypper_repo.erb +4 -2
- data/lib/chef/provider/systemd_unit.rb +36 -10
- data/lib/chef/provider/template/content.rb +3 -7
- data/lib/chef/provider/user.rb +2 -2
- data/lib/chef/provider/user/dscl.rb +1 -1
- data/lib/chef/provider/user/mac.rb +17 -20
- data/lib/chef/provider/user/pw.rb +1 -1
- data/lib/chef/provider/user/windows.rb +1 -1
- data/lib/chef/provider/windows_script.rb +1 -1
- data/lib/chef/provider/zypper_repository.rb +28 -32
- data/lib/chef/providers.rb +1 -1
- data/lib/chef/resource.rb +6 -7
- data/lib/chef/resource/alternatives.rb +6 -6
- data/lib/chef/resource/apt_package.rb +1 -1
- data/lib/chef/resource/apt_preference.rb +2 -2
- data/lib/chef/resource/apt_repository.rb +6 -6
- data/lib/chef/resource/apt_update.rb +5 -4
- data/lib/chef/resource/archive_file.rb +2 -3
- data/lib/chef/resource/breakpoint.rb +1 -1
- data/lib/chef/resource/build_essential.rb +2 -6
- data/lib/chef/resource/chef_client_config.rb +10 -5
- data/lib/chef/resource/chef_client_cron.rb +5 -5
- data/lib/chef/resource/chef_client_launchd.rb +6 -6
- data/lib/chef/resource/chef_client_scheduled_task.rb +16 -16
- data/lib/chef/resource/chef_client_systemd_timer.rb +5 -5
- data/lib/chef/resource/chef_client_trusted_certificate.rb +2 -2
- data/lib/chef/resource/chef_handler.rb +3 -7
- data/lib/chef/resource/chef_sleep.rb +1 -1
- data/lib/chef/resource/chef_vault_secret.rb +5 -10
- data/lib/chef/resource/chocolatey_config.rb +2 -6
- data/lib/chef/resource/chocolatey_feature.rb +2 -6
- data/lib/chef/resource/chocolatey_source.rb +4 -10
- data/lib/chef/resource/cron/_cron_shared.rb +2 -2
- data/lib/chef/resource/cron/cron_d.rb +4 -6
- data/lib/chef/resource/cron_access.rb +2 -4
- data/lib/chef/resource/dmg_package.rb +6 -10
- data/lib/chef/resource/dpkg_package.rb +1 -1
- data/lib/chef/resource/dsc_resource.rb +1 -1
- data/lib/chef/resource/execute.rb +11 -6
- data/lib/chef/resource/file.rb +1 -1
- data/lib/chef/resource/gem_package.rb +2 -1
- data/lib/chef/resource/group.rb +6 -6
- data/lib/chef/{knife/recipe_list.rb → resource/habitat/_habitat_shared.rb} +13 -17
- data/lib/chef/resource/habitat/habitat_package.rb +129 -0
- data/lib/chef/resource/habitat/habitat_sup.rb +329 -0
- data/lib/chef/resource/habitat/habitat_sup_systemd.rb +67 -0
- data/lib/chef/resource/habitat/habitat_sup_windows.rb +90 -0
- data/lib/chef/resource/habitat_config.rb +107 -0
- data/lib/chef/resource/habitat_install.rb +247 -0
- data/lib/chef/resource/habitat_service.rb +451 -0
- data/lib/chef/resource/habitat_user_toml.rb +92 -0
- data/lib/chef/resource/homebrew_cask.rb +17 -10
- data/lib/chef/resource/homebrew_package.rb +1 -1
- data/lib/chef/resource/homebrew_tap.rb +4 -7
- data/lib/chef/resource/homebrew_update.rb +2 -2
- data/lib/chef/resource/hostname.rb +68 -22
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/inspec_waiver_file_entry.rb +156 -0
- data/lib/chef/resource/kernel_module.rb +6 -17
- data/lib/chef/resource/locale.rb +2 -3
- data/lib/chef/resource/lwrp_base.rb +20 -1
- data/lib/chef/resource/macos_userdefaults.rb +10 -14
- data/lib/chef/resource/mdadm.rb +53 -7
- data/lib/chef/resource/mount.rb +2 -1
- data/lib/chef/resource/ohai_hint.rb +2 -6
- data/lib/chef/resource/openbsd_package.rb +17 -0
- data/lib/chef/resource/openssl_dhparam.rb +1 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +3 -5
- data/lib/chef/resource/openssl_ec_public_key.rb +1 -3
- data/lib/chef/resource/openssl_rsa_private_key.rb +2 -4
- data/lib/chef/resource/openssl_rsa_public_key.rb +1 -3
- data/lib/chef/resource/openssl_x509_certificate.rb +3 -6
- data/lib/chef/resource/openssl_x509_crl.rb +1 -3
- data/lib/chef/resource/openssl_x509_request.rb +1 -3
- data/lib/chef/resource/osx_profile.rb +3 -3
- data/lib/chef/resource/plist.rb +8 -8
- data/lib/chef/resource/powershell_package_source.rb +2 -4
- data/lib/chef/resource/powershell_script.rb +1 -1
- data/lib/chef/resource/reboot.rb +38 -9
- data/lib/chef/resource/remote_directory.rb +2 -2
- data/lib/chef/resource/remote_file.rb +3 -3
- data/lib/chef/resource/rhsm_errata.rb +16 -3
- data/lib/chef/resource/rhsm_errata_level.rb +11 -6
- data/lib/chef/resource/rhsm_register.rb +12 -6
- data/lib/chef/resource/rhsm_repo.rb +17 -6
- data/lib/chef/resource/rhsm_subscription.rb +2 -6
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/ssh_known_hosts_entry.rb +4 -7
- data/lib/chef/resource/sudo.rb +8 -12
- data/lib/chef/resource/support/HabService.dll.config.erb +19 -0
- data/lib/chef/resource/support/client.erb +8 -1
- data/lib/chef/resource/support/sup.toml.erb +179 -0
- data/lib/chef/resource/swap_file.rb +2 -6
- data/lib/chef/resource/sysctl.rb +2 -6
- data/lib/chef/resource/systemd_unit.rb +2 -2
- data/lib/chef/resource/template.rb +1 -1
- data/lib/chef/resource/timezone.rb +1 -3
- data/lib/chef/resource/user/mac_user.rb +1 -1
- data/lib/chef/resource/user_ulimit.rb +2 -2
- data/lib/chef/resource/windows_ad_join.rb +2 -6
- data/lib/chef/resource/windows_audit_policy.rb +2 -2
- data/lib/chef/resource/windows_auto_run.rb +2 -5
- data/lib/chef/resource/windows_certificate.rb +207 -73
- data/lib/chef/resource/windows_defender.rb +163 -0
- data/lib/chef/resource/windows_defender_exclusion.rb +125 -0
- data/lib/chef/resource/windows_dfs_folder.rb +2 -6
- data/lib/chef/resource/windows_dfs_namespace.rb +2 -6
- data/lib/chef/resource/windows_dfs_server.rb +1 -3
- data/lib/chef/resource/windows_dns_record.rb +2 -6
- data/lib/chef/resource/windows_dns_zone.rb +2 -6
- data/lib/chef/resource/windows_env.rb +6 -5
- data/lib/chef/resource/windows_feature.rb +3 -9
- data/lib/chef/resource/windows_feature_dism.rb +3 -9
- data/lib/chef/resource/windows_feature_powershell.rb +3 -3
- data/lib/chef/resource/windows_firewall_profile.rb +4 -4
- data/lib/chef/resource/windows_firewall_rule.rb +20 -9
- data/lib/chef/resource/windows_font.rb +3 -5
- data/lib/chef/resource/windows_pagefile.rb +104 -69
- data/lib/chef/resource/windows_path.rb +4 -4
- data/lib/chef/resource/windows_printer.rb +80 -61
- data/lib/chef/resource/windows_printer_port.rb +49 -66
- data/lib/chef/resource/windows_security_policy.rb +56 -40
- data/lib/chef/resource/windows_share.rb +14 -21
- data/lib/chef/resource/windows_shortcut.rb +4 -6
- data/lib/chef/resource/windows_task.rb +19 -7
- data/lib/chef/resource/windows_uac.rb +3 -5
- data/lib/chef/resource/windows_update_settings.rb +259 -0
- data/lib/chef/resource/windows_user_privilege.rb +4 -4
- data/lib/chef/resource/windows_workgroup.rb +3 -4
- data/lib/chef/resource/yum_package.rb +10 -10
- data/lib/chef/resource/zypper_package.rb +4 -4
- data/lib/chef/resource/zypper_repository.rb +28 -8
- data/lib/chef/resource_builder.rb +8 -2
- data/lib/chef/resource_reporter.rb +0 -1
- data/lib/chef/resources.rb +13 -2
- data/lib/chef/run_lock.rb +1 -1
- data/lib/chef/runner.rb +1 -1
- data/lib/chef/secret_fetcher.rb +54 -0
- data/lib/chef/secret_fetcher/aws_secrets_manager.rb +53 -0
- data/lib/chef/secret_fetcher/azure_key_vault.rb +56 -0
- data/lib/chef/secret_fetcher/base.rb +72 -0
- data/lib/chef/secret_fetcher/example.rb +46 -0
- data/lib/chef/shell/ext.rb +3 -3
- data/lib/chef/user.rb +0 -1
- data/lib/chef/user_v1.rb +3 -4
- data/lib/chef/util/dsc/configuration_generator.rb +1 -0
- data/lib/chef/util/dsc/local_configuration_manager.rb +1 -1
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api.rb +9 -2
- data/lib/chef/win32/registry.rb +4 -2
- data/spec/data/cookbooks/openldap/libraries/openldap.rb +1 -1
- data/spec/data/lwrp/resources/bar.rb +2 -0
- data/spec/data/lwrp/resources/buck_passer.rb +1 -0
- data/spec/data/lwrp/resources/buck_passer_2.rb +1 -0
- data/spec/data/lwrp/resources/embedded_resource_accesses_providers_scope.rb +1 -0
- data/spec/data/lwrp/resources/foo.rb +2 -0
- data/spec/data/lwrp/resources/inline_compiler.rb +1 -0
- data/spec/data/lwrp/resources/monkey_name_printer.rb +1 -0
- data/spec/data/lwrp/resources/paint_drying_watcher.rb +1 -0
- data/spec/data/lwrp/resources/thumb_twiddler.rb +1 -0
- data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +2 -0
- data/spec/data/lwrp_const_scoping/resources/conflict.rb +1 -0
- data/spec/data/lwrp_override/resources/foo.rb +1 -0
- data/spec/data/rubygems.org/nonexistent_gem-info +1 -0
- data/spec/data/rubygems.org/sexp_processor-info +49 -0
- data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +2 -0
- data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -0
- data/spec/data/run_context/cookbooks/test/resources/resource.rb +2 -0
- data/spec/functional/dsl/registry_helper_spec.rb +1 -1
- data/spec/functional/mixin/from_file_spec.rb +1 -1
- data/spec/functional/resource/aixinit_service_spec.rb +7 -7
- data/spec/functional/resource/apt_package_spec.rb +1 -1
- data/spec/functional/resource/chocolatey_package_spec.rb +13 -0
- data/spec/functional/resource/dnf_package_spec.rb +857 -534
- data/spec/functional/resource/group_spec.rb +1 -1
- data/spec/functional/resource/link_spec.rb +1 -1
- data/spec/functional/resource/registry_spec.rb +8 -8
- data/spec/functional/resource/remote_file_spec.rb +1 -1
- data/spec/functional/resource/user/mac_user_spec.rb +2 -2
- data/spec/functional/resource/windows_certificate_spec.rb +92 -35
- data/spec/functional/resource/windows_env_spec.rb +2 -2
- data/spec/functional/resource/windows_hostname_spec.rb +91 -0
- data/spec/functional/resource/windows_pagefile_spec.rb +98 -0
- data/spec/functional/resource/yum_package_spec.rb +495 -428
- data/spec/functional/version_spec.rb +1 -1
- data/spec/functional/win32/registry_spec.rb +1 -1
- data/spec/integration/client/client_spec.rb +5 -22
- data/spec/integration/client/exit_code_spec.rb +1 -1
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/compliance/compliance_spec.rb +1 -1
- data/spec/integration/ohai/ohai_spec.rb +7 -6
- data/spec/integration/recipes/accumulator_spec.rb +13 -1
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +5 -1
- data/spec/integration/recipes/lwrp_spec.rb +3 -1
- data/spec/integration/recipes/notifies_spec.rb +15 -1
- data/spec/integration/recipes/notifying_block_spec.rb +2 -1
- data/spec/integration/recipes/recipe_dsl_spec.rb +10 -10
- data/spec/integration/recipes/resource_action_spec.rb +4 -4
- data/spec/integration/recipes/unified_mode_spec.rb +71 -1
- data/spec/integration/recipes/use_partial_spec.rb +4 -1
- data/spec/spec_helper.rb +13 -13
- data/spec/support/chef_helpers.rb +1 -17
- data/spec/support/lib/chef/resource/with_state.rb +0 -1
- data/spec/support/lib/chef/resource/zen_follower.rb +0 -1
- data/spec/support/lib/chef/resource/zen_master.rb +0 -1
- data/spec/support/matchers/leak.rb +7 -9
- data/spec/support/platform_helpers.rb +1 -8
- data/spec/support/shared/functional/execute_resource.rb +1 -1
- data/spec/support/shared/integration/integration_helper.rb +0 -1
- data/spec/support/shared/unit/provider/file.rb +3 -9
- data/spec/support/shared/unit/script_resource.rb +2 -2
- data/spec/unit/application/solo_spec.rb +2 -2
- data/spec/unit/chef_fs/diff_spec.rb +1 -1
- data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +1 -1
- data/spec/unit/chef_fs/file_system_spec.rb +1 -1
- data/spec/unit/compliance/fetcher/automate_spec.rb +0 -16
- data/spec/unit/compliance/reporter/automate_spec.rb +26 -2
- data/spec/unit/compliance/reporter/chef_server_automate_spec.rb +20 -0
- data/spec/unit/compliance/reporter/compliance_enforcer_spec.rb +1 -0
- data/spec/unit/compliance/runner_spec.rb +31 -5
- data/spec/unit/cookbook_version_spec.rb +52 -0
- data/spec/unit/data_bag_item_spec.rb +1 -6
- data/spec/unit/data_collector_spec.rb +47 -1
- data/spec/unit/dsl/reboot_pending_spec.rb +2 -2
- data/spec/unit/dsl/registry_helper_spec.rb +1 -1
- data/spec/unit/dsl/render_helpers_spec.rb +102 -0
- data/spec/unit/dsl/secret_spec.rb +65 -0
- data/spec/unit/handler_spec.rb +8 -2
- data/spec/unit/lwrp_spec.rb +1 -1
- data/spec/unit/mixin/params_validate_spec.rb +4 -3
- data/spec/unit/node/attribute_spec.rb +1 -1
- data/spec/unit/node_spec.rb +78 -0
- data/spec/unit/org_group_spec.rb +45 -0
- data/spec/unit/policy_builder/dynamic_spec.rb +0 -5
- data/spec/unit/policy_builder/policyfile_spec.rb +144 -56
- data/spec/unit/property_spec.rb +23 -22
- data/spec/unit/provider/apt_update_spec.rb +3 -1
- data/spec/unit/provider/cron_spec.rb +1 -1
- data/spec/unit/provider/group/gpasswd_spec.rb +2 -2
- data/spec/unit/provider/group/groupmod_spec.rb +2 -2
- data/spec/unit/provider/group/pw_spec.rb +2 -2
- data/spec/unit/provider/group_spec.rb +1 -1
- data/spec/unit/provider/link_spec.rb +1 -1
- data/spec/unit/provider/mount/aix_spec.rb +1 -1
- data/spec/unit/provider/package/apt_spec.rb +84 -18
- data/spec/unit/provider/package/deb_spec.rb +3 -3
- data/spec/unit/provider/package/dnf/python_helper_spec.rb +1 -0
- data/spec/unit/provider/package/powershell_spec.rb +74 -12
- data/spec/unit/provider/package/rubygems_spec.rb +21 -33
- data/spec/unit/provider/package/yum/python_helper_spec.rb +1 -0
- data/spec/unit/provider/service/arch_service_spec.rb +1 -0
- data/spec/unit/provider/service/debian_service_spec.rb +1 -0
- data/spec/unit/provider/service/macosx_spec.rb +2 -2
- data/spec/unit/provider/service/systemd_service_spec.rb +138 -23
- data/spec/unit/provider/service/upstart_service_spec.rb +0 -29
- data/spec/unit/provider/service/windows_spec.rb +2 -2
- data/spec/unit/provider/subversion_spec.rb +2 -2
- data/spec/unit/provider/systemd_unit_spec.rb +79 -60
- data/spec/unit/provider/zypper_repository_spec.rb +5 -12
- data/spec/unit/provider_spec.rb +0 -8
- data/spec/unit/resource/inspec_waiver_file_entry_spec.rb +80 -0
- data/spec/unit/resource/powershell_script_spec.rb +2 -2
- data/spec/unit/resource/windows_defender_exclusion_spec.rb +62 -0
- data/spec/unit/resource/windows_defender_spec.rb +71 -0
- data/spec/unit/resource/windows_firewall_rule_spec.rb +12 -7
- data/spec/unit/resource/windows_pagefile_spec.rb +4 -9
- data/spec/unit/resource/windows_task_spec.rb +1 -1
- data/spec/unit/resource/windows_update_settings_spec.rb +64 -0
- data/spec/unit/resource/zypper_repository_spec.rb +1 -1
- data/spec/unit/secret_fetcher/azure_key_vault_spec.rb +63 -0
- data/spec/unit/secret_fetcher_spec.rb +82 -0
- data/spec/unit/user_spec.rb +1 -1
- data/spec/unit/user_v1_spec.rb +6 -4
- data/tasks/rspec.rb +9 -6
- metadata +59 -519
- data/bin/knife +0 -24
- data/lib/chef/application/knife.rb +0 -234
- data/lib/chef/application/windows_service.rb +0 -338
- data/lib/chef/application/windows_service_manager.rb +0 -205
- data/lib/chef/chef_fs/knife.rb +0 -160
- data/lib/chef/chef_fs/parallelizer.rb +0 -102
- data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +0 -35
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +0 -278
- data/lib/chef/cookbook_site_streaming_uploader.rb +0 -244
- data/lib/chef/knife.rb +0 -665
- data/lib/chef/knife/acl_add.rb +0 -57
- data/lib/chef/knife/acl_base.rb +0 -183
- data/lib/chef/knife/acl_bulk_add.rb +0 -78
- data/lib/chef/knife/acl_bulk_remove.rb +0 -83
- data/lib/chef/knife/acl_remove.rb +0 -62
- data/lib/chef/knife/acl_show.rb +0 -56
- data/lib/chef/knife/bootstrap.rb +0 -1192
- data/lib/chef/knife/bootstrap/chef_vault_handler.rb +0 -162
- data/lib/chef/knife/bootstrap/client_builder.rb +0 -212
- data/lib/chef/knife/bootstrap/templates/README.md +0 -11
- data/lib/chef/knife/bootstrap/templates/chef-full.erb +0 -242
- data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +0 -278
- data/lib/chef/knife/bootstrap/train_connector.rb +0 -336
- data/lib/chef/knife/client_bulk_delete.rb +0 -104
- data/lib/chef/knife/client_create.rb +0 -101
- data/lib/chef/knife/client_delete.rb +0 -62
- data/lib/chef/knife/client_edit.rb +0 -52
- data/lib/chef/knife/client_key_create.rb +0 -73
- data/lib/chef/knife/client_key_delete.rb +0 -80
- data/lib/chef/knife/client_key_edit.rb +0 -83
- data/lib/chef/knife/client_key_list.rb +0 -73
- data/lib/chef/knife/client_key_show.rb +0 -80
- data/lib/chef/knife/client_list.rb +0 -41
- data/lib/chef/knife/client_reregister.rb +0 -58
- data/lib/chef/knife/client_show.rb +0 -48
- data/lib/chef/knife/config_get.rb +0 -39
- data/lib/chef/knife/config_get_profile.rb +0 -37
- data/lib/chef/knife/config_list.rb +0 -139
- data/lib/chef/knife/config_list_profiles.rb +0 -37
- data/lib/chef/knife/config_show.rb +0 -127
- data/lib/chef/knife/config_use.rb +0 -61
- data/lib/chef/knife/config_use_profile.rb +0 -47
- data/lib/chef/knife/configure.rb +0 -150
- data/lib/chef/knife/configure_client.rb +0 -48
- data/lib/chef/knife/cookbook_bulk_delete.rb +0 -71
- data/lib/chef/knife/cookbook_delete.rb +0 -151
- data/lib/chef/knife/cookbook_download.rb +0 -142
- data/lib/chef/knife/cookbook_list.rb +0 -47
- data/lib/chef/knife/cookbook_metadata.rb +0 -106
- data/lib/chef/knife/cookbook_metadata_from_file.rb +0 -49
- data/lib/chef/knife/cookbook_show.rb +0 -98
- data/lib/chef/knife/cookbook_upload.rb +0 -292
- data/lib/chef/knife/core/bootstrap_context.rb +0 -264
- data/lib/chef/knife/core/cookbook_scm_repo.rb +0 -159
- data/lib/chef/knife/core/formatting_options.rb +0 -49
- data/lib/chef/knife/core/gem_glob_loader.rb +0 -138
- data/lib/chef/knife/core/generic_presenter.rb +0 -232
- data/lib/chef/knife/core/hashed_command_loader.rb +0 -100
- data/lib/chef/knife/core/node_editor.rb +0 -130
- data/lib/chef/knife/core/node_presenter.rb +0 -133
- data/lib/chef/knife/core/object_loader.rb +0 -115
- data/lib/chef/knife/core/status_presenter.rb +0 -147
- data/lib/chef/knife/core/subcommand_loader.rb +0 -203
- data/lib/chef/knife/core/text_formatter.rb +0 -85
- data/lib/chef/knife/core/ui.rb +0 -338
- data/lib/chef/knife/core/windows_bootstrap_context.rb +0 -406
- data/lib/chef/knife/data_bag_create.rb +0 -81
- data/lib/chef/knife/data_bag_delete.rb +0 -49
- data/lib/chef/knife/data_bag_edit.rb +0 -74
- data/lib/chef/knife/data_bag_from_file.rb +0 -113
- data/lib/chef/knife/data_bag_list.rb +0 -42
- data/lib/chef/knife/data_bag_secret_options.rb +0 -122
- data/lib/chef/knife/data_bag_show.rb +0 -69
- data/lib/chef/knife/delete.rb +0 -125
- data/lib/chef/knife/deps.rb +0 -156
- data/lib/chef/knife/diff.rb +0 -83
- data/lib/chef/knife/download.rb +0 -84
- data/lib/chef/knife/edit.rb +0 -88
- data/lib/chef/knife/environment_compare.rb +0 -128
- data/lib/chef/knife/environment_create.rb +0 -52
- data/lib/chef/knife/environment_delete.rb +0 -44
- data/lib/chef/knife/environment_edit.rb +0 -44
- data/lib/chef/knife/environment_from_file.rb +0 -84
- data/lib/chef/knife/environment_list.rb +0 -41
- data/lib/chef/knife/environment_show.rb +0 -47
- data/lib/chef/knife/exec.rb +0 -99
- data/lib/chef/knife/group_add.rb +0 -55
- data/lib/chef/knife/group_create.rb +0 -49
- data/lib/chef/knife/group_destroy.rb +0 -53
- data/lib/chef/knife/group_remove.rb +0 -56
- data/lib/chef/knife/group_show.rb +0 -49
- data/lib/chef/knife/key_create.rb +0 -112
- data/lib/chef/knife/key_create_base.rb +0 -50
- data/lib/chef/knife/key_delete.rb +0 -55
- data/lib/chef/knife/key_edit.rb +0 -118
- data/lib/chef/knife/key_edit_base.rb +0 -55
- data/lib/chef/knife/key_list.rb +0 -90
- data/lib/chef/knife/key_list_base.rb +0 -45
- data/lib/chef/knife/key_show.rb +0 -53
- data/lib/chef/knife/list.rb +0 -177
- data/lib/chef/knife/node_bulk_delete.rb +0 -75
- data/lib/chef/knife/node_create.rb +0 -47
- data/lib/chef/knife/node_delete.rb +0 -46
- data/lib/chef/knife/node_edit.rb +0 -70
- data/lib/chef/knife/node_environment_set.rb +0 -53
- data/lib/chef/knife/node_from_file.rb +0 -51
- data/lib/chef/knife/node_list.rb +0 -44
- data/lib/chef/knife/node_policy_set.rb +0 -79
- data/lib/chef/knife/node_run_list_add.rb +0 -104
- data/lib/chef/knife/node_run_list_remove.rb +0 -67
- data/lib/chef/knife/node_run_list_set.rb +0 -66
- data/lib/chef/knife/node_show.rb +0 -63
- data/lib/chef/knife/null.rb +0 -12
- data/lib/chef/knife/raw.rb +0 -123
- data/lib/chef/knife/rehash.rb +0 -50
- data/lib/chef/knife/role_bulk_delete.rb +0 -66
- data/lib/chef/knife/role_create.rb +0 -53
- data/lib/chef/knife/role_delete.rb +0 -46
- data/lib/chef/knife/role_edit.rb +0 -45
- data/lib/chef/knife/role_env_run_list_add.rb +0 -87
- data/lib/chef/knife/role_env_run_list_clear.rb +0 -55
- data/lib/chef/knife/role_env_run_list_remove.rb +0 -57
- data/lib/chef/knife/role_env_run_list_replace.rb +0 -60
- data/lib/chef/knife/role_env_run_list_set.rb +0 -70
- data/lib/chef/knife/role_from_file.rb +0 -51
- data/lib/chef/knife/role_list.rb +0 -42
- data/lib/chef/knife/role_run_list_add.rb +0 -87
- data/lib/chef/knife/role_run_list_clear.rb +0 -55
- data/lib/chef/knife/role_run_list_remove.rb +0 -56
- data/lib/chef/knife/role_run_list_replace.rb +0 -60
- data/lib/chef/knife/role_run_list_set.rb +0 -69
- data/lib/chef/knife/role_show.rb +0 -48
- data/lib/chef/knife/search.rb +0 -194
- data/lib/chef/knife/serve.rb +0 -65
- data/lib/chef/knife/show.rb +0 -72
- data/lib/chef/knife/ssh.rb +0 -645
- data/lib/chef/knife/ssl_check.rb +0 -284
- data/lib/chef/knife/ssl_fetch.rb +0 -161
- data/lib/chef/knife/status.rb +0 -95
- data/lib/chef/knife/supermarket_download.rb +0 -121
- data/lib/chef/knife/supermarket_install.rb +0 -192
- data/lib/chef/knife/supermarket_list.rb +0 -76
- data/lib/chef/knife/supermarket_search.rb +0 -53
- data/lib/chef/knife/supermarket_share.rb +0 -166
- data/lib/chef/knife/supermarket_show.rb +0 -66
- data/lib/chef/knife/supermarket_unshare.rb +0 -61
- data/lib/chef/knife/tag_create.rb +0 -52
- data/lib/chef/knife/tag_delete.rb +0 -60
- data/lib/chef/knife/tag_list.rb +0 -47
- data/lib/chef/knife/upload.rb +0 -86
- data/lib/chef/knife/user_create.rb +0 -107
- data/lib/chef/knife/user_delete.rb +0 -44
- data/lib/chef/knife/user_dissociate.rb +0 -42
- data/lib/chef/knife/user_edit.rb +0 -52
- data/lib/chef/knife/user_invite_add.rb +0 -43
- data/lib/chef/knife/user_invite_list.rb +0 -34
- data/lib/chef/knife/user_invite_rescind.rb +0 -63
- data/lib/chef/knife/user_key_create.rb +0 -73
- data/lib/chef/knife/user_key_delete.rb +0 -80
- data/lib/chef/knife/user_key_edit.rb +0 -83
- data/lib/chef/knife/user_key_list.rb +0 -73
- data/lib/chef/knife/user_key_show.rb +0 -80
- data/lib/chef/knife/user_list.rb +0 -42
- data/lib/chef/knife/user_reregister.rb +0 -59
- data/lib/chef/knife/user_show.rb +0 -48
- data/lib/chef/knife/xargs.rb +0 -282
- data/lib/chef/knife/yaml_convert.rb +0 -91
- data/lib/chef/provider/package/yum/simplejson/LICENSE.txt +0 -79
- data/lib/chef/provider/package/yum/simplejson/__init__.py +0 -318
- data/lib/chef/provider/package/yum/simplejson/__init__.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/decoder.py +0 -354
- data/lib/chef/provider/package/yum/simplejson/decoder.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/encoder.py +0 -440
- data/lib/chef/provider/package/yum/simplejson/encoder.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/scanner.py +0 -65
- data/lib/chef/provider/package/yum/simplejson/scanner.pyc +0 -0
- data/lib/chef/provider/package/yum/simplejson/tool.py +0 -37
- data/lib/chef/resource/user/dscl_user.rb +0 -35
- data/spec/functional/knife/configure_spec.rb +0 -33
- data/spec/functional/knife/cookbook_delete_spec.rb +0 -156
- data/spec/functional/knife/exec_spec.rb +0 -55
- data/spec/functional/knife/rehash_spec.rb +0 -39
- data/spec/functional/knife/smoke_test.rb +0 -42
- data/spec/functional/knife/ssh_spec.rb +0 -352
- data/spec/functional/resource/user/dscl_spec.rb +0 -188
- data/spec/functional/resource/windows_service_spec.rb +0 -105
- data/spec/functional/win32/service_manager_spec.rb +0 -220
- data/spec/integration/knife/chef_fs_data_store_spec.rb +0 -557
- data/spec/integration/knife/chef_repo_path_spec.rb +0 -962
- data/spec/integration/knife/chef_repository_file_system_spec.rb +0 -200
- data/spec/integration/knife/chefignore_spec.rb +0 -301
- data/spec/integration/knife/client_bulk_delete_spec.rb +0 -131
- data/spec/integration/knife/client_create_spec.rb +0 -70
- data/spec/integration/knife/client_delete_spec.rb +0 -64
- data/spec/integration/knife/client_key_create_spec.rb +0 -66
- data/spec/integration/knife/client_key_delete_spec.rb +0 -43
- data/spec/integration/knife/client_key_list_spec.rb +0 -61
- data/spec/integration/knife/client_key_show_spec.rb +0 -45
- data/spec/integration/knife/client_list_spec.rb +0 -49
- data/spec/integration/knife/client_show_spec.rb +0 -37
- data/spec/integration/knife/common_options_spec.rb +0 -174
- data/spec/integration/knife/config_list_spec.rb +0 -220
- data/spec/integration/knife/config_show_spec.rb +0 -192
- data/spec/integration/knife/config_use_spec.rb +0 -198
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +0 -113
- data/spec/integration/knife/cookbook_bulk_delete_spec.rb +0 -65
- data/spec/integration/knife/cookbook_download_spec.rb +0 -72
- data/spec/integration/knife/cookbook_list_spec.rb +0 -55
- data/spec/integration/knife/cookbook_show_spec.rb +0 -149
- data/spec/integration/knife/cookbook_upload_spec.rb +0 -128
- data/spec/integration/knife/data_bag_create_spec.rb +0 -125
- data/spec/integration/knife/data_bag_delete_spec.rb +0 -59
- data/spec/integration/knife/data_bag_edit_spec.rb +0 -105
- data/spec/integration/knife/data_bag_from_file_spec.rb +0 -116
- data/spec/integration/knife/data_bag_list_spec.rb +0 -44
- data/spec/integration/knife/data_bag_show_spec.rb +0 -95
- data/spec/integration/knife/delete_spec.rb +0 -1018
- data/spec/integration/knife/deps_spec.rb +0 -703
- data/spec/integration/knife/diff_spec.rb +0 -605
- data/spec/integration/knife/download_spec.rb +0 -1336
- data/spec/integration/knife/environment_compare_spec.rb +0 -75
- data/spec/integration/knife/environment_create_spec.rb +0 -41
- data/spec/integration/knife/environment_delete_spec.rb +0 -37
- data/spec/integration/knife/environment_from_file_spec.rb +0 -116
- data/spec/integration/knife/environment_list_spec.rb +0 -42
- data/spec/integration/knife/environment_show_spec.rb +0 -77
- data/spec/integration/knife/list_spec.rb +0 -1060
- data/spec/integration/knife/node_bulk_delete_spec.rb +0 -52
- data/spec/integration/knife/node_create_spec.rb +0 -47
- data/spec/integration/knife/node_delete_spec.rb +0 -48
- data/spec/integration/knife/node_environment_set_spec.rb +0 -46
- data/spec/integration/knife/node_from_file_spec.rb +0 -59
- data/spec/integration/knife/node_list_spec.rb +0 -45
- data/spec/integration/knife/node_run_list_add_spec.rb +0 -54
- data/spec/integration/knife/node_run_list_remove_spec.rb +0 -36
- data/spec/integration/knife/node_run_list_set_spec.rb +0 -41
- data/spec/integration/knife/node_show_spec.rb +0 -36
- data/spec/integration/knife/raw_spec.rb +0 -297
- data/spec/integration/knife/redirection_spec.rb +0 -64
- data/spec/integration/knife/role_bulk_delete_spec.rb +0 -52
- data/spec/integration/knife/role_create_spec.rb +0 -41
- data/spec/integration/knife/role_delete_spec.rb +0 -48
- data/spec/integration/knife/role_from_file_spec.rb +0 -96
- data/spec/integration/knife/role_list_spec.rb +0 -45
- data/spec/integration/knife/role_show_spec.rb +0 -51
- data/spec/integration/knife/search_node_spec.rb +0 -40
- data/spec/integration/knife/serve_spec.rb +0 -92
- data/spec/integration/knife/show_spec.rb +0 -197
- data/spec/integration/knife/upload_spec.rb +0 -1617
- data/spec/support/shared/functional/win32_service.rb +0 -57
- data/spec/unit/application/knife_spec.rb +0 -241
- data/spec/unit/chef_fs/parallelizer_spec.rb +0 -479
- data/spec/unit/cookbook_site_streaming_uploader_spec.rb +0 -198
- data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +0 -152
- data/spec/unit/knife/bootstrap/client_builder_spec.rb +0 -207
- data/spec/unit/knife/bootstrap/train_connector_spec.rb +0 -244
- data/spec/unit/knife/bootstrap_spec.rb +0 -2220
- data/spec/unit/knife/client_bulk_delete_spec.rb +0 -166
- data/spec/unit/knife/client_create_spec.rb +0 -169
- data/spec/unit/knife/client_delete_spec.rb +0 -99
- data/spec/unit/knife/client_edit_spec.rb +0 -53
- data/spec/unit/knife/client_list_spec.rb +0 -34
- data/spec/unit/knife/client_reregister_spec.rb +0 -62
- data/spec/unit/knife/client_show_spec.rb +0 -52
- data/spec/unit/knife/configure_client_spec.rb +0 -81
- data/spec/unit/knife/configure_spec.rb +0 -190
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +0 -87
- data/spec/unit/knife/cookbook_delete_spec.rb +0 -239
- data/spec/unit/knife/cookbook_download_spec.rb +0 -255
- data/spec/unit/knife/cookbook_list_spec.rb +0 -88
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +0 -72
- data/spec/unit/knife/cookbook_metadata_spec.rb +0 -182
- data/spec/unit/knife/cookbook_show_spec.rb +0 -253
- data/spec/unit/knife/cookbook_upload_spec.rb +0 -364
- data/spec/unit/knife/core/bootstrap_context_spec.rb +0 -287
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +0 -187
- data/spec/unit/knife/core/gem_glob_loader_spec.rb +0 -209
- data/spec/unit/knife/core/hashed_command_loader_spec.rb +0 -112
- data/spec/unit/knife/core/node_editor_spec.rb +0 -211
- data/spec/unit/knife/core/object_loader_spec.rb +0 -81
- data/spec/unit/knife/core/status_presenter_spec.rb +0 -54
- data/spec/unit/knife/core/subcommand_loader_spec.rb +0 -64
- data/spec/unit/knife/core/ui_spec.rb +0 -656
- data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +0 -238
- data/spec/unit/knife/data_bag_create_spec.rb +0 -175
- data/spec/unit/knife/data_bag_edit_spec.rb +0 -126
- data/spec/unit/knife/data_bag_from_file_spec.rb +0 -174
- data/spec/unit/knife/data_bag_secret_options_spec.rb +0 -173
- data/spec/unit/knife/data_bag_show_spec.rb +0 -139
- data/spec/unit/knife/environment_compare_spec.rb +0 -112
- data/spec/unit/knife/environment_create_spec.rb +0 -91
- data/spec/unit/knife/environment_delete_spec.rb +0 -71
- data/spec/unit/knife/environment_edit_spec.rb +0 -79
- data/spec/unit/knife/environment_from_file_spec.rb +0 -90
- data/spec/unit/knife/environment_list_spec.rb +0 -54
- data/spec/unit/knife/environment_show_spec.rb +0 -52
- data/spec/unit/knife/key_create_spec.rb +0 -223
- data/spec/unit/knife/key_delete_spec.rb +0 -133
- data/spec/unit/knife/key_edit_spec.rb +0 -264
- data/spec/unit/knife/key_helper.rb +0 -74
- data/spec/unit/knife/key_list_spec.rb +0 -216
- data/spec/unit/knife/key_show_spec.rb +0 -126
- data/spec/unit/knife/node_bulk_delete_spec.rb +0 -94
- data/spec/unit/knife/node_delete_spec.rb +0 -77
- data/spec/unit/knife/node_edit_spec.rb +0 -116
- data/spec/unit/knife/node_environment_set_spec.rb +0 -61
- data/spec/unit/knife/node_from_file_spec.rb +0 -59
- data/spec/unit/knife/node_list_spec.rb +0 -62
- data/spec/unit/knife/node_policy_set_spec.rb +0 -122
- data/spec/unit/knife/node_run_list_add_spec.rb +0 -145
- data/spec/unit/knife/node_run_list_remove_spec.rb +0 -106
- data/spec/unit/knife/node_run_list_set_spec.rb +0 -115
- data/spec/unit/knife/node_show_spec.rb +0 -65
- data/spec/unit/knife/raw_spec.rb +0 -43
- data/spec/unit/knife/role_bulk_delete_spec.rb +0 -80
- data/spec/unit/knife/role_create_spec.rb +0 -80
- data/spec/unit/knife/role_delete_spec.rb +0 -67
- data/spec/unit/knife/role_edit_spec.rb +0 -77
- data/spec/unit/knife/role_env_run_list_add_spec.rb +0 -217
- data/spec/unit/knife/role_env_run_list_clear_spec.rb +0 -94
- data/spec/unit/knife/role_env_run_list_remove_spec.rb +0 -102
- data/spec/unit/knife/role_env_run_list_replace_spec.rb +0 -105
- data/spec/unit/knife/role_env_run_list_set_spec.rb +0 -99
- data/spec/unit/knife/role_from_file_spec.rb +0 -69
- data/spec/unit/knife/role_list_spec.rb +0 -54
- data/spec/unit/knife/role_run_list_add_spec.rb +0 -179
- data/spec/unit/knife/role_run_list_clear_spec.rb +0 -84
- data/spec/unit/knife/role_run_list_remove_spec.rb +0 -92
- data/spec/unit/knife/role_run_list_replace_spec.rb +0 -98
- data/spec/unit/knife/role_run_list_set_spec.rb +0 -89
- data/spec/unit/knife/role_show_spec.rb +0 -59
- data/spec/unit/knife/ssh_spec.rb +0 -403
- data/spec/unit/knife/ssl_check_spec.rb +0 -256
- data/spec/unit/knife/ssl_fetch_spec.rb +0 -222
- data/spec/unit/knife/status_spec.rb +0 -112
- data/spec/unit/knife/supermarket_download_spec.rb +0 -152
- data/spec/unit/knife/supermarket_install_spec.rb +0 -202
- data/spec/unit/knife/supermarket_list_spec.rb +0 -70
- data/spec/unit/knife/supermarket_search_spec.rb +0 -85
- data/spec/unit/knife/supermarket_share_spec.rb +0 -208
- data/spec/unit/knife/supermarket_unshare_spec.rb +0 -78
- data/spec/unit/knife/tag_create_spec.rb +0 -23
- data/spec/unit/knife/tag_delete_spec.rb +0 -25
- data/spec/unit/knife/tag_list_spec.rb +0 -23
- data/spec/unit/knife/user_create_spec.rb +0 -184
- data/spec/unit/knife/user_delete_spec.rb +0 -46
- data/spec/unit/knife/user_edit_spec.rb +0 -48
- data/spec/unit/knife/user_list_spec.rb +0 -36
- data/spec/unit/knife/user_reregister_spec.rb +0 -56
- data/spec/unit/knife/user_show_spec.rb +0 -46
- data/spec/unit/knife_spec.rb +0 -634
- data/spec/unit/provider/user/dscl_spec.rb +0 -699
- data/spec/unit/windows_service_spec.rb +0 -118
@@ -1,699 +0,0 @@
|
|
1
|
-
#
|
2
|
-
# Author:: Dreamcat4 (<dreamcat4@gmail.com>)
|
3
|
-
# Copyright:: Copyright (c) Chef Software Inc.
|
4
|
-
# License:: Apache License, Version 2.0
|
5
|
-
#
|
6
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
-
# you may not use this file except in compliance with the License.
|
8
|
-
# You may obtain a copy of the License at
|
9
|
-
#
|
10
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
-
#
|
12
|
-
# Unless required by applicable law or agreed to in writing, software
|
13
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
-
# See the License for the specific language governing permissions and
|
16
|
-
# limitations under the License.
|
17
|
-
#
|
18
|
-
|
19
|
-
require "spec_helper"
|
20
|
-
require "ostruct"
|
21
|
-
|
22
|
-
describe Chef::Provider::User::Dscl do
|
23
|
-
before do
|
24
|
-
allow(ChefUtils).to receive(:windows?) { false }
|
25
|
-
end
|
26
|
-
|
27
|
-
let(:shellcmdresult) { Struct.new(:stdout, :stderr, :exitstatus) }
|
28
|
-
|
29
|
-
let(:password) { nil }
|
30
|
-
let(:salt) { nil }
|
31
|
-
let(:iterations) { nil }
|
32
|
-
|
33
|
-
let(:events) { Chef::EventDispatch::Dispatcher.new }
|
34
|
-
|
35
|
-
let(:node) do
|
36
|
-
Chef::Node.new.tap do |node|
|
37
|
-
node.automatic["os"] = "darwin"
|
38
|
-
node.automatic["platform_version"] = "10.13.0"
|
39
|
-
end
|
40
|
-
end
|
41
|
-
|
42
|
-
let(:run_context) { Chef::RunContext.new(node, {}, events) }
|
43
|
-
|
44
|
-
let(:new_resource) do
|
45
|
-
r = Chef::Resource::User::DsclUser.new("toor", run_context)
|
46
|
-
r.password(password)
|
47
|
-
r.salt(salt)
|
48
|
-
r.iterations(iterations)
|
49
|
-
r
|
50
|
-
end
|
51
|
-
|
52
|
-
let(:provider) do
|
53
|
-
Chef::Provider::User::Dscl.new(new_resource, run_context)
|
54
|
-
end
|
55
|
-
|
56
|
-
let(:salted_sha512_password) do
|
57
|
-
"0f543f021c63255e64e121a3585601b8ecfedf6d2\
|
58
|
-
705ddac69e682a33db5dbcdb9b56a2520bc8fff63a\
|
59
|
-
2ba6b7984c0737ff0b7949455071581f7affcd536d\
|
60
|
-
402b6cdb097"
|
61
|
-
end
|
62
|
-
|
63
|
-
let(:salted_sha512_pbkdf2_password) do
|
64
|
-
"c734b6e4787c3727bb35e29fdd92b97c\
|
65
|
-
1de12df509577a045728255ec7c6c5f5\
|
66
|
-
c18efa05ed02b682ffa7ebc05119900e\
|
67
|
-
b1d4880833aa7a190afc13e2bf0936b8\
|
68
|
-
20123e8c98f0f9bcac2a629d9163caac\
|
69
|
-
9464a8c234f3919082400b4f939bb77b\
|
70
|
-
c5adbbac718b7eb99463a7b679571e0f\
|
71
|
-
1c9fef2ef08d0b9e9c2bcf644eed2ffc"
|
72
|
-
end
|
73
|
-
|
74
|
-
let(:salted_sha512_pbkdf2_salt) do
|
75
|
-
"2d942d8364a9ccf2b8e5cb7ed1ff58f78\
|
76
|
-
e29dbfee7f9db58859144d061fd0058"
|
77
|
-
end
|
78
|
-
|
79
|
-
let(:salted_sha512_pbkdf2_iterations) do
|
80
|
-
25000
|
81
|
-
end
|
82
|
-
|
83
|
-
let(:vagrant_sha_512) do
|
84
|
-
"6f75d7190441facc34291ebbea1fc756b242d4f\
|
85
|
-
e9bcff141bccb84f1979e27e539539aa31f9f7dcc92c0cea959\
|
86
|
-
ea18e18b720e358e7fbe3cfbeaa561456f6ba008937a30"
|
87
|
-
end
|
88
|
-
|
89
|
-
let(:vagrant_sha_512_pbkdf2) do
|
90
|
-
"12601a90db17cbf\
|
91
|
-
8ba4808e6382fb0d3b9d8a6c1a190477bf680ab21afb\
|
92
|
-
6065467136e55cc208a6f74156e3daf20fb13369ef4b\
|
93
|
-
7bafa047d80359fb46a48a4adccd548ebb33851b093\
|
94
|
-
47cca84341a7f93a27147343f89fb843fb46c0017d2\
|
95
|
-
64afa4976baacf941b915bd1ec1ca24c30b3e759e02\
|
96
|
-
403e02f59fe7ff5938a7636c"
|
97
|
-
end
|
98
|
-
|
99
|
-
let(:vagrant_sha_512_pbkdf2_salt) do
|
100
|
-
"ee954be472fdc60ddf89484781433993625f006af6ec810c08f49a7e413946a1"
|
101
|
-
end
|
102
|
-
|
103
|
-
let(:vagrant_sha_512_pbkdf2_iterations) do
|
104
|
-
34482
|
105
|
-
end
|
106
|
-
|
107
|
-
describe "when shelling out to dscl" do
|
108
|
-
it "should run dscl with the supplied cmd /Path args" do
|
109
|
-
shell_return = shellcmdresult.new("stdout", "err", 0)
|
110
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-cmd", "/Path", "args").and_return(shell_return)
|
111
|
-
expect(provider.run_dscl("cmd", "/Path", "args")).to eq("stdout")
|
112
|
-
end
|
113
|
-
|
114
|
-
it "returns an empty string from delete commands" do
|
115
|
-
shell_return = shellcmdresult.new("out", "err", 23)
|
116
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-delete", "/Path", "args").and_return(shell_return)
|
117
|
-
expect(provider.run_dscl("delete", "/Path", "args")).to eq("")
|
118
|
-
end
|
119
|
-
|
120
|
-
it "should raise an exception for any other command" do
|
121
|
-
shell_return = shellcmdresult.new("out", "err", 23)
|
122
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-cmd", "/Path", "arguments").and_return(shell_return)
|
123
|
-
expect { provider.run_dscl("cmd", "/Path", "arguments") }.to raise_error(Chef::Exceptions::DsclCommandFailed)
|
124
|
-
end
|
125
|
-
|
126
|
-
it "raises an exception when dscl reports 'no such key'" do
|
127
|
-
shell_return = shellcmdresult.new("No such key: ", "err", 23)
|
128
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-cmd", "/Path", "args").and_return(shell_return)
|
129
|
-
expect { provider.run_dscl("cmd", "/Path", "args") }.to raise_error(Chef::Exceptions::DsclCommandFailed)
|
130
|
-
end
|
131
|
-
|
132
|
-
it "raises an exception when dscl reports 'eDSRecordNotFound'" do
|
133
|
-
shell_return = shellcmdresult.new("<dscl_cmd> DS Error: -14136 (eDSRecordNotFound)", "err", -14136)
|
134
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-cmd", "/Path", "args").and_return(shell_return)
|
135
|
-
expect { provider.run_dscl("cmd", "/Path", "args") }.to raise_error(Chef::Exceptions::DsclCommandFailed)
|
136
|
-
end
|
137
|
-
end
|
138
|
-
|
139
|
-
describe "get_free_uid" do
|
140
|
-
before do
|
141
|
-
expect(provider).to receive(:run_dscl).with("list", "/Users", "uid").and_return("\nwheel 200\nstaff 201\nbrahms 500\nchopin 501\n")
|
142
|
-
end
|
143
|
-
|
144
|
-
describe "when the system property is set to true" do
|
145
|
-
before do
|
146
|
-
new_resource.system(true)
|
147
|
-
end
|
148
|
-
|
149
|
-
it "should return the first unused uid number on or above 200" do
|
150
|
-
expect(provider.get_free_uid).to eq(202)
|
151
|
-
end
|
152
|
-
end
|
153
|
-
|
154
|
-
it "should return the first unused uid number on or above 500" do
|
155
|
-
expect(provider.get_free_uid).to eq(502)
|
156
|
-
end
|
157
|
-
|
158
|
-
it "should raise an exception when the search limit is exhausted" do
|
159
|
-
search_limit = 1
|
160
|
-
expect { provider.get_free_uid(search_limit) }.to raise_error(RuntimeError)
|
161
|
-
end
|
162
|
-
end
|
163
|
-
|
164
|
-
describe "uid_used?" do
|
165
|
-
it "should return false if not given any valid uid number" do
|
166
|
-
expect(provider.uid_used?(nil)).to be_falsey
|
167
|
-
end
|
168
|
-
|
169
|
-
describe "when called with a user id" do
|
170
|
-
before do
|
171
|
-
expect(provider).to receive(:run_dscl).with("list", "/Users", "uid").and_return("\naj 500\n")
|
172
|
-
end
|
173
|
-
|
174
|
-
it "should return true for a used uid number" do
|
175
|
-
expect(provider.uid_used?(500)).to be_truthy
|
176
|
-
end
|
177
|
-
|
178
|
-
it "should return false for an unused uid number" do
|
179
|
-
expect(provider.uid_used?(501)).to be_falsey
|
180
|
-
end
|
181
|
-
end
|
182
|
-
end
|
183
|
-
|
184
|
-
describe "when determining the uid to set" do
|
185
|
-
it "raises RequestedUIDUnavailable if the requested uid is already in use" do
|
186
|
-
allow(provider).to receive(:uid_used?).and_return(true)
|
187
|
-
expect(provider).to receive(:get_free_uid).and_return(501)
|
188
|
-
expect { provider.dscl_set_uid }.to raise_error(Chef::Exceptions::RequestedUIDUnavailable)
|
189
|
-
end
|
190
|
-
|
191
|
-
it "finds a valid, unused uid when none is specified" do
|
192
|
-
expect(provider).to receive(:run_dscl).with("list", "/Users", "uid").and_return("")
|
193
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "UniqueID", 501)
|
194
|
-
expect(provider).to receive(:get_free_uid).and_return(501)
|
195
|
-
provider.dscl_set_uid
|
196
|
-
expect(new_resource.uid).to eq(501)
|
197
|
-
end
|
198
|
-
|
199
|
-
it "sets the uid specified in the resource" do
|
200
|
-
new_resource.uid(1000)
|
201
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "UniqueID", 1000).and_return(true)
|
202
|
-
expect(provider).to receive(:run_dscl).with("list", "/Users", "uid").and_return("")
|
203
|
-
provider.dscl_set_uid
|
204
|
-
end
|
205
|
-
end
|
206
|
-
|
207
|
-
describe "current_home_exists?" do
|
208
|
-
let(:current_resource) do
|
209
|
-
new_resource.dup
|
210
|
-
end
|
211
|
-
|
212
|
-
before do
|
213
|
-
provider.current_resource = current_resource
|
214
|
-
end
|
215
|
-
|
216
|
-
it "returns false for nil home dir" do
|
217
|
-
current_resource.home nil
|
218
|
-
expect(provider.current_home_exists?).to be_falsey
|
219
|
-
end
|
220
|
-
|
221
|
-
it "is false for empty string" do
|
222
|
-
current_resource.home ""
|
223
|
-
expect(provider.current_home_exists?).to be_falsey
|
224
|
-
end
|
225
|
-
|
226
|
-
it "is true for existing directory" do
|
227
|
-
current_resource.home "/Users/blah"
|
228
|
-
allow(::File).to receive(:exist?).with("/Users/blah").and_return(true)
|
229
|
-
expect(provider.current_home_exists?).to be_truthy
|
230
|
-
end
|
231
|
-
end
|
232
|
-
|
233
|
-
describe "when modifying the home directory" do
|
234
|
-
let(:current_resource) do
|
235
|
-
new_resource.dup
|
236
|
-
end
|
237
|
-
|
238
|
-
before do
|
239
|
-
new_resource.manage_home true
|
240
|
-
new_resource.home("/Users/toor")
|
241
|
-
|
242
|
-
provider.current_resource = current_resource
|
243
|
-
end
|
244
|
-
|
245
|
-
it "deletes the home directory when resource#home is nil" do
|
246
|
-
new_resource.instance_variable_set(:@home, nil)
|
247
|
-
expect(provider).to receive(:run_dscl).with("delete", "/Users/toor", "NFSHomeDirectory").and_return(true)
|
248
|
-
provider.dscl_set_home
|
249
|
-
end
|
250
|
-
|
251
|
-
it "raises InvalidHomeDirectory when the resource's home directory doesn't look right" do
|
252
|
-
new_resource.home("epic-fail")
|
253
|
-
expect { provider.dscl_set_home }.to raise_error(Chef::Exceptions::InvalidHomeDirectory)
|
254
|
-
end
|
255
|
-
|
256
|
-
it "moves the users home to the new location if it exists and the target location is different" do
|
257
|
-
new_resource.manage_home true
|
258
|
-
|
259
|
-
current_home = CHEF_SPEC_DATA + "/old_home_dir"
|
260
|
-
current_home_files = [current_home + "/my-dot-emacs", current_home + "/my-dot-vim"]
|
261
|
-
current_resource.home(current_home)
|
262
|
-
new_resource.gid(23)
|
263
|
-
allow(::File).to receive(:exist?).with("/old/home/toor").and_return(true)
|
264
|
-
allow(::File).to receive(:exist?).with("/Users/toor").and_return(true)
|
265
|
-
allow(::File).to receive(:exist?).with(current_home).and_return(true)
|
266
|
-
|
267
|
-
expect(FileUtils).to receive(:mkdir_p).with("/Users/toor").and_return(true)
|
268
|
-
expect(FileUtils).to receive(:rmdir).with(current_home)
|
269
|
-
expect(::Dir).to receive(:glob).with("#{CHEF_SPEC_DATA}/old_home_dir/*", ::File::FNM_DOTMATCH).and_return(current_home_files)
|
270
|
-
expect(FileUtils).to receive(:mv).with(current_home_files, "/Users/toor", force: true)
|
271
|
-
expect(FileUtils).to receive(:chown_R).with("toor", "23", "/Users/toor")
|
272
|
-
|
273
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "NFSHomeDirectory", "/Users/toor")
|
274
|
-
provider.dscl_set_home
|
275
|
-
end
|
276
|
-
|
277
|
-
it "should run createhomedir to create the user's new home folder" do
|
278
|
-
expect(provider).to receive(:shell_out_compacted!).with("/usr/sbin/createhomedir", "-c", "-u", "toor")
|
279
|
-
provider.ditto_home
|
280
|
-
end
|
281
|
-
|
282
|
-
it "creates the user's NFSHomeDirectory and home directory" do
|
283
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "NFSHomeDirectory", "/Users/toor").and_return(true)
|
284
|
-
expect(provider).to receive(:ditto_home)
|
285
|
-
provider.dscl_set_home
|
286
|
-
end
|
287
|
-
end
|
288
|
-
|
289
|
-
describe "resource_requirements" do
|
290
|
-
let(:dscl_exists) { true }
|
291
|
-
let(:plutil_exists) { true }
|
292
|
-
|
293
|
-
before do
|
294
|
-
allow(::File).to receive(:exist?).with("/usr/bin/dscl").and_return(dscl_exists)
|
295
|
-
allow(::File).to receive(:exist?).with("/usr/bin/plutil").and_return(plutil_exists)
|
296
|
-
end
|
297
|
-
|
298
|
-
def run_requirements
|
299
|
-
provider.define_resource_requirements
|
300
|
-
provider.action = :create
|
301
|
-
provider.process_resource_requirements
|
302
|
-
end
|
303
|
-
|
304
|
-
describe "when dscl doesn't exist" do
|
305
|
-
let(:dscl_exists) { false }
|
306
|
-
|
307
|
-
it "should raise an error" do
|
308
|
-
expect { run_requirements }.to raise_error(Chef::Exceptions::User)
|
309
|
-
end
|
310
|
-
end
|
311
|
-
|
312
|
-
describe "when plutil doesn't exist" do
|
313
|
-
let(:plutil_exists) { false }
|
314
|
-
|
315
|
-
it "should raise an error" do
|
316
|
-
expect { run_requirements }.to raise_error(Chef::Exceptions::User)
|
317
|
-
end
|
318
|
-
end
|
319
|
-
|
320
|
-
describe "when password is SALTED-SHA512" do
|
321
|
-
let(:password) { salted_sha512_password }
|
322
|
-
|
323
|
-
it "should raise an error" do
|
324
|
-
expect { run_requirements }.to raise_error(Chef::Exceptions::User)
|
325
|
-
end
|
326
|
-
end
|
327
|
-
|
328
|
-
describe "when password is SALTED-SHA512-PBKDF2" do
|
329
|
-
let(:password) { salted_sha512_pbkdf2_password }
|
330
|
-
|
331
|
-
describe "when salt and iteration is not set" do
|
332
|
-
it "should raise an error" do
|
333
|
-
expect { run_requirements }.to raise_error(Chef::Exceptions::User)
|
334
|
-
end
|
335
|
-
end
|
336
|
-
|
337
|
-
describe "when salt and iteration is set" do
|
338
|
-
let(:salt) { salted_sha512_pbkdf2_salt }
|
339
|
-
let(:iterations) { salted_sha512_pbkdf2_iterations }
|
340
|
-
|
341
|
-
it "should not raise an error" do
|
342
|
-
expect { run_requirements }.not_to raise_error
|
343
|
-
end
|
344
|
-
end
|
345
|
-
end
|
346
|
-
end
|
347
|
-
|
348
|
-
describe "load_current_resource" do
|
349
|
-
# set this to any of the user plist files under spec/data
|
350
|
-
let(:user_plist_file) { nil }
|
351
|
-
|
352
|
-
before do
|
353
|
-
expect(provider).to receive(:shell_out_compacted).with("dscacheutil", "-flushcache")
|
354
|
-
expect(provider).to receive(:shell_out_compacted).with("plutil", "-convert", "xml1", "-o", "-", "/var/db/dslocal/nodes/Default/users/toor.plist") do
|
355
|
-
if user_plist_file.nil?
|
356
|
-
shellcmdresult.new("Can not find the file", "Sorry!!", 1)
|
357
|
-
else
|
358
|
-
shellcmdresult.new(File.read(File.join(CHEF_SPEC_DATA, "mac_users/#{user_plist_file}.plist.xml")), "", 0)
|
359
|
-
end
|
360
|
-
end
|
361
|
-
|
362
|
-
unless user_plist_file.nil?
|
363
|
-
expect(provider).to receive(:convert_binary_plist_to_xml).and_return(File.read(File.join(CHEF_SPEC_DATA, "mac_users/#{user_plist_file}.shadow.xml")))
|
364
|
-
end
|
365
|
-
end
|
366
|
-
|
367
|
-
describe "when user is not there" do
|
368
|
-
it "shouldn't raise an error" do
|
369
|
-
expect { provider.load_current_resource }.not_to raise_error
|
370
|
-
end
|
371
|
-
|
372
|
-
it "should set @user_exists" do
|
373
|
-
provider.load_current_resource
|
374
|
-
expect(provider.instance_variable_get(:@user_exists)).to be_falsey
|
375
|
-
end
|
376
|
-
|
377
|
-
it "should set username" do
|
378
|
-
provider.load_current_resource
|
379
|
-
expect(provider.current_resource.username).to eq("toor")
|
380
|
-
end
|
381
|
-
end
|
382
|
-
|
383
|
-
describe "when user is there" do
|
384
|
-
let(:password) { "something" } # Load password during load_current_resource
|
385
|
-
|
386
|
-
let(:user_plist_file) { "10.9" }
|
387
|
-
|
388
|
-
it "collects the user data correctly" do
|
389
|
-
provider.load_current_resource
|
390
|
-
expect(provider.current_resource.comment).to eq("vagrant")
|
391
|
-
expect(provider.current_resource.uid).to eq("501")
|
392
|
-
expect(provider.current_resource.gid).to eq("80")
|
393
|
-
expect(provider.current_resource.home).to eq("/Users/vagrant")
|
394
|
-
expect(provider.current_resource.shell).to eq("/bin/bash")
|
395
|
-
expect(provider.current_resource.password).to eq(vagrant_sha_512_pbkdf2)
|
396
|
-
expect(provider.current_resource.salt).to eq(vagrant_sha_512_pbkdf2_salt)
|
397
|
-
expect(provider.current_resource.iterations).to eq(vagrant_sha_512_pbkdf2_iterations)
|
398
|
-
end
|
399
|
-
|
400
|
-
describe "when a plain password is set that is same" do
|
401
|
-
let(:password) { "vagrant" }
|
402
|
-
|
403
|
-
it "diverged_password? should report false" do
|
404
|
-
provider.load_current_resource
|
405
|
-
expect(provider.diverged_password?).to be_falsey
|
406
|
-
end
|
407
|
-
end
|
408
|
-
|
409
|
-
describe "when a plain password is set that is different" do
|
410
|
-
let(:password) { "not_vagrant" }
|
411
|
-
|
412
|
-
it "diverged_password? should report true" do
|
413
|
-
provider.load_current_resource
|
414
|
-
expect(provider.diverged_password?).to be_truthy
|
415
|
-
end
|
416
|
-
end
|
417
|
-
|
418
|
-
describe "when iterations change" do
|
419
|
-
let(:password) { vagrant_sha_512_pbkdf2 }
|
420
|
-
let(:salt) { vagrant_sha_512_pbkdf2_salt }
|
421
|
-
let(:iterations) { 12345 }
|
422
|
-
|
423
|
-
it "diverged_password? should report true" do
|
424
|
-
provider.load_current_resource
|
425
|
-
expect(provider.diverged_password?).to be_truthy
|
426
|
-
end
|
427
|
-
end
|
428
|
-
|
429
|
-
describe "when shadow hash changes" do
|
430
|
-
let(:password) { salted_sha512_pbkdf2_password }
|
431
|
-
let(:salt) { vagrant_sha_512_pbkdf2_salt }
|
432
|
-
let(:iterations) { vagrant_sha_512_pbkdf2_iterations }
|
433
|
-
|
434
|
-
it "diverged_password? should report true" do
|
435
|
-
provider.load_current_resource
|
436
|
-
expect(provider.diverged_password?).to be_truthy
|
437
|
-
end
|
438
|
-
end
|
439
|
-
|
440
|
-
describe "when salt change" do
|
441
|
-
let(:password) { vagrant_sha_512_pbkdf2 }
|
442
|
-
let(:salt) { salted_sha512_pbkdf2_salt }
|
443
|
-
let(:iterations) { vagrant_sha_512_pbkdf2_iterations }
|
444
|
-
|
445
|
-
it "diverged_password? should report true" do
|
446
|
-
provider.load_current_resource
|
447
|
-
expect(provider.diverged_password?).to be_truthy
|
448
|
-
end
|
449
|
-
end
|
450
|
-
|
451
|
-
describe "when salt isn't found" do
|
452
|
-
it "diverged_password? should report true" do
|
453
|
-
provider.load_current_resource
|
454
|
-
provider.current_resource.salt(nil)
|
455
|
-
expect(provider.diverged_password?).to be_truthy
|
456
|
-
end
|
457
|
-
end
|
458
|
-
end
|
459
|
-
end
|
460
|
-
|
461
|
-
describe "salted_sha512_pbkdf2?" do
|
462
|
-
it "should return true when the string is a salted_sha512_pbkdf2 hash" do
|
463
|
-
expect(provider.salted_sha512_pbkdf2?(salted_sha512_pbkdf2_password)).to be_truthy
|
464
|
-
end
|
465
|
-
|
466
|
-
it "should return false otherwise" do
|
467
|
-
expect(provider.salted_sha512_pbkdf2?(salted_sha512_password)).to be_falsey
|
468
|
-
expect(provider.salted_sha512_pbkdf2?("any other string")).to be_falsey
|
469
|
-
end
|
470
|
-
end
|
471
|
-
|
472
|
-
describe "salted_sha512?" do
|
473
|
-
it "should return true when the string is a salted_sha512_pbkdf2 hash" do
|
474
|
-
expect(provider.salted_sha512_pbkdf2?(salted_sha512_pbkdf2_password)).to be_truthy
|
475
|
-
end
|
476
|
-
|
477
|
-
it "should return false otherwise" do
|
478
|
-
expect(provider.salted_sha512?(salted_sha512_pbkdf2_password)).to be_falsey
|
479
|
-
expect(provider.salted_sha512?("any other string")).to be_falsey
|
480
|
-
end
|
481
|
-
end
|
482
|
-
|
483
|
-
describe "prepare_password_shadow_info" do
|
484
|
-
describe "when the password is plain text" do
|
485
|
-
let(:password) { "vagrant" }
|
486
|
-
|
487
|
-
it "password_shadow_info should have salted-sha-512 format" do
|
488
|
-
shadow_info = provider.prepare_password_shadow_info
|
489
|
-
expect(shadow_info).to have_key("SALTED-SHA512-PBKDF2")
|
490
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("entropy")
|
491
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("salt")
|
492
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("iterations")
|
493
|
-
info = shadow_info["SALTED-SHA512-PBKDF2"]["entropy"].string.unpack("H*").first
|
494
|
-
expect(provider.salted_sha512_pbkdf2?(info)).to be_truthy
|
495
|
-
end
|
496
|
-
end
|
497
|
-
|
498
|
-
describe "when the password is salted-sha-512" do
|
499
|
-
let(:password) { vagrant_sha_512_pbkdf2 }
|
500
|
-
let(:iterations) { vagrant_sha_512_pbkdf2_iterations }
|
501
|
-
let(:salt) { vagrant_sha_512_pbkdf2_salt }
|
502
|
-
|
503
|
-
it "password_shadow_info should have salted-sha-512 format" do
|
504
|
-
shadow_info = provider.prepare_password_shadow_info
|
505
|
-
expect(shadow_info).to have_key("SALTED-SHA512-PBKDF2")
|
506
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("entropy")
|
507
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("salt")
|
508
|
-
expect(shadow_info["SALTED-SHA512-PBKDF2"]).to have_key("iterations")
|
509
|
-
info = shadow_info["SALTED-SHA512-PBKDF2"]["entropy"].string.unpack("H*").first
|
510
|
-
expect(provider.salted_sha512_pbkdf2?(info)).to be_truthy
|
511
|
-
expect(info).to eq(vagrant_sha_512_pbkdf2)
|
512
|
-
end
|
513
|
-
end
|
514
|
-
end
|
515
|
-
|
516
|
-
describe "set_password" do
|
517
|
-
before do
|
518
|
-
new_resource.password("something")
|
519
|
-
end
|
520
|
-
|
521
|
-
it "should sleep and flush the dscl cache before saving the password" do
|
522
|
-
expect(provider).to receive(:prepare_password_shadow_info).and_return({})
|
523
|
-
mock_shellout = double("Mock::Shellout")
|
524
|
-
allow(mock_shellout).to receive(:run_command)
|
525
|
-
expect(provider).to receive(:shell_out_compacted).and_return(mock_shellout)
|
526
|
-
expect(provider).to receive(:read_user_info)
|
527
|
-
expect(provider).to receive(:dscl_set)
|
528
|
-
expect(provider).to receive(:sleep).with(3)
|
529
|
-
expect(provider).to receive(:save_user_info)
|
530
|
-
provider.set_password
|
531
|
-
end
|
532
|
-
end
|
533
|
-
|
534
|
-
describe "when the user does not yet exist and chef is creating it" do
|
535
|
-
context "with a numeric gid" do
|
536
|
-
before do
|
537
|
-
new_resource.comment "#mockssuck"
|
538
|
-
new_resource.gid 1001
|
539
|
-
end
|
540
|
-
|
541
|
-
it "creates the user, comment field, sets uid, gid, configures the home directory, sets the shell, and sets the password" do
|
542
|
-
expect(provider).to receive :dscl_create_user
|
543
|
-
expect(provider).to receive :dscl_create_comment
|
544
|
-
expect(provider).to receive :dscl_set_uid
|
545
|
-
expect(provider).to receive :dscl_set_gid
|
546
|
-
expect(provider).to receive :dscl_set_home
|
547
|
-
expect(provider).to receive :dscl_set_shell
|
548
|
-
expect(provider).to receive :set_password
|
549
|
-
provider.create_user
|
550
|
-
end
|
551
|
-
|
552
|
-
it "creates the user and sets the comment field" do
|
553
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor").and_return(true)
|
554
|
-
provider.dscl_create_user
|
555
|
-
end
|
556
|
-
|
557
|
-
it "sets the comment field" do
|
558
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "RealName", "#mockssuck").and_return(true)
|
559
|
-
provider.dscl_create_comment
|
560
|
-
end
|
561
|
-
|
562
|
-
it "sets the comment field to username" do
|
563
|
-
new_resource.comment nil
|
564
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "RealName", "toor").and_return(true)
|
565
|
-
provider.dscl_create_comment
|
566
|
-
end
|
567
|
-
|
568
|
-
it "should run run_dscl with create /Users/user PrimaryGroupID to set the users primary group" do
|
569
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "PrimaryGroupID", 1001).and_return(true)
|
570
|
-
provider.dscl_set_gid
|
571
|
-
end
|
572
|
-
|
573
|
-
it "should run run_dscl with create /Users/user UserShell to set the users login shell" do
|
574
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "UserShell", "/usr/bin/false").and_return(true)
|
575
|
-
provider.dscl_set_shell
|
576
|
-
end
|
577
|
-
end
|
578
|
-
|
579
|
-
context "with a non-numeric gid" do
|
580
|
-
before do
|
581
|
-
new_resource.comment "#mockssuck"
|
582
|
-
new_resource.gid "newgroup"
|
583
|
-
end
|
584
|
-
|
585
|
-
it "should map the group name to a numeric ID when the group exists" do
|
586
|
-
expect(provider).to receive(:run_dscl).with("read", "/Groups/newgroup", "PrimaryGroupID").ordered.and_return("PrimaryGroupID: 1001\n")
|
587
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "PrimaryGroupID", "1001").ordered.and_return(true)
|
588
|
-
provider.dscl_set_gid
|
589
|
-
end
|
590
|
-
|
591
|
-
it "should raise an exception when the group does not exist" do
|
592
|
-
shell_return = shellcmdresult.new("<dscl_cmd> DS Error: -14136 (eDSRecordNotFound)", "err", -14136)
|
593
|
-
expect(provider).to receive(:shell_out_compacted).with("dscl", ".", "-read", "/Groups/newgroup", "PrimaryGroupID").and_return(shell_return)
|
594
|
-
expect { provider.dscl_set_gid }.to raise_error(Chef::Exceptions::GroupIDNotFound)
|
595
|
-
end
|
596
|
-
end
|
597
|
-
|
598
|
-
it "should set group ID to 20 if it's not specified" do
|
599
|
-
new_resource.gid nil
|
600
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "PrimaryGroupID", 20).ordered.and_return(true)
|
601
|
-
provider.dscl_set_gid
|
602
|
-
expect(new_resource.gid).to eq(20)
|
603
|
-
end
|
604
|
-
end
|
605
|
-
|
606
|
-
describe "when the user exists and chef is managing it" do
|
607
|
-
before do
|
608
|
-
current_resource = new_resource.dup
|
609
|
-
provider.current_resource = current_resource
|
610
|
-
|
611
|
-
# These are all different from current_resource
|
612
|
-
new_resource.username "mud"
|
613
|
-
new_resource.uid 2342
|
614
|
-
new_resource.gid 2342
|
615
|
-
new_resource.home "/Users/death"
|
616
|
-
new_resource.password "goaway"
|
617
|
-
end
|
618
|
-
|
619
|
-
it "sets the user, comment field, uid, gid, moves the home directory, sets the shell, and sets the password" do
|
620
|
-
expect(provider).to receive :dscl_create_user
|
621
|
-
expect(provider).to receive :dscl_create_comment
|
622
|
-
expect(provider).to receive :dscl_set_uid
|
623
|
-
expect(provider).to receive :dscl_set_gid
|
624
|
-
expect(provider).to receive :dscl_set_home
|
625
|
-
expect(provider).to receive :dscl_set_shell
|
626
|
-
expect(provider).to receive :set_password
|
627
|
-
provider.create_user
|
628
|
-
end
|
629
|
-
end
|
630
|
-
|
631
|
-
describe "when changing the gid" do
|
632
|
-
before do
|
633
|
-
current_resource = new_resource.dup
|
634
|
-
provider.current_resource = current_resource
|
635
|
-
|
636
|
-
# This is different from current_resource
|
637
|
-
new_resource.gid 2342
|
638
|
-
end
|
639
|
-
|
640
|
-
it "sets the gid" do
|
641
|
-
expect(provider).to receive :dscl_set_gid
|
642
|
-
provider.manage_user
|
643
|
-
end
|
644
|
-
end
|
645
|
-
|
646
|
-
describe "when the user exists" do
|
647
|
-
before do
|
648
|
-
expect(provider).to receive(:shell_out_compacted).with("dscacheutil", "-flushcache")
|
649
|
-
expect(provider).to receive(:shell_out_compacted).with("plutil", "-convert", "xml1", "-o", "-", "/var/db/dslocal/nodes/Default/users/toor.plist") do
|
650
|
-
shellcmdresult.new(File.read(File.join(CHEF_SPEC_DATA, "mac_users/10.9.plist.xml")), "", 0)
|
651
|
-
end
|
652
|
-
provider.load_current_resource
|
653
|
-
end
|
654
|
-
|
655
|
-
describe "when Chef is removing the user" do
|
656
|
-
it "removes the user from the groups and deletes home directory when the resource is configured to manage home" do
|
657
|
-
new_resource.manage_home true
|
658
|
-
expect(provider).to receive(:run_dscl).with("list", "/Groups").and_return("my_group\nyour_group\nreal_group\n")
|
659
|
-
expect(provider).to receive(:run_dscl).with("read", "/Groups/my_group").and_raise(Chef::Exceptions::DsclCommandFailed) # Empty group
|
660
|
-
expect(provider).to receive(:run_dscl).with("read", "/Groups/your_group").and_return("GroupMembership: not_you")
|
661
|
-
expect(provider).to receive(:run_dscl).with("read", "/Groups/real_group").and_return("GroupMembership: toor")
|
662
|
-
expect(provider).to receive(:run_dscl).with("delete", "/Groups/real_group", "GroupMembership", "toor")
|
663
|
-
expect(provider).to receive(:run_dscl).with("delete", "/Users/toor")
|
664
|
-
expect(FileUtils).to receive(:rm_rf).with("/Users/vagrant")
|
665
|
-
provider.remove_user
|
666
|
-
end
|
667
|
-
end
|
668
|
-
|
669
|
-
describe "when user is not locked" do
|
670
|
-
it "determines the user as not locked" do
|
671
|
-
expect(provider).not_to be_locked
|
672
|
-
end
|
673
|
-
end
|
674
|
-
|
675
|
-
describe "when user is locked" do
|
676
|
-
before do
|
677
|
-
auth_authority = provider.instance_variable_get(:@authentication_authority)
|
678
|
-
provider.instance_variable_set(:@authentication_authority, auth_authority + ";DisabledUser;")
|
679
|
-
end
|
680
|
-
|
681
|
-
it "determines the user as not locked" do
|
682
|
-
expect(provider).to be_locked
|
683
|
-
end
|
684
|
-
|
685
|
-
it "can unlock the user" do
|
686
|
-
expect(provider).to receive(:run_dscl).with("create", "/Users/toor", "AuthenticationAuthority", ";ShadowHash;HASHLIST:<SALTED-SHA512-PBKDF2>")
|
687
|
-
provider.unlock_user
|
688
|
-
end
|
689
|
-
end
|
690
|
-
end
|
691
|
-
|
692
|
-
describe "when locking the user" do
|
693
|
-
it "should run run_dscl with append /Users/user AuthenticationAuthority ;DisabledUser; to lock the user account" do
|
694
|
-
expect(provider).to receive(:run_dscl).with("append", "/Users/toor", "AuthenticationAuthority", ";DisabledUser;")
|
695
|
-
provider.lock_user
|
696
|
-
end
|
697
|
-
end
|
698
|
-
|
699
|
-
end
|