cookstyle 8.5.2 → 8.6.4
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/config/chefstyle.yml +11 -3
- data/config/cookstyle.yml +159 -151
- data/cookstyle.gemspec +1 -1
- data/lib/cookstyle/version.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/block_guard_clause_string_only.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/chef_application_fatal.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/conditional_ruby_shellout.rb +3 -3
- data/lib/rubocop/cop/chef/correctness/dnf_package_allow_downgrades.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/empty_resource_guard.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/incorrect_library_injection.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_cookbook_name.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_default_action.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_notification_resource.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_notification_timing.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_platform_family_helper.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_platform_family_values_in_case.rb +1 -1
- data/lib/rubocop/cop/chef/correctness/invalid_platform_helper.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_platform_metadata.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_platform_values_in_case.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_value_for_platform_family_helper.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_value_for_platform_helper.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/invalid_version_metadata.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/lazy_eval_node_attribute_defaults.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/lazy_in_resource_guard.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/macos_userdefaults_invalid_type.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/malformed_value_for_platform.rb +3 -3
- data/lib/rubocop/cop/chef/correctness/metadata_malformed_version.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/metadata_missing_name.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/metadata_missing_version.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/node_normal.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/node_normal_unless.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/node_save.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/notifies_action_not_symbol.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/octal_mode_as_string.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/openssl_password_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/powershell_delete_file.rb +1 -1
- data/lib/rubocop/cop/chef/correctness/powershell_file_exists.rb +4 -4
- data/lib/rubocop/cop/chef/correctness/property_without_type.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/resource_sets_internal_properties.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/resource_sets_name_property.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/resource_with_none_action.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/scoped_file_exist.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/service_resource.rb +1 -1
- data/lib/rubocop/cop/chef/correctness/supports_must_be_float.rb +2 -2
- data/lib/rubocop/cop/chef/correctness/tmp_path.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/cb_depends_on_self.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/chef_handler_recipe.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/chef_handler_supports.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/chef_rest.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/chef_shellout.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/chef_sugar_helpers.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/chef_windows_platform_helper.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/chefdk_generators.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/chefspec_coverage_report.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/chefspec_legacy_runner.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/chocolatey_package_uninstall_action.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/depends_chef_nginx_cookbook.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/depends_chef_reporting_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/depends_compat_resource.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/depends_omnibus_updater_cookbook.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/depends_partial_search.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/depends_poise.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/deprecated_chefspec_platform.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/deprecated_mixins.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/deprecated_platform_methods.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/deprecated_shellout_methods.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/deprecated_sudo_actions.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/deprecated_windows_version_check.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/deprecated_yum_repository_actions.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/deprecated_yum_repository_properties.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/easy_install.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/eol_audit_mode.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/epic_fail.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/erl_call.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/execute_path_property.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/execute_relative_creates_without_cwd.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/foodcritic_testing.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/hwrp_without_provides.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/hwrp_without_unified_mode_true.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/inherits_compat_resource.rb +8 -8
- data/lib/rubocop/cop/chef/deprecation/launchd_deprecated_hash_property.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/legacy_notify_syntax.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/legacy_yum_cookbook_recipes.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/librarian_chefspec.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/locale_lc_all_property.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/log_resource_notifications.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/macos_userdefaults_global_property.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/name_property_and_default.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/node_deep_fetch.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/node_methods_not_attributes.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/node_set.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/node_set_unless.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/node_set_without_level.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/partial_search_class_usage.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/partial_search_helper_usage.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/poise_archive.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/policyfile_community_source.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/powershell_cookbook_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/require_recipe.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/resource_overrides_provides_method.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/resource_uses_dsl_name_method.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/resource_uses_only_resource_name.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/resource_uses_provider_base_method.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/resource_uses_updated_method.rb +3 -2
- data/lib/rubocop/cop/chef/deprecation/resource_without_unified_mode_true.rb +3 -3
- data/lib/rubocop/cop/chef/deprecation/ruby_27_keyword_argument_warnings.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/ruby_block_create_action.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/run_command_helper.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/search_uses_positional_parameters.rb +8 -10
- data/lib/rubocop/cop/chef/deprecation/use_automatic_resource_name.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/use_inline_resources.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/use_yaml_dump.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/user_supports_property.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/verify_property_file_expansion.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/windows_feature_servermanagercmd.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/windows_package_installer_type_string.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/windows_task_change_action.rb +4 -4
- data/lib/rubocop/cop/chef/deprecation/windows_version_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/deprecation/xml_ruby_recipe.rb +1 -1
- data/lib/rubocop/cop/chef/deprecation/yum_dnf_compat_recipe.rb +1 -1
- data/lib/rubocop/cop/chef/effortless/chef_vault_used.rb +6 -6
- data/lib/rubocop/cop/chef/effortless/data_bags.rb +1 -1
- data/lib/rubocop/cop/chef/effortless/depends_chef_vault.rb +1 -1
- data/lib/rubocop/cop/chef/effortless/node_environment.rb +2 -2
- data/lib/rubocop/cop/chef/effortless/node_policygroup.rb +1 -1
- data/lib/rubocop/cop/chef/effortless/node_roles.rb +2 -2
- data/lib/rubocop/cop/chef/effortless/search_for_environments_or_roles.rb +1 -1
- data/lib/rubocop/cop/chef/effortless/search_used.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/action_method_in_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/allowed_actions_initializer.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/apt_default_recipe.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/berksfile_source.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/build_essential.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/chef_14_resources.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/chef_15_resources.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/chef_gem_nokogiri.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/class_eval_action_class.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/compile_time_resources.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/conditional_using_test.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/cron_d_file_or_template.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/cron_manage_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/databag_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/declare_action_class.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/default_action_initializer.rb +5 -5
- data/lib/rubocop/cop/chef/modernize/defines_chefspec_matchers.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_chef_vault_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_chocolatey_cookbooks.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_kernel_module_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_locale_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_openssl_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_timezone_lwrp_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_windows_firewall_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/depends_zypper_cookbook.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/dsl_include_in_resource.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/empty_resource_initialize.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/execute_apt_update.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/execute_sc_exe.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/execute_sleep.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/execute_sysctl.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/execute_tzutil.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/foodcritic_comments.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/if_provides_default_action.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/includes_mixin_shellout.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/libarchive_file.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/macos_user_defaults.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/minitest_handler_usage.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/node_init_package.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/node_roles_include.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/ohai_default_recipe.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/openssl_rsa_key_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/openssl_x509_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/osx_config_profile_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/powershell_expand_archive.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/powershell_guard_interpreter.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/powershell_install_package.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/powershell_install_windowsfeature.rb +6 -6
- data/lib/rubocop/cop/chef/modernize/property_with_name_attribute.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/provides_initializer.rb +4 -4
- data/lib/rubocop/cop/chef/modernize/resource_name_initializer.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/resource_set_or_return.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/resource_with_attributes.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/respond_to_compile_time.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/respond_to_metadata.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/respond_to_provides.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/respond_to_resource_name.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/sc_windows_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/seven_zip_archive.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/shell_out_helper.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/shellouts_to_chocolatey.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/simplify_apt_ppa_setup.rb +14 -14
- data/lib/rubocop/cop/chef/modernize/sysctl_param_resource.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/unnecessary_mixlib_shellout_require.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/use_chef_language_cloud_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/use_chef_language_env_helpers.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/use_chef_language_systemd_helper.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/use_multipackage_installs.rb +3 -3
- data/lib/rubocop/cop/chef/modernize/use_require_relative.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/whyrun_supported_true.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/windows_default_recipe.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/windows_registry_uac.rb +2 -2
- data/lib/rubocop/cop/chef/modernize/windows_zipfile.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/zipfile_resource.rb +1 -1
- data/lib/rubocop/cop/chef/modernize/zypper_repo.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/apt_repository_distribution_default.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/apt_repository_notifies_apt_update.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/attribute_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/conflicts_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/custom_resource_with_allowed_actions.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/double_compile_time.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/grouping_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/long_description_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/multiple_platform_checks.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/name_property_and_required.rb +4 -4
- data/lib/rubocop/cop/chef/redundant/ohai_attribute_to_string.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/property_splat_regex.rb +3 -3
- data/lib/rubocop/cop/chef/redundant/property_with_default_and_required.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/provides_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/recipe_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/replaces_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/resource_with_nothing_action.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/sensitive_property_in_resource.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/string_property_with_nil_default.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/suggests_metadata.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/unnecessary_desired_state.rb +2 -2
- data/lib/rubocop/cop/chef/redundant/unnecessary_name_property.rb +1 -1
- data/lib/rubocop/cop/chef/redundant/use_create_if_missing.rb +2 -2
- data/lib/rubocop/cop/chef/security/ssh_private_key.rb +1 -1
- data/lib/rubocop/cop/chef/sharing/default_maintainer_metadata.rb +4 -3
- data/lib/rubocop/cop/chef/sharing/empty_metadata_field.rb +2 -2
- data/lib/rubocop/cop/chef/sharing/include_property_descriptions.rb +2 -2
- data/lib/rubocop/cop/chef/sharing/include_resource_descriptions.rb +1 -1
- data/lib/rubocop/cop/chef/sharing/include_resource_examples.rb +1 -1
- data/lib/rubocop/cop/chef/sharing/insecure_cookbook_url.rb +4 -4
- data/lib/rubocop/cop/chef/sharing/invalid_license_string.rb +288 -11
- data/lib/rubocop/cop/chef/style/attribute_keys.rb +4 -4
- data/lib/rubocop/cop/chef/style/chef_whaaat.rb +2 -2
- data/lib/rubocop/cop/chef/style/comments_copyright_format.rb +2 -2
- data/lib/rubocop/cop/chef/style/comments_default_copyright.rb +2 -2
- data/lib/rubocop/cop/chef/style/comments_format.rb +2 -2
- data/lib/rubocop/cop/chef/style/file_mode.rb +2 -2
- data/lib/rubocop/cop/chef/style/immediate_notification_timing.rb +2 -2
- data/lib/rubocop/cop/chef/style/include_recipe_with_parentheses.rb +2 -2
- data/lib/rubocop/cop/chef/style/negating_only_if.rb +2 -2
- data/lib/rubocop/cop/chef/style/overly_complex_supports_depends_metadata.rb +2 -2
- data/lib/rubocop/cop/chef/style/simplify_platform_major_version_check.rb +4 -4
- data/lib/rubocop/cop/chef/style/true_false_resource_properties.rb +2 -2
- data/lib/rubocop/cop/chef/style/unnecessary_os_check.rb +5 -5
- data/lib/rubocop/cop/chef/style/unnecessary_platform_case_statement.rb +2 -2
- data/lib/rubocop/cop/chef/style/use_platform_helpers.rb +3 -3
- data/lib/rubocop/cop/inspec/deprecation/attribute_default.rb +2 -2
- data/lib/rubocop/cop/inspec/deprecation/attribute_helper.rb +2 -2
- metadata +6 -10
|
@@ -23,7 +23,7 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# template '/etc/www/configures-apache.conf' do
|
|
28
28
|
# notifies :restart, resources(service: 'apache')
|
|
29
29
|
# end
|
|
@@ -40,7 +40,7 @@ module RuboCop
|
|
|
40
40
|
# subscribes :restart, resources(service: service_name_variable), :immediately
|
|
41
41
|
# end
|
|
42
42
|
#
|
|
43
|
-
#
|
|
43
|
+
# # good
|
|
44
44
|
# template '/etc/www/configures-apache.conf' do
|
|
45
45
|
# notifies :restart, 'service[apache]'
|
|
46
46
|
# end
|
|
@@ -19,11 +19,11 @@ module RuboCop
|
|
|
19
19
|
module Cop
|
|
20
20
|
module Chef
|
|
21
21
|
module Deprecations
|
|
22
|
-
# The
|
|
22
|
+
# The locale resource's lc_all property has been deprecated and will be removed in Chef Infra Client 17
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# locale 'set locale' do
|
|
28
28
|
# lang 'en_gb.utf-8'
|
|
29
29
|
# lc_all 'en_gb.utf-8'
|
|
@@ -32,7 +32,7 @@ module RuboCop
|
|
|
32
32
|
class LocaleDeprecatedLcAllProperty < Base
|
|
33
33
|
include RuboCop::Chef::CookbookHelpers
|
|
34
34
|
|
|
35
|
-
MSG = "The
|
|
35
|
+
MSG = "The locale resource's lc_all property has been deprecated and will be removed in Chef Infra Client 17"
|
|
36
36
|
|
|
37
37
|
def on_block(node)
|
|
38
38
|
match_property_in_resource?(:locale, 'lc_all', node) do |property|
|
|
@@ -23,7 +23,7 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# template '/etc/foo' do
|
|
28
28
|
# source 'bar.erb'
|
|
29
29
|
# notifies :write, 'log[Aggregate notifications using a single log resource]', :immediately
|
|
@@ -33,7 +33,7 @@ module RuboCop
|
|
|
33
33
|
# notifies :restart, 'service[foo]', :delayed
|
|
34
34
|
# end
|
|
35
35
|
#
|
|
36
|
-
#
|
|
36
|
+
# # good
|
|
37
37
|
# template '/etc/foo' do
|
|
38
38
|
# source 'bar.erb'
|
|
39
39
|
# notifies :run, 'notify_group[Aggregate notifications using a single notify_group resource]', :immediately
|
|
@@ -23,14 +23,14 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# macos_userdefaults 'set a value' do
|
|
28
28
|
# global true
|
|
29
29
|
# key 'key'
|
|
30
30
|
# value 'value'
|
|
31
31
|
# end
|
|
32
32
|
#
|
|
33
|
-
#
|
|
33
|
+
# # good
|
|
34
34
|
# macos_userdefaults 'set a value' do
|
|
35
35
|
# key 'key'
|
|
36
36
|
# value 'value'
|
|
@@ -23,11 +23,11 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# property :config_file, String, default: 'foo', name_property: true
|
|
28
28
|
# attribute :config_file, String, default: 'foo', name_attribute: true
|
|
29
29
|
#
|
|
30
|
-
#
|
|
30
|
+
# # good
|
|
31
31
|
# property :config_file, String, name_property: true
|
|
32
32
|
# attribute :config_file, String, name_attribute: true
|
|
33
33
|
#
|
|
@@ -22,16 +22,16 @@ module RuboCop
|
|
|
22
22
|
#
|
|
23
23
|
# @example
|
|
24
24
|
#
|
|
25
|
-
#
|
|
25
|
+
# # bad
|
|
26
26
|
# node.deep_fetch("foo")
|
|
27
27
|
#
|
|
28
|
-
#
|
|
28
|
+
# # good
|
|
29
29
|
# node.read("foo")
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # bad
|
|
32
32
|
# node.deep_fetch!("foo")
|
|
33
33
|
#
|
|
34
|
-
#
|
|
34
|
+
# # good
|
|
35
35
|
# node.read!("foo")
|
|
36
36
|
#
|
|
37
37
|
class NodeDeepFetch < Base
|
|
@@ -23,14 +23,14 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# node.fqdn
|
|
28
28
|
# node.platform
|
|
29
29
|
# node.platform_family
|
|
30
30
|
# node.platform_version
|
|
31
31
|
# node.hostname
|
|
32
32
|
#
|
|
33
|
-
#
|
|
33
|
+
# # good
|
|
34
34
|
# node['fqdn']
|
|
35
35
|
# node['platform']
|
|
36
36
|
# node['platform_family']
|
|
@@ -22,13 +22,13 @@ module RuboCop
|
|
|
22
22
|
#
|
|
23
23
|
# @example
|
|
24
24
|
#
|
|
25
|
-
#
|
|
25
|
+
# # bad
|
|
26
26
|
# node['foo']['bar'] = 1
|
|
27
27
|
# node['foo']['bar'] << 1
|
|
28
28
|
# node['foo']['bar'] += 1
|
|
29
29
|
# node['foo']['bar'] -= 1
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # good
|
|
32
32
|
# node.default['foo']['bar'] = 1
|
|
33
33
|
# node.default['foo']['bar'] << 1
|
|
34
34
|
# node.default['foo']['bar'] += 1
|
|
@@ -23,8 +23,8 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
27
|
-
# ::Chef::PartialSearch.new.search(
|
|
26
|
+
# # bad
|
|
27
|
+
# ::Chef::PartialSearch.new.search(:node, 'role:web',
|
|
28
28
|
# keys: { 'name' => [ 'name' ],
|
|
29
29
|
# 'ip' => [ 'ipaddress' ],
|
|
30
30
|
# 'kernel_version' => %w(kernel version),
|
|
@@ -35,7 +35,7 @@ module RuboCop
|
|
|
35
35
|
# puts result['kernel_version']
|
|
36
36
|
# end
|
|
37
37
|
#
|
|
38
|
-
#
|
|
38
|
+
# # good
|
|
39
39
|
# search(:node, 'role:web',
|
|
40
40
|
# filter_result: { 'name' => [ 'name' ],
|
|
41
41
|
# 'ip' => [ 'ipaddress' ],
|
|
@@ -23,7 +23,7 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# partial_search(:node, 'role:web',
|
|
28
28
|
# keys: { 'name' => [ 'name' ],
|
|
29
29
|
# 'ip' => [ 'ipaddress' ],
|
|
@@ -35,7 +35,7 @@ module RuboCop
|
|
|
35
35
|
# puts result['kernel_version']
|
|
36
36
|
# end
|
|
37
37
|
#
|
|
38
|
-
#
|
|
38
|
+
# # good
|
|
39
39
|
# search(:node, 'role:web',
|
|
40
40
|
# filter_result: { 'name' => [ 'name' ],
|
|
41
41
|
# 'ip' => [ 'ipaddress' ],
|
|
@@ -23,12 +23,12 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# poise_archive 'https://example.com/myapp.tgz' do
|
|
28
28
|
# destination '/opt/my_app'
|
|
29
29
|
# end
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # good
|
|
32
32
|
# archive_file 'https://example.com/myapp.tgz' do
|
|
33
33
|
# destination '/opt/my_app'
|
|
34
34
|
# end
|
|
@@ -23,10 +23,10 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# Powershell::VersionHelper.powershell_version?('4.0')
|
|
28
28
|
#
|
|
29
|
-
#
|
|
29
|
+
# # good
|
|
30
30
|
# node['powershell']['version'].to_f == 4.0
|
|
31
31
|
#
|
|
32
32
|
# # better (Chef Infra Client 15.8+)
|
|
@@ -23,10 +23,10 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# my_resource = MyResource.dsl_name
|
|
28
28
|
#
|
|
29
|
-
#
|
|
29
|
+
# # good
|
|
30
30
|
# my_resource = MyResource.resource_name
|
|
31
31
|
#
|
|
32
32
|
class ResourceUsesDslNameMethod < Base
|
|
@@ -37,8 +37,8 @@ module RuboCop
|
|
|
37
37
|
add_offense(node, severity: :warning)
|
|
38
38
|
end
|
|
39
39
|
|
|
40
|
-
# potential autocorrect is
|
|
41
|
-
# this might not be worth it yet based on the
|
|
40
|
+
# potential autocorrect is to replace .dsl_name with .resource_name, but we need to actually verify the context
|
|
41
|
+
# this might not be worth it yet based on the false auto correct potential
|
|
42
42
|
end
|
|
43
43
|
end
|
|
44
44
|
end
|
|
@@ -23,16 +23,17 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# action :foo do
|
|
28
28
|
# updated = true
|
|
29
29
|
# end
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # good
|
|
32
32
|
# action :foo do
|
|
33
33
|
# converge_by('resource did something') do
|
|
34
34
|
# # code that causes the resource to converge
|
|
35
35
|
# end
|
|
36
|
+
# end
|
|
36
37
|
#
|
|
37
38
|
class ResourceUsesUpdatedMethod < Base
|
|
38
39
|
MSG = "Don't use updated = true/false to update resource state. This will cause failures in Chef Infra Client 13 and later."
|
|
@@ -19,11 +19,11 @@ module RuboCop
|
|
|
19
19
|
module Cop
|
|
20
20
|
module Chef
|
|
21
21
|
module Deprecations
|
|
22
|
-
# Chef Infra Client 15.3 and later include a new Unified Mode that simplifies the execution of resources by
|
|
22
|
+
# Chef Infra Client 15.3 and later include a new Unified Mode that simplifies the execution of resources by replacing the traditional compile and converge phases with a single phase. Unified mode simplifies writing advanced resources and avoids confusing errors that often occur when mixing ruby and Chef Infra resources. Chef Infra Client 17.0 and later will begin warning that `unified_mode true` should be set in all resources to validate that they will continue to function in Chef Infra Client 18.0 (April 2022) when Unified Mode becomes the default.
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# resource_name :foo
|
|
28
28
|
# provides :foo
|
|
29
29
|
#
|
|
@@ -31,7 +31,7 @@ module RuboCop
|
|
|
31
31
|
# # some action code
|
|
32
32
|
# end
|
|
33
33
|
#
|
|
34
|
-
#
|
|
34
|
+
# # good
|
|
35
35
|
# resource_name :foo
|
|
36
36
|
# provides :foo
|
|
37
37
|
# unified_mode true
|
|
@@ -23,11 +23,11 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# shell_out!('hostnamectl status', { returns: [0, 1] })
|
|
28
28
|
# shell_out('hostnamectl status', { returns: [0, 1] })
|
|
29
29
|
#
|
|
30
|
-
#
|
|
30
|
+
# # good
|
|
31
31
|
# shell_out!('hostnamectl status', returns: [0, 1])
|
|
32
32
|
# shell_out('hostnamectl status', returns: [0, 1])
|
|
33
33
|
#
|
|
@@ -23,7 +23,7 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# ruby_block 'my special ruby block' do
|
|
28
28
|
# block do
|
|
29
29
|
# puts 'running'
|
|
@@ -31,7 +31,7 @@ module RuboCop
|
|
|
31
31
|
# action :create
|
|
32
32
|
# end
|
|
33
33
|
#
|
|
34
|
-
#
|
|
34
|
+
# # good
|
|
35
35
|
# ruby_block 'my special ruby block' do
|
|
36
36
|
# block do
|
|
37
37
|
# puts 'running'
|
|
@@ -23,14 +23,14 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# require 'chef/mixin/command'
|
|
28
28
|
# include Chef::Mixin::Command
|
|
29
29
|
#
|
|
30
30
|
# run_command('/bin/foo')
|
|
31
31
|
# run_command_with_systems_locale('/bin/foo')
|
|
32
32
|
#
|
|
33
|
-
#
|
|
33
|
+
# # good
|
|
34
34
|
# shell_out!('/bin/foo')
|
|
35
35
|
#
|
|
36
36
|
class UsesRunCommandHelper < Base
|
|
@@ -23,17 +23,15 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
|
|
27
|
-
#
|
|
28
|
-
#
|
|
29
|
-
#
|
|
30
|
-
|
|
31
|
-
### correct
|
|
26
|
+
# # bad
|
|
27
|
+
# search(:node, '*:*', 0, 1000, { :ip_address => ["ipaddress"] })
|
|
28
|
+
# search(:node, '*:*', 0, 1000)
|
|
29
|
+
# search(:node, '*:*', 0)
|
|
32
30
|
#
|
|
33
|
-
#
|
|
34
|
-
#
|
|
35
|
-
#
|
|
36
|
-
#
|
|
31
|
+
# # good
|
|
32
|
+
# search(:node, '*:*', start: 0, rows: 1000, filter_result: { :ip_address => ["ipaddress"] })
|
|
33
|
+
# search(:node, '*:*', start: 0, rows: 1000)
|
|
34
|
+
# search(:node, '*:*', start: 0)
|
|
37
35
|
#
|
|
38
36
|
class SearchUsesPositionalParameters < Base
|
|
39
37
|
extend AutoCorrector
|
|
@@ -23,7 +23,7 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# user "betty" do
|
|
28
28
|
# supports({
|
|
29
29
|
# manage_home: true,
|
|
@@ -35,7 +35,7 @@ module RuboCop
|
|
|
35
35
|
# supports :manage_home => true
|
|
36
36
|
# end
|
|
37
37
|
#
|
|
38
|
-
#
|
|
38
|
+
# # good
|
|
39
39
|
# user "betty" do
|
|
40
40
|
# manage_home true
|
|
41
41
|
# non_unique true
|
|
@@ -23,12 +23,12 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# file '/etc/nginx.conf' do
|
|
28
28
|
# verify 'nginx -t -c %{file}'
|
|
29
29
|
# end
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # good
|
|
32
32
|
# file '/etc/nginx.conf' do
|
|
33
33
|
# verify 'nginx -t -c %{path}'
|
|
34
34
|
# end
|
|
@@ -23,12 +23,12 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# windows_feature 'DHCP' do
|
|
28
28
|
# install_method :servermanagercmd
|
|
29
29
|
# end
|
|
30
30
|
#
|
|
31
|
-
#
|
|
31
|
+
# # good
|
|
32
32
|
# windows_feature 'DHCP' do
|
|
33
33
|
# install_method :windows_feature_dism
|
|
34
34
|
# end
|
|
@@ -23,14 +23,14 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# windows_package 'AppveyorDeploymentAgent' do
|
|
28
28
|
# source 'https://www.example.com/appveyor.msi'
|
|
29
29
|
# installer_type 'msi'
|
|
30
30
|
# options "/quiet /qn /norestart /log install.log"
|
|
31
31
|
# end
|
|
32
32
|
#
|
|
33
|
-
#
|
|
33
|
+
# # good
|
|
34
34
|
# windows_package 'AppveyorDeploymentAgent' do
|
|
35
35
|
# source 'https://www.example.com/appveyor.msi'
|
|
36
36
|
# installer_type :msi
|
|
@@ -20,11 +20,11 @@ module RuboCop
|
|
|
20
20
|
module Chef
|
|
21
21
|
module Deprecations
|
|
22
22
|
# The :change action in the windows_task resource was removed when windows_task was added to Chef Infra Client 13+
|
|
23
|
-
# The default action of :create
|
|
23
|
+
# The default action of :create can now be used to create and update tasks.
|
|
24
24
|
#
|
|
25
25
|
# @example
|
|
26
26
|
#
|
|
27
|
-
#
|
|
27
|
+
# # bad
|
|
28
28
|
# windows_task 'chef ad-join leave start time' do
|
|
29
29
|
# task_name 'chef ad-join leave'
|
|
30
30
|
# start_day '06/09/2016'
|
|
@@ -32,7 +32,7 @@ module RuboCop
|
|
|
32
32
|
# action [:change, :create]
|
|
33
33
|
# end
|
|
34
34
|
#
|
|
35
|
-
#
|
|
35
|
+
# # good
|
|
36
36
|
# windows_task 'chef ad-join leave start time' do
|
|
37
37
|
# task_name 'chef ad-join leave'
|
|
38
38
|
# start_day '06/09/2016'
|
|
@@ -47,7 +47,7 @@ module RuboCop
|
|
|
47
47
|
|
|
48
48
|
minimum_target_chef_version '13.0'
|
|
49
49
|
|
|
50
|
-
MSG = 'The :change action in the windows_task resource was removed when windows_task was added to Chef Infra Client 13+. The default action of :create
|
|
50
|
+
MSG = 'The :change action in the windows_task resource was removed when windows_task was added to Chef Infra Client 13+. The default action of :create can now be used to create and update tasks.'
|
|
51
51
|
|
|
52
52
|
def on_block(node)
|
|
53
53
|
match_property_in_resource?(:windows_task, 'action', node) do |action_node|
|
|
@@ -23,13 +23,13 @@ module RuboCop
|
|
|
23
23
|
#
|
|
24
24
|
# @example
|
|
25
25
|
#
|
|
26
|
-
#
|
|
26
|
+
# # bad
|
|
27
27
|
# Windows::VersionHelper.nt_version
|
|
28
28
|
# Windows::VersionHelper.server_version?
|
|
29
29
|
# Windows::VersionHelper.core_version?
|
|
30
30
|
# Windows::VersionHelper.workstation_version?
|
|
31
31
|
#
|
|
32
|
-
#
|
|
32
|
+
# # good
|
|
33
33
|
# node['platform_version'].to_f
|
|
34
34
|
# node['kernel']['product_type'] == 'Server'
|
|
35
35
|
# node['kernel']['server_core']
|