chef 16.17.51-universal-mingw32 → 17.0.242-universal-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/Gemfile +9 -13
- data/README.md +1 -1
- data/Rakefile +2 -2
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +6 -8
- data/lib/chef/action_collection.rb +1 -1
- data/lib/chef/application/base.rb +1 -1
- data/lib/chef/application.rb +1 -1
- data/lib/chef/applications.rb +0 -1
- data/lib/chef/chef_fs/command_line.rb +5 -2
- data/lib/chef/chef_fs/file_system.rb +9 -10
- data/lib/chef/client.rb +2 -2
- data/lib/chef/compliance/default_attributes.rb +4 -3
- 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/gem_installer.rb +1 -5
- 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 +4 -26
- data/lib/chef/data_bag_item.rb +11 -2
- data/lib/chef/data_collector/run_end_message.rb +2 -2
- data/lib/chef/delayed_evaluator.rb +4 -0
- data/lib/chef/deprecated.rb +6 -12
- data/lib/chef/dsl/chef_vault.rb +6 -6
- data/lib/chef/dsl/reboot_pending.rb +1 -2
- data/lib/chef/exceptions.rb +0 -3
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +20 -22
- data/lib/chef/formatters/error_mapper.rb +2 -2
- data/lib/chef/group.rb +75 -0
- data/lib/chef/http.rb +5 -5
- data/lib/chef/mixin/get_source_from_package.rb +1 -1
- 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/node.rb +19 -20
- data/lib/chef/org.rb +3 -2
- data/lib/chef/policy_builder/policyfile.rb +0 -5
- data/lib/chef/property.rb +18 -0
- data/lib/chef/provider/cron.rb +1 -1
- data/lib/chef/provider/execute.rb +2 -1
- data/lib/chef/provider/file.rb +1 -1
- data/lib/chef/provider/git.rb +5 -7
- data/lib/chef/provider/group/dscl.rb +1 -1
- 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 +2 -2
- 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/mount.rb +5 -5
- 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 +1 -1
- data/lib/chef/provider/package/portage.rb +2 -2
- data/lib/chef/provider/package/powershell.rb +0 -5
- data/lib/chef/provider/package/rubygems.rb +9 -15
- data/lib/chef/provider/package/windows.rb +2 -4
- data/lib/chef/provider/package/yum/yum_helper.py +1 -1
- data/lib/chef/provider/package.rb +17 -21
- data/lib/chef/provider/route.rb +2 -2
- 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/service.rb +6 -6
- data/lib/chef/provider/subversion.rb +10 -12
- data/lib/chef/provider/systemd_unit.rb +36 -10
- data/lib/chef/provider/template/content.rb +3 -7
- 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/user.rb +2 -2
- data/lib/chef/provider/zypper_repository.rb +2 -2
- data/lib/chef/provider.rb +1 -1
- data/lib/chef/providers.rb +0 -1
- 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 +3 -2
- data/lib/chef/resource/archive_file.rb +8 -9
- 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 +2 -2
- data/lib/chef/resource/chef_client_cron.rb +4 -4
- data/lib/chef/resource/chef_client_launchd.rb +3 -3
- data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
- data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
- data/lib/chef/resource/chef_client_trusted_certificate.rb +0 -1
- 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 +3 -8
- 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_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/execute.rb +6 -1
- data/lib/chef/resource/file.rb +1 -1
- data/lib/chef/resource/group.rb +2 -2
- data/lib/chef/resource/homebrew_cask.rb +5 -15
- data/lib/chef/resource/homebrew_tap.rb +2 -6
- data/lib/chef/resource/hostname.rb +21 -17
- data/lib/chef/resource/http_request.rb +1 -1
- data/lib/chef/resource/kernel_module.rb +6 -17
- data/lib/chef/resource/locale.rb +2 -3
- data/lib/chef/resource/lwrp_base.rb +4 -0
- data/lib/chef/resource/macos_userdefaults.rb +10 -14
- data/lib/chef/resource/mdadm.rb +53 -7
- data/lib/chef/resource/mount.rb +3 -2
- data/lib/chef/resource/openssl_ec_private_key.rb +2 -2
- data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
- data/lib/chef/resource/openssl_x509_certificate.rb +2 -2
- data/lib/chef/resource/plist.rb +7 -7
- data/lib/chef/resource/powershell_script.rb +1 -1
- data/lib/chef/resource/remote_file.rb +1 -1
- data/lib/chef/resource/rhsm_errata.rb +16 -1
- data/lib/chef/resource/rhsm_errata_level.rb +10 -1
- data/lib/chef/resource/rhsm_register.rb +12 -6
- data/lib/chef/resource/rhsm_repo.rb +2 -6
- data/lib/chef/resource/rhsm_subscription.rb +7 -11
- data/lib/chef/resource/scm/git.rb +1 -1
- data/lib/chef/resource/sudo.rb +6 -6
- data/lib/chef/resource/support/client.erb +0 -6
- data/lib/chef/resource/sysctl.rb +2 -6
- data/lib/chef/resource/systemd_unit.rb +3 -3
- 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 -3
- data/lib/chef/resource/windows_ad_join.rb +2 -6
- data/lib/chef/resource/windows_audit_policy.rb +1 -1
- data/lib/chef/resource/windows_auto_run.rb +2 -5
- data/lib/chef/resource/windows_certificate.rb +207 -73
- 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 +5 -4
- data/lib/chef/resource/windows_feature.rb +3 -9
- data/lib/chef/resource/windows_feature_dism.rb +2 -6
- 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 +2 -5
- data/lib/chef/resource/windows_font.rb +2 -4
- data/lib/chef/resource/windows_pagefile.rb +2 -6
- data/lib/chef/resource/windows_path.rb +2 -2
- data/lib/chef/resource/windows_printer.rb +4 -4
- data/lib/chef/resource/windows_printer_port.rb +6 -6
- data/lib/chef/resource/windows_security_policy.rb +9 -12
- 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 +17 -5
- data/lib/chef/resource/windows_uac.rb +2 -4
- data/lib/chef/resource/windows_user_privilege.rb +5 -5
- data/lib/chef/resource/windows_workgroup.rb +1 -2
- data/lib/chef/resource.rb +1 -1
- data/lib/chef/resource_reporter.rb +1 -1
- data/lib/chef/resources.rb +0 -1
- 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 +2 -9
- data/lib/chef/win32/registry.rb +4 -2
- data/lib/chef/win32/version.rb +1 -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/resources/resource.rb +2 -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/functional/dsl/registry_helper_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 +4 -1
- data/spec/functional/resource/group_spec.rb +1 -5
- data/spec/functional/resource/link_spec.rb +0 -8
- data/spec/functional/resource/registry_spec.rb +8 -8
- data/spec/functional/resource/user/mac_user_spec.rb +2 -2
- data/spec/functional/resource/windows_certificate_spec.rb +92 -35
- 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 -2
- 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 +9 -9
- data/spec/integration/recipes/unified_mode_spec.rb +1 -1
- data/spec/integration/recipes/use_partial_spec.rb +4 -1
- data/spec/spec_helper.rb +10 -13
- data/spec/support/chef_helpers.rb +0 -16
- 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/integration/integration_helper.rb +0 -1
- 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_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 +30 -4
- data/spec/unit/cookbook_version_spec.rb +0 -52
- data/spec/unit/data_bag_item_spec.rb +1 -6
- data/spec/unit/data_collector_spec.rb +2 -71
- data/spec/unit/dsl/reboot_pending_spec.rb +2 -2
- data/spec/unit/dsl/registry_helper_spec.rb +1 -1
- 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/policyfile_spec.rb +1 -11
- data/spec/unit/property_spec.rb +23 -22
- 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/package/apt_spec.rb +84 -18
- data/spec/unit/provider/package/deb_spec.rb +3 -3
- data/spec/unit/provider/package/powershell_spec.rb +12 -74
- data/spec/unit/provider/package/rubygems_spec.rb +18 -30
- 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 +2 -2
- data/spec/unit/provider_spec.rb +0 -8
- data/spec/unit/resource/archive_file_spec.rb +1 -13
- data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +0 -14
- data/spec/unit/resource/homebrew_cask_spec.rb +11 -29
- data/spec/unit/resource/mount_spec.rb +0 -10
- data/spec/unit/resource/powershell_script_spec.rb +2 -2
- data/spec/unit/resource/rhsm_subscription_spec.rb +3 -50
- data/spec/unit/resource/systemd_unit_spec.rb +1 -1
- data/spec/unit/resource/user_ulimit_spec.rb +1 -14
- data/spec/unit/resource/windows_task_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +0 -5
- data/spec/unit/user_spec.rb +1 -1
- data/spec/unit/user_v1_spec.rb +6 -4
- data/tasks/rspec.rb +15 -7
- metadata +19 -382
- 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/flatten_enumerable.rb +0 -35
- data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +0 -278
- data/lib/chef/chef_fs/parallelizer.rb +0 -102
- data/lib/chef/cookbook_site_streaming_uploader.rb +0 -244
- 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/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/bootstrap.rb +0 -1192
- 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 -405
- 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_list.rb +0 -43
- 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/recipe_list.rb +0 -32
- 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/knife.rb +0 -665
- data/lib/chef/resource/user/dscl_user.rb +0 -35
- data/spec/data/knife-home/.chef/plugins/knife/example_home_subcommand.rb +0 -0
- data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
- data/spec/data/knife_subcommand/test_explicit_category.rb +0 -7
- data/spec/data/knife_subcommand/test_name_mapping.rb +0 -4
- data/spec/data/knife_subcommand/test_yourself.rb +0 -21
- 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 -1616
- data/spec/support/shared/functional/knife.rb +0 -37
- data/spec/support/shared/functional/win32_service.rb +0 -57
- data/spec/support/shared/integration/knife_support.rb +0 -192
- data/spec/support/shared/unit/knife_shared.rb +0 -39
- 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
@@ -72,7 +72,6 @@ class Chef
|
|
72
72
|
# A rubygems specification object containing the list of gemspecs for all
|
73
73
|
# available gems in the gem installation.
|
74
74
|
# Implemented by subclasses
|
75
|
-
# For rubygems >= 1.8.0
|
76
75
|
#
|
77
76
|
# @return [Gem::Specification]
|
78
77
|
#
|
@@ -107,10 +106,8 @@ class Chef
|
|
107
106
|
# This isn't sorting before returning because the only code that
|
108
107
|
# uses this method calls `max_by` so it doesn't need to be sorted.
|
109
108
|
stubs
|
110
|
-
|
109
|
+
else # >= rubygems 1.8 behavior
|
111
110
|
gem_specification.find_all_by_name(gem_dep.name, gem_dep.requirement)
|
112
|
-
else
|
113
|
-
gem_source_index.search(gem_dep)
|
114
111
|
end
|
115
112
|
end
|
116
113
|
|
@@ -192,7 +189,8 @@ class Chef
|
|
192
189
|
begin
|
193
190
|
rs = dependency_installer.resolve_dependencies gem_dependency.name, gem_dependency.requirement
|
194
191
|
rs.specs.find { |s| s.name == gem_dependency.name }
|
195
|
-
|
192
|
+
# ruby-3.0.0 versions of rubygems-3.x throws NoMethodError when the dep is not found
|
193
|
+
rescue Gem::UnsatisfiableDependencyError, NoMethodError
|
196
194
|
nil
|
197
195
|
end
|
198
196
|
end
|
@@ -481,9 +479,7 @@ class Chef
|
|
481
479
|
end
|
482
480
|
|
483
481
|
def all_installed_versions
|
484
|
-
@all_installed_versions ||=
|
485
|
-
@gem_env.installed_versions(Gem::Dependency.new(gem_dependency.name, ">= 0"))
|
486
|
-
end
|
482
|
+
@all_installed_versions ||= @gem_env.installed_versions(Gem::Dependency.new(gem_dependency.name, ">= 0"))
|
487
483
|
end
|
488
484
|
|
489
485
|
##
|
@@ -523,13 +519,11 @@ class Chef
|
|
523
519
|
end
|
524
520
|
|
525
521
|
def candidate_version
|
526
|
-
@candidate_version ||=
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
end
|
532
|
-
end
|
522
|
+
@candidate_version ||= if source_is_remote?
|
523
|
+
@gem_env.candidate_version_from_remote(gem_dependency, *gem_sources).to_s
|
524
|
+
else
|
525
|
+
@gem_env.candidate_version_from_file(gem_dependency, new_resource.source).to_s
|
526
|
+
end
|
533
527
|
end
|
534
528
|
|
535
529
|
def version_requirement_satisfied?(current_version, new_version)
|
@@ -70,8 +70,7 @@ class Chef
|
|
70
70
|
end
|
71
71
|
|
72
72
|
def package_provider
|
73
|
-
@package_provider ||=
|
74
|
-
case installer_type
|
73
|
+
@package_provider ||= case installer_type
|
75
74
|
when :msi
|
76
75
|
logger.trace("#{new_resource} is MSI")
|
77
76
|
require_relative "windows/msi"
|
@@ -80,8 +79,7 @@ class Chef
|
|
80
79
|
logger.trace("#{new_resource} is EXE with type '#{installer_type}'")
|
81
80
|
require_relative "windows/exe"
|
82
81
|
Chef::Provider::Package::Windows::Exe.new(resource_for_provider, installer_type, uninstall_registry_entries)
|
83
|
-
|
84
|
-
end
|
82
|
+
end
|
85
83
|
end
|
86
84
|
|
87
85
|
def installer_type
|
@@ -109,7 +109,7 @@ class Chef
|
|
109
109
|
|
110
110
|
action :install do
|
111
111
|
unless target_version_array.any?
|
112
|
-
logger.
|
112
|
+
logger.debug("#{new_resource} is already installed - nothing to do")
|
113
113
|
return
|
114
114
|
end
|
115
115
|
|
@@ -138,7 +138,7 @@ class Chef
|
|
138
138
|
|
139
139
|
action :upgrade do
|
140
140
|
unless target_version_array.any?
|
141
|
-
logger.
|
141
|
+
logger.debug("#{new_resource} no versions to upgrade - nothing to do")
|
142
142
|
return
|
143
143
|
end
|
144
144
|
|
@@ -177,7 +177,7 @@ class Chef
|
|
177
177
|
logger.info("#{new_resource} removed")
|
178
178
|
end
|
179
179
|
else
|
180
|
-
logger.
|
180
|
+
logger.debug("#{new_resource} package does not exist - nothing to do")
|
181
181
|
end
|
182
182
|
end
|
183
183
|
|
@@ -229,7 +229,7 @@ class Chef
|
|
229
229
|
end
|
230
230
|
end
|
231
231
|
else
|
232
|
-
logger.
|
232
|
+
logger.debug("#{new_resource} is already locked")
|
233
233
|
end
|
234
234
|
end
|
235
235
|
|
@@ -248,7 +248,7 @@ class Chef
|
|
248
248
|
end
|
249
249
|
end
|
250
250
|
else
|
251
|
-
logger.
|
251
|
+
logger.debug("#{new_resource} is already unlocked")
|
252
252
|
end
|
253
253
|
end
|
254
254
|
|
@@ -598,12 +598,10 @@ class Chef
|
|
598
598
|
# @return [Array] new_resource.source as an array
|
599
599
|
def source_array
|
600
600
|
@source_array ||=
|
601
|
-
|
602
|
-
|
603
|
-
|
604
|
-
|
605
|
-
[ new_resource.source ].flatten
|
606
|
-
end
|
601
|
+
if new_resource.source.nil?
|
602
|
+
package_name_array.map { nil }
|
603
|
+
else
|
604
|
+
[ new_resource.source ].flatten
|
607
605
|
end
|
608
606
|
end
|
609
607
|
|
@@ -612,16 +610,14 @@ class Chef
|
|
612
610
|
# @return [Array] Array of sources with package_names converted to sources
|
613
611
|
def resolved_source_array
|
614
612
|
@resolved_source_array ||=
|
615
|
-
|
616
|
-
|
617
|
-
|
618
|
-
|
619
|
-
|
620
|
-
|
621
|
-
|
622
|
-
|
623
|
-
source
|
624
|
-
end
|
613
|
+
source_array.each_with_index.map do |source, i|
|
614
|
+
package_name = package_name_array[i]
|
615
|
+
# we require at least one '/' in the package_name to avoid [XXX_]package 'foo' breaking due to a random 'foo' file in cwd
|
616
|
+
if use_package_name_for_source? && source.nil? && package_name.match(/#{::File::SEPARATOR}/) && ::File.exist?(package_name)
|
617
|
+
logger.trace("No package source specified, but #{package_name} exists on filesystem, using #{package_name} as source.")
|
618
|
+
package_name
|
619
|
+
else
|
620
|
+
source
|
625
621
|
end
|
626
622
|
end
|
627
623
|
end
|
data/lib/chef/provider/route.rb
CHANGED
@@ -131,7 +131,7 @@ class Chef
|
|
131
131
|
action :add do
|
132
132
|
# check to see if load_current_resource found the route
|
133
133
|
if is_running
|
134
|
-
logger.
|
134
|
+
logger.debug("#{new_resource} route already active - nothing to do")
|
135
135
|
else
|
136
136
|
command = generate_command(:add)
|
137
137
|
converge_by("run #{command.join(" ")} to add route") do
|
@@ -152,7 +152,7 @@ class Chef
|
|
152
152
|
logger.info("#{new_resource} removed")
|
153
153
|
end
|
154
154
|
else
|
155
|
-
logger.
|
155
|
+
logger.debug("#{new_resource} route does not exist - nothing to do")
|
156
156
|
end
|
157
157
|
|
158
158
|
# for now we always write the file (ugly but its what it is)
|
@@ -45,7 +45,7 @@ class Chef
|
|
45
45
|
priority_ok = @current_resource.priority == @new_resource.priority
|
46
46
|
end
|
47
47
|
if @current_resource.enabled && priority_ok
|
48
|
-
logger.
|
48
|
+
logger.debug("#{@new_resource} already enabled - nothing to do")
|
49
49
|
else
|
50
50
|
converge_by("enable service #{@new_resource}") do
|
51
51
|
enable_service
|
@@ -138,7 +138,7 @@ class Chef
|
|
138
138
|
priority_ok = @current_resource.priority == new_resource.priority
|
139
139
|
end
|
140
140
|
if current_resource.enabled && priority_ok
|
141
|
-
logger.
|
141
|
+
logger.debug("#{new_resource} already enabled - nothing to do")
|
142
142
|
else
|
143
143
|
converge_by("enable service #{new_resource}") do
|
144
144
|
enable_service
|
@@ -130,27 +130,21 @@ class Chef
|
|
130
130
|
# The variable name used in /etc/rc.conf for enabling this service
|
131
131
|
def service_enable_variable_name
|
132
132
|
@service_enable_variable_name ||=
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
if init_command
|
139
|
-
::File.open(init_command) do |rcscript|
|
140
|
-
rcscript.each_line do |line|
|
141
|
-
if line =~ /^name="?(\w+)"?/
|
142
|
-
return $1 + "_enable"
|
143
|
-
end
|
133
|
+
if init_command
|
134
|
+
::File.open(init_command) do |rcscript|
|
135
|
+
rcscript.each_line do |line|
|
136
|
+
if line =~ /^name="?(\w+)"?/
|
137
|
+
return $1 + "_enable"
|
144
138
|
end
|
145
139
|
end
|
146
|
-
# some scripts support multiple instances through symlinks such as openvpn.
|
147
|
-
# We should get the service name from rcvar.
|
148
|
-
logger.trace("name=\"service\" not found at #{init_command}. falling back to rcvar")
|
149
|
-
shell_out!("#{init_command} rcvar").stdout[/(\w+_enable)=/, 1]
|
150
|
-
else
|
151
|
-
# for why-run mode when the rcd_script is not there yet
|
152
|
-
new_resource.service_name
|
153
140
|
end
|
141
|
+
# some scripts support multiple instances through symlinks such as openvpn.
|
142
|
+
# We should get the service name from rcvar.
|
143
|
+
logger.trace("name=\"service\" not found at #{init_command}. falling back to rcvar")
|
144
|
+
shell_out!("#{init_command} rcvar").stdout[/(\w+_enable)=/, 1]
|
145
|
+
else
|
146
|
+
# for why-run mode when the rcd_script is not there yet
|
147
|
+
new_resource.service_name
|
154
148
|
end
|
155
149
|
end
|
156
150
|
|
@@ -161,9 +155,9 @@ class Chef
|
|
161
155
|
case line
|
162
156
|
when /^#{Regexp.escape(var_name)}="(\w+)"/
|
163
157
|
enabled_state_found!
|
164
|
-
if $1
|
158
|
+
if $1.casecmp?("yes")
|
165
159
|
current_resource.enabled true
|
166
|
-
elsif $1
|
160
|
+
elsif $1.casecmp?("no") || $1.casecmp?("none")
|
167
161
|
current_resource.enabled false
|
168
162
|
end
|
169
163
|
end
|
@@ -171,7 +165,7 @@ class Chef
|
|
171
165
|
end
|
172
166
|
|
173
167
|
if current_resource.enabled.nil?
|
174
|
-
logger.
|
168
|
+
logger.debug("#{new_resource.name} enable/disable state unknown")
|
175
169
|
current_resource.enabled false
|
176
170
|
end
|
177
171
|
end
|
@@ -105,7 +105,7 @@ class Chef
|
|
105
105
|
|
106
106
|
def start_service
|
107
107
|
if @current_resource.running
|
108
|
-
logger.
|
108
|
+
logger.debug("#{@new_resource} already running, not starting")
|
109
109
|
else
|
110
110
|
if @new_resource.start_command
|
111
111
|
super
|
@@ -117,7 +117,7 @@ class Chef
|
|
117
117
|
|
118
118
|
def stop_service
|
119
119
|
unless @current_resource.running
|
120
|
-
logger.
|
120
|
+
logger.debug("#{@new_resource} not running, not stopping")
|
121
121
|
else
|
122
122
|
if @new_resource.stop_command
|
123
123
|
super
|
@@ -153,7 +153,7 @@ class Chef
|
|
153
153
|
#
|
154
154
|
def enable_service
|
155
155
|
if @current_resource.enabled
|
156
|
-
logger.
|
156
|
+
logger.debug("#{@new_resource} already enabled, not enabling")
|
157
157
|
else
|
158
158
|
load_service
|
159
159
|
end
|
@@ -161,7 +161,7 @@ class Chef
|
|
161
161
|
|
162
162
|
def disable_service
|
163
163
|
unless @current_resource.enabled
|
164
|
-
logger.
|
164
|
+
logger.debug("#{@new_resource} not enabled, not disabling")
|
165
165
|
else
|
166
166
|
unload_service
|
167
167
|
end
|
@@ -76,6 +76,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
76
76
|
end
|
77
77
|
end
|
78
78
|
|
79
|
+
def systemd_service_status
|
80
|
+
@systemd_service_status ||= begin
|
81
|
+
# Collect all the status information for a service and returns it at once
|
82
|
+
options, args = get_systemctl_options_args
|
83
|
+
s = shell_out!(systemctl_path, args, "show", "-p", "UnitFileState", "-p", "ActiveState", new_resource.service_name, options)
|
84
|
+
# e.g. /bin/systemctl --system show -p UnitFileState -p ActiveState sshd.service
|
85
|
+
# Returns something like:
|
86
|
+
# ActiveState=active
|
87
|
+
# UnitFileState=enabled
|
88
|
+
status = {}
|
89
|
+
s.stdout.each_line do |line|
|
90
|
+
k, v = line.strip.split("=")
|
91
|
+
status[k] = v
|
92
|
+
end
|
93
|
+
|
94
|
+
# Assert requisite keys exist
|
95
|
+
unless status.key?("UnitFileState") && status.key?("ActiveState")
|
96
|
+
raise Chef::Exceptions::Service, "'#{systemctl_path} show' not reporting status for #{new_resource.service_name}!"
|
97
|
+
end
|
98
|
+
|
99
|
+
status
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
79
103
|
def get_systemctl_options_args
|
80
104
|
if new_resource.user
|
81
105
|
raise NotImplementedError, "#{new_resource} does not support the user property on a target_mode host (yet)" if Chef::Config.target_mode?
|
@@ -98,7 +122,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
98
122
|
|
99
123
|
def start_service
|
100
124
|
if current_resource.running
|
101
|
-
logger.
|
125
|
+
logger.debug("#{new_resource} already running, not starting")
|
102
126
|
else
|
103
127
|
if new_resource.start_command
|
104
128
|
super
|
@@ -111,7 +135,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
111
135
|
|
112
136
|
def stop_service
|
113
137
|
unless current_resource.running
|
114
|
-
logger.
|
138
|
+
logger.debug("#{new_resource} not running, not stopping")
|
115
139
|
else
|
116
140
|
if new_resource.stop_command
|
117
141
|
super
|
@@ -146,7 +170,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
146
170
|
|
147
171
|
def enable_service
|
148
172
|
if current_resource.masked || current_resource.indirect
|
149
|
-
logger.
|
173
|
+
logger.debug("#{new_resource} cannot be enabled: it is masked or indirect")
|
150
174
|
return
|
151
175
|
end
|
152
176
|
options, args = get_systemctl_options_args
|
@@ -155,7 +179,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
155
179
|
|
156
180
|
def disable_service
|
157
181
|
if current_resource.masked || current_resource.indirect
|
158
|
-
logger.
|
182
|
+
logger.debug("#{new_resource} cannot be disabled: it is masked or indirect")
|
159
183
|
return
|
160
184
|
end
|
161
185
|
options, args = get_systemctl_options_args
|
@@ -173,25 +197,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
|
|
173
197
|
end
|
174
198
|
|
175
199
|
def is_active?
|
176
|
-
|
177
|
-
|
200
|
+
# Note: "activating" is not active (as with type=notify or a oneshot)
|
201
|
+
systemd_service_status["ActiveState"] == "active"
|
178
202
|
end
|
179
203
|
|
180
204
|
def is_enabled?
|
181
|
-
|
182
|
-
|
205
|
+
# if the service is in sysv compat mode, shellout to determine if enabled
|
206
|
+
if systemd_service_status["UnitFileState"] == "bad"
|
207
|
+
options, args = get_systemctl_options_args
|
208
|
+
return shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, "--quiet", **options).exitstatus == 0
|
209
|
+
end
|
210
|
+
# See https://github.com/systemd/systemd/blob/master/src/systemctl/systemctl-is-enabled.c
|
211
|
+
# Note: enabled-runtime is excluded because this is volatile, and the state of enabled-runtime
|
212
|
+
# specifically means that the service is not enabled
|
213
|
+
%w{enabled static generated alias indirect}.include?(systemd_service_status["UnitFileState"])
|
183
214
|
end
|
184
215
|
|
185
216
|
def is_indirect?
|
186
|
-
|
187
|
-
s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
|
188
|
-
s.stdout.include?("indirect")
|
217
|
+
systemd_service_status["UnitFileState"] == "indirect"
|
189
218
|
end
|
190
219
|
|
191
220
|
def is_masked?
|
192
|
-
|
193
|
-
|
194
|
-
|
221
|
+
# Note: masked-runtime is excluded, because runtime is volatile, and
|
222
|
+
# because masked-runtime is not masked.
|
223
|
+
systemd_service_status["UnitFileState"] == "masked"
|
195
224
|
end
|
196
225
|
|
197
226
|
private
|
@@ -28,10 +28,6 @@ class Chef
|
|
28
28
|
# to maintain a local state of service across restart's internal calls
|
29
29
|
attr_accessor :upstart_service_running
|
30
30
|
|
31
|
-
provides :service, platform_family: "debian", override: true do
|
32
|
-
upstart?
|
33
|
-
end
|
34
|
-
|
35
31
|
UPSTART_STATE_FORMAT = %r{\S+ \(?(start|stop)?\)? ?[/ ](\w+)}.freeze
|
36
32
|
|
37
33
|
# Returns true if the configs for the service name has upstart variable
|
@@ -65,15 +61,8 @@ class Chef
|
|
65
61
|
end
|
66
62
|
end
|
67
63
|
|
68
|
-
|
69
|
-
|
70
|
-
@upstart_job_dir = "/etc/event.d"
|
71
|
-
@upstart_conf_suffix = ""
|
72
|
-
else
|
73
|
-
@upstart_job_dir = "/etc/init"
|
74
|
-
@upstart_conf_suffix = ".conf"
|
75
|
-
end
|
76
|
-
|
64
|
+
@upstart_job_dir = "/etc/init"
|
65
|
+
@upstart_conf_suffix = ".conf"
|
77
66
|
@command_success = true # new_resource.status_command= false, means upstart used
|
78
67
|
@config_file_found = true
|
79
68
|
@upstart_command_success = true
|
@@ -85,7 +85,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
85
85
|
|
86
86
|
state = current_state
|
87
87
|
if state == RUNNING
|
88
|
-
logger.
|
88
|
+
logger.debug "#{@new_resource} already started - nothing to do"
|
89
89
|
elsif state == START_PENDING
|
90
90
|
logger.trace "#{@new_resource} already sent start signal - waiting for start"
|
91
91
|
wait_for_state(RUNNING)
|
@@ -114,7 +114,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
114
114
|
raise Chef::Exceptions::Service, "Service #{@new_resource} can't be started from state [#{state}]"
|
115
115
|
end
|
116
116
|
else
|
117
|
-
logger.
|
117
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
118
118
|
end
|
119
119
|
end
|
120
120
|
|
@@ -133,7 +133,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
133
133
|
end
|
134
134
|
@new_resource.updated_by_last_action(true)
|
135
135
|
elsif state == STOPPED
|
136
|
-
logger.
|
136
|
+
logger.debug "#{@new_resource} already stopped - nothing to do"
|
137
137
|
elsif state == STOP_PENDING
|
138
138
|
logger.trace "#{@new_resource} already sent stop signal - waiting for stop"
|
139
139
|
wait_for_state(STOPPED)
|
@@ -141,7 +141,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
141
141
|
raise Chef::Exceptions::Service, "Service #{@new_resource} can't be stopped from state [#{state}]"
|
142
142
|
end
|
143
143
|
else
|
144
|
-
logger.
|
144
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
145
145
|
end
|
146
146
|
end
|
147
147
|
|
@@ -156,7 +156,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
156
156
|
end
|
157
157
|
@new_resource.updated_by_last_action(true)
|
158
158
|
else
|
159
|
-
logger.
|
159
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
160
160
|
end
|
161
161
|
end
|
162
162
|
|
@@ -164,7 +164,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
164
164
|
if Win32::Service.exists?(@new_resource.service_name)
|
165
165
|
set_startup_type(:automatic)
|
166
166
|
else
|
167
|
-
logger.
|
167
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
168
168
|
end
|
169
169
|
end
|
170
170
|
|
@@ -172,13 +172,13 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
172
172
|
if Win32::Service.exists?(@new_resource.service_name)
|
173
173
|
set_startup_type(:disabled)
|
174
174
|
else
|
175
|
-
logger.
|
175
|
+
logger.debug "#{@new_resource} does not exist - nothing to do"
|
176
176
|
end
|
177
177
|
end
|
178
178
|
|
179
179
|
action :create do
|
180
180
|
if Win32::Service.exists?(new_resource.service_name)
|
181
|
-
logger.
|
181
|
+
logger.debug "#{new_resource} already exists - nothing to do"
|
182
182
|
return
|
183
183
|
end
|
184
184
|
|
@@ -191,7 +191,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
191
191
|
|
192
192
|
action :delete do
|
193
193
|
unless Win32::Service.exists?(new_resource.service_name)
|
194
|
-
logger.
|
194
|
+
logger.debug "#{new_resource} does not exist - nothing to do"
|
195
195
|
return
|
196
196
|
end
|
197
197
|
|
@@ -222,7 +222,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
222
222
|
logger.info("#{@new_resource} enabled")
|
223
223
|
end
|
224
224
|
else
|
225
|
-
logger.
|
225
|
+
logger.debug("#{@new_resource} already enabled - nothing to do")
|
226
226
|
end
|
227
227
|
load_new_resource_state
|
228
228
|
@new_resource.enabled(true)
|
@@ -235,7 +235,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
235
235
|
logger.info("#{@new_resource} disabled")
|
236
236
|
end
|
237
237
|
else
|
238
|
-
logger.
|
238
|
+
logger.debug("#{@new_resource} already disabled - nothing to do")
|
239
239
|
end
|
240
240
|
load_new_resource_state
|
241
241
|
@new_resource.enabled(false)
|
@@ -248,7 +248,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
|
|
248
248
|
set_startup_type(startup_type)
|
249
249
|
end
|
250
250
|
else
|
251
|
-
logger.
|
251
|
+
logger.debug("#{@new_resource} startup_type already #{startup_type} - nothing to do")
|
252
252
|
end
|
253
253
|
|
254
254
|
converge_delayed_start
|
@@ -82,7 +82,7 @@ class Chef
|
|
82
82
|
|
83
83
|
action :enable do
|
84
84
|
if current_resource.enabled
|
85
|
-
logger.
|
85
|
+
logger.debug("#{new_resource} already enabled - nothing to do")
|
86
86
|
else
|
87
87
|
converge_by("enable service #{new_resource}") do
|
88
88
|
enable_service
|
@@ -100,7 +100,7 @@ class Chef
|
|
100
100
|
logger.info("#{new_resource} disabled")
|
101
101
|
end
|
102
102
|
else
|
103
|
-
logger.
|
103
|
+
logger.debug("#{new_resource} already disabled - nothing to do")
|
104
104
|
end
|
105
105
|
load_new_resource_state
|
106
106
|
new_resource.enabled(false)
|
@@ -108,7 +108,7 @@ class Chef
|
|
108
108
|
|
109
109
|
action :mask do
|
110
110
|
if current_resource.masked
|
111
|
-
logger.
|
111
|
+
logger.debug("#{new_resource} already masked - nothing to do")
|
112
112
|
else
|
113
113
|
converge_by("mask service #{new_resource}") do
|
114
114
|
mask_service
|
@@ -126,7 +126,7 @@ class Chef
|
|
126
126
|
logger.info("#{new_resource} unmasked")
|
127
127
|
end
|
128
128
|
else
|
129
|
-
logger.
|
129
|
+
logger.debug("#{new_resource} already unmasked - nothing to do")
|
130
130
|
end
|
131
131
|
load_new_resource_state
|
132
132
|
new_resource.masked(false)
|
@@ -139,7 +139,7 @@ class Chef
|
|
139
139
|
logger.info("#{new_resource} started")
|
140
140
|
end
|
141
141
|
else
|
142
|
-
logger.
|
142
|
+
logger.debug("#{new_resource} already running - nothing to do")
|
143
143
|
end
|
144
144
|
load_new_resource_state
|
145
145
|
new_resource.running(true)
|
@@ -152,7 +152,7 @@ class Chef
|
|
152
152
|
logger.info("#{new_resource} stopped")
|
153
153
|
end
|
154
154
|
else
|
155
|
-
logger.
|
155
|
+
logger.debug("#{new_resource} already stopped - nothing to do")
|
156
156
|
end
|
157
157
|
load_new_resource_state
|
158
158
|
new_resource.running(false)
|
@@ -61,7 +61,7 @@ class Chef
|
|
61
61
|
shell_out!(checkout_command, run_options)
|
62
62
|
end
|
63
63
|
else
|
64
|
-
logger.
|
64
|
+
logger.debug "#{new_resource} checkout destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
|
65
65
|
end
|
66
66
|
end
|
67
67
|
|
@@ -69,7 +69,7 @@ class Chef
|
|
69
69
|
if target_dir_non_existent_or_empty?
|
70
70
|
action_force_export
|
71
71
|
else
|
72
|
-
logger.
|
72
|
+
logger.debug "#{new_resource} export destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
|
73
73
|
end
|
74
74
|
end
|
75
75
|
|
@@ -121,16 +121,14 @@ class Chef
|
|
121
121
|
# up the revision id by asking the server
|
122
122
|
# If the specified revision is an integer, trust it.
|
123
123
|
def revision_int
|
124
|
-
@revision_int ||=
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
end
|
133
|
-
end
|
124
|
+
@revision_int ||= if /^\d+$/.match?(new_resource.revision)
|
125
|
+
new_resource.revision
|
126
|
+
else
|
127
|
+
command = scm(:info, new_resource.repository, new_resource.svn_info_args, authentication, "-r#{new_resource.revision}")
|
128
|
+
svn_info = shell_out!(command, run_options(cwd: cwd, returns: [0, 1])).stdout
|
129
|
+
|
130
|
+
extract_revision_info(svn_info)
|
131
|
+
end
|
134
132
|
end
|
135
133
|
|
136
134
|
alias :revision_slug :revision_int
|