Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update dependency foodcritic to v16 #12

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

mend-5034428[bot]
Copy link

@mend-5034428 mend-5034428 bot commented Nov 28, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
foodcritic (source) '~> 5.0' -> '~> 16.3' age adoption passing confidence

Release Notes

acrmp/foodcritic (foodcritic)

v16.3.0

Compare Source

Please keep in mind that Foodcritic is considered EOL. This release is being made to reduce the side of dependencies in Chef Workstation. Users of Foodcritic should migrate to Cookstyle which ships with nearly 200 Chef cookbook cops and autocorrects code.

  • Removed the dependency on cucumber-core and its many dependencies by vendoring the gherkin tag processing logic from cucumber-core 3.x
  • Fix FC123 to properly look for files in subdirectories within the /files directory

v16.2.0

Compare Source

  • Updated Chef Infra metadata to 15.4 and 14.14 to add new resource properties and actions
  • Fixed the detection of :'symbol' action in notifications on Ruby 2.6+

v16.1.1

Compare Source

  • Resolved failure in FC123 when a cookbook does not include a files directory

v16.1.0

Compare Source

  • Updated Chef Infra Client metadata for 15.1 to include the new chocolatey_feature resources as well as new properties in the launchd and chocolatey_source resources
  • Added new rule to detect large files shipped in a cookbook: FC123: Content of a cookbook file is larger than 1MB. Thanks @​mattray
  • Allow configuring the size of the AST cache with a new --ast-cache-size command line option. Thanks @​Babar
  • Fix false positives in FC019 by chaning the Chef internal methods we check against. Thanks @​TravisWhitehead

v16.0.0

Compare Source

  • Removed Chef 13 metadata
  • Added metadata for Chef 14.12.9 and 15.0.293
  • Reenabled FC121 which detects the usage of cookbooks made obsolete by Chef 14

v15.1.0

Compare Source

  • Stripped test files from the gem artifact to slim the install size
  • Removed the legacy man page file that appears to be used
  • Updated chef metadata to 14.8 which provides information on the actions / properties of windows_task

v15.0.0

Compare Source

With this release of Foodcritic we are now shipping only metadata for the latest versions of each supported Chef version. Chef metadata files are getting increasingly large and this is increasing the size of Chef DK/Workstation significantly. This release ships with Chef 14.7 and 13.12 metadata and future releases will update the metadata versions without a major version bump as this should not be considered a breaking change.

v14.3.0

Compare Source

  • Added Chef 13.11.3 metadata
  • Removed Chef 13.5, 13.6, 13.7 and 13.9 metadata
  • Disabled FC121 for now. This rule was causing a lot of confusion and resulting in authors dropping support for Chef 13 prematurely. This rule we get enabled again when Chef 13 goes EOL this coming April

v14.2.0

Compare Source

  • Add Chef 14.5 metadata with 14.4 being the new default
  • Removed Chef 13.4 metadata
  • Pin cucumber-core to prevent pulling in new breaking changes

v14.1.0

Compare Source

  • Add Chef 14.3 and 14.4 metadata with 14.4 being the new default

v14.0.0

Compare Source

  • Removed Chef 13.0, 13.1, and 13.3 metadata.
  • Added Chef 13.9, 14.1, and 14.2 metadata and made 14.2 the new default, which adds property checking for all new Chef 14 resources to Foodcritic.
  • Renamed FC048 from "Prefer Mixlib::ShellOut" to "Prefer shell_out helper method to shelling out with Ruby" since Chef includes a helpful shell_out helper that is the preferred way to shell out in resources or libraries.
  • Removed FC012, which looked for legacy README.rdoc files. These haven't existed since the very early days of Chef and our existing check for README.MD files will catch any cookbooks still missing the proper format.
  • Added the opensource tag to FC071: Missing LICENSE file. This lets you easily skip this by excluding any rules tagged with opensource.
  • Added a new rule FC121: Cookbook depends on cookbook made obsolete by Chef 14. This rule detects cookbook which depend on build-essential, dmg, chef_handler, chef_hostname, mac_os_x, swap, or sysctl cookbooks. The resources from these cookbooks now ship in Chef 14 and depending on the cookbooks is no longer necessary. Note removing these dependencies does increase the minimum required chef-client for
  • The non-existent resource UnresolvedSubscribes has been removed from the metadata files slimming Foodcritic's install size by 1500 lines.
  • Updated the list of SPDX licenses in FC069 and FC078 to the current list.

v13.1.1

Compare Source

  • Fixed an error in the detection of attributes.rb files when using root alias functionality
  • Updated rules that used the 'deprecation' tag to instead use the 'deprecated' tag. All rules for deprecated functionality now have the same catch all tag.

v13.1.0

Compare Source

Speed improvements

Foodcritic now caches some of the information on cookbooks it previously calculated repeatedly. This results in a 10X reduction in some disk reads and a 7% improvement in runtime overall.

Rule file improvements

The fetching and parsing of Foodcritic rule files (.foodcritic files) has been improved. If a non-existent file is specified on the CLI we will now fail instead of silently continuing. Additionally, if the .foodcritic file exists, but cannot be read/parsed we will also fail instead of silently continuing.

Improved file detection

Several deficiencies in how Foodcritic detected files within a cookbook have been resolved. If you use the Chef 13+ root alias files such as attributes.rb or recipe.rb these will now be detected. Additionally we will detect template files not in the default directory, or deeply nested in directories within the templates directory.

New Rules
  • FC116 - Cookbook depends on the deprecated compat_resource cookbook
  • FC120 - Do not set the name property directly on a resource
  • FC122 - Use the build_essential resource instead of the recipe

v13.0.1

Compare Source

  • Properly discover templates not in templates/default/. Templates in the root of the templates directory would be skipped previously
  • Force encoding to UTF8 to prevent errors when encoding isn't set on the host
  • Alert with the filename when an improperly encoded file is encountered instead of silently failing
  • Removed the chef13 tag from FC085

v13.0.0

Compare Source

Chef 12 Support

As Chef 12 goes end of life next month this release makes several changes assuming Chef 13+:

Support for Ruby 2.2 has been removed

Chef 12 metadata files have been removed.

A new rule FC113: Resource declares deprecated use_inline_resources, which suggests a coding standard that requires Chef 13+. This rule is being introduced as use_inline_resources will begin throwing deprecation warnings in later Chef 14 releases and will eventually be removed from Chef.

Removed FC017: LWRP does not notify when updated. This is no longer applicable with Chef 13+ since inline resources are always used and notifications in resources happen automatically.

If full Chef 12 support is necessary then Foodcritic 12.2.2 is probably the best release to stick with. Keep in mind that later Foodcritic releases include rules that aid in Chef upgrades so sticking with an older release is not advised. Instead you should disable individual rules or tags that don't apply to your organization.

New/Removed Rules
  • Added FC113: Resource declares deprecated use_inline_resources.
  • Added FC115: Custom resource contains a name_property that is required
  • Added FC117: Do not use kind_of in custom resource properties
  • Added FC118: Resource property setting name_attribute vs. name_property
  • Added FC119: windows_task :change action no longer exists in Chef 13
  • Removed FC017: LWRP does not notify when updated.
Other Changes
  • Updated the notification_action API to detect actions that aren't symbols
  • Expand FC037 to detect notifying with actions as strings
  • Incompatibilities with Ruby 2.5 and FC025/FC026 have been resolved
  • Added Chef 13.7.16 metadata
  • The chef12 tag has been removed from FC064/FC065 has issue_url and source_url metadata aren't actually required by chef 12. This makes it seem as though users need to add this metadata to migrate to Chef 12, which isn't the case.

v12.3.0

Compare Source

Implemented enhancements:

  • Removed FC017, FC057, and FC059 as use_inline_resources is the default in Chef 13 and no longer required
  • Added FC110: Script resources should use 'code' property not 'command' property
  • Added FC111: search using deprecated sort flag
  • Added FC112 Resource using deprecated dsl_name method
  • Added FC113 Resource declares deprecated use_inline_resources
  • Added FC114 Cookbook uses legacy Ohai config syntax
  • Extended the find_resources method to allow accepting an array of resource names not just a single resource name

v12.2.2

Compare Source

Fixed bugs:

  • Don't require a space before the # in an ignore comment.
  • FC009 should not alert on a raise in a resource
  • Catch systemd service starts in FC004 and resolve several false positives

v12.2.1

Compare Source

Fixed bugs:

  • Fixed FC104 alerting for any resource with a :create action instead of just ruby_block resources

v12.2.0

Compare Source

Implemented enhancements:

  • Added Chef 13.6 resource metadata
  • Added FC103: Deprecated :uninstall action in chocolatey_package used
  • Added FC104: Use the :run action in ruby_block instead of :create
  • Added FC105: Deprecated erl_call resource used
  • Added FC106: Use the plist_hash property in launchd instead of hash
  • Added FC107: Resource uses epic_fail instead of ignore_failure
  • Added FC108: Resource should not define a property named 'name'
  • Added FC109: Use platform-specific package resources instead of provider property
  • Updated FC085 to also alert on @​new_resource.updated_by_last_action
  • Refactored multiple rules to simplify which files they trigger on

Fixed bugs:

  • Updated FC086 to only alert if someone is using DataBagItem/EncryptedDataBagItem to load a data bag

v12.1.0

Compare Source

Implemented enhancements:

  • Updated FC094 and FC095 tags from chef15 -> chef14 as the deprecation timeline has been changed
  • Updated FC087 to check for all deprecated Chef::Platform methods
  • Added FC101: Cookbook uses the deprecated deploy resource
  • Added FC102: Cookbook uses the deprecated Chef::DSL::Recipe::FullDSL class

v12.0.1

Compare Source

Fixed bugs:

  • Fixed the tags for new rules to correctly specify the version of Chef where the breaking change will occur, not the version of Chef were the deprecation warning was introduced

v12.0.0

Compare Source

Implemented enhancements:

  • Added FC093 - Generated README text needs updating
  • Added FC094 - Deprecated filesystem2 ohai plugin data used
  • Added FC095 - Deprecated cloud_v2 ohai plugin data used
  • Added FC096 - Deprecated libvirt virtualization ohai data used
  • Added FC097 - Deprecated Chef::Mixin::LanguageIncludeAttribute class used
  • Added FC098 - Deprecated Chef::Mixin::RecipeDefinitionDSLCore class used
  • Added FC099 - Deprecated Chef::Mixin::LanguageIncludeRecipe class used
  • Added FC100 - Deprecated Chef::Mixin::Language class used
  • Removed metadata for Chef versions 12.10, 12.11, 12.13, 12.14
  • Added metadata for Chef 12.21 and 13.5

v11.4.0

Compare Source

Implemented enhancements:

  • Added metadata for Chef 13.3.42 and 13.4.19 to include the latest new resources shipped in chef-client

v11.3.1

Compare Source

Fixed bugs:

  • Allow EncryptedDataBagItem.load_secret in FC086

v11.3.0

Compare Source

Full Changelog

Implemented enhancements:

  • The yajl-ruby dependency has been replaced with ffi-yajl which is used by Chef and is already present in ChefDK. A single usage of Ruby's JSON parser has also been replaced with ffi-yajl as well.
  • FC033 logic has been slightly simplified.

Fixed bugs:

  • FC001 will no longer alert when a user references the run_state, which is correctly accessed as a symbol and not a string.

v11.2.0

Compare Source

Full Changelog

Implemented enhancements:

  • Added metadata for Chef 13.1 and made this the default. This means that FC009 will now alert on cookbooks using code that has been removed in Chef 13.
  • Added FC091: Use property not attribute in custom resources.
  • Added FC092: Custom resources should not define actions.
  • Removed metadata for Chef 12.6, 12.7, and 12.8. This only impacts users specifically setting these metadata versions via the command line.
  • Disabled the opensource tag by default to simply use of Foodcritic for non-community cookbook developers. At the time of writing this only includes FC078. To enable it again: foodcritic -t any .
  • Added a Dockerfile for running Foodcritic in Docker.

v11.1.0

Compare Source

Full Changelog

Implemented enhancements:

  • Added FC086 - Use databag helper methods to load data bag items. Tags: style
  • Added FC087 - Library maps provider with deprecated Chef::Platform.set. Tags: chef13 deprecated
  • Added FC088 - Prefer Mixlib::Shellout over deprecated Chef::Mixin::Command. Tags: chef13 deprecated
  • Added FC089 - Prefer Mixlib::Shellout over deprecated Chef::ShellOut. Tags: chef13 deprecated
  • Added a new --rule-file flag to specify the path to your .foodcritic file
  • Added metadata for Chef 12.20.3 and made it the default
  • Updated several rule names to be more clear that we're checking for deprecated functionality

v11.0.0

Compare Source

Full Changelog

Implemented enhancements:

  • Added FC079 to detect the usage of the easy_install_package resource which is deprecated in Chef 13. Tags: deprecated, chef13.
  • Added FC080 to detect user resources that include the supports property, which is deprecated in Chef 13. Tags: deprecated, chef13.
  • Added FC081 to detect a cookbook that depends on the partial_search cookbook as partial search functionality is built into Chef 12 and later. Tags: chef12.
  • Added FC082 to detect the usage of node.set and node.set_unless which will be removed in Chef 14. Tags: deprecated, chef14.
  • Added FC083 to detect execute resources that include the path property, which is deprecated in Chef 12. Tags: deprecated, chef12.
  • Added FC084 to detect usage of the deprecated Chef::REST class. Tags: deprecated, chef13.
  • Added FC085 to detect usage of new_resource.updated_by_last_action to converge resources. Tags: deprecated, chef13.
  • Updated and refactored API methods declared_dependencies, supported_platforms, and word_list_values
  • Deprecated API methods checks_for_chef_solo and chef_solo_search_supported? have been removed.
  • Added a new API method json_file_to_hash for loading json files as a hash.
  • Added a new rake command to run the regression test on just a single cookbook

Fixed bugs:

  • Multiple rules have been rewritten to use Foodcritic APIs instead of using XPATH queries directly. This avoids false positives created by overly simplistic queries.
  • Fixed FC069 to skip if the license metadata is any formatting of 'All Rights Reserved'.
  • Added the license and supermarket tag to FC078.
  • Updated the field and field_value API methods to correctly recognize additional formats of data in the metdata.

v10.4.1

Compare Source

Full Changelog

Implemented enhancements:

  • Removed the development dependency on github_changelog_generator

Fixed bugs:

  • Fixed running cucumber tests using the cucumber CLI command
  • Fixed FC016 incorrectly firing on custom resources that have no properties. FC016 will now skip over resources that have any actions as those are custom resources and custom resources don't need to declare a default_action.
  • Added the missing chef13 tag to FC018
  • Updated FC028 to detect both node.platform_family? in addition to the existing node.platform? usage. This rule has also been renamed and tags updated since the use of node.platform? is a style issue and not a correctness issue. Both node.platform? and platform? are acceptable in cookbooks.
  • Fixed FC071 to not alert for cookbooks where the license is 'all rights reserved' in addition to the existing allowed 'All Rights Reserved' string
  • Fixed FC071 to detect the LICENSE file if foodcritic is not running in the root of the cookbook
  • Fixed FC070 to not alert when platform supports is defined through an array of platforms

v10.4.0

Compare Source

Full Changelog

Implemented enhancements:

  • Added FC076 to alert when the deprecated conflicts metadata is used
  • Added FC077 to alert when the deprecated replaces metadata is used
  • Added FC078 to alert when a non-OSI-approved license is used in metadata. You can disable this rule turning off the new opensource tag. For example: foodcritic -t ~opensource .

Fixed bugs:

  • Regression tests now ignore .foodcritic files so we see all possible failures
  • FC053 / FC052 updated to properly refer the metadata as deprecated and not unimplemented
  • FC071 no longer alerts when cookbooks are licensed as "All Rights Reserved"

v10.3.1

Compare Source

Full Changelog

Implemented enhancements:

  • Added Chef 13.0.113 metadata, but retained 12.19.36 as the default

Fixed bugs:

  • Resolved a regression when running Foodcritic as a Rake task

v10.3.0

Compare Source

Full Changelog

Implemented enhancements:

  • Added FC069 to ensure standardized licenses are defined in metadata
  • Added FC070 to detect invalid platform supports in metadata
  • Added FC071 to ensure a LICENSE file is included with the cookbook
  • Added FC072 to detect attributes defined in metadata
  • Added FC073 to detect root alias collisions with non-root alias files
  • Added FC074 to detect setting the default_action in a LWRP without using the default_action DSL
  • Added FC075 to detect node.save usage
  • Updated FC008 to fail if the ChefDK generated boilerplate is included
  • Updated FC024 to not recommend adding amazon as an equivalent platform to Redhat as Amazon is its own platform family in Chef 13
  • Updated FC045 to no longer fail if metadata.rb cannot be found
  • Added support for the Chef 13 root alias cookbook structure changes defined in https://github.com/chef/chef-rfc/blob/master/rfc033-root-aliases.md
  • Testing has been completed reworked to simplify testing and allow for far more robust functional tests. Minitest unit tests have been converted to rspec and a new functional testing framework has been added utilizing rspec. Tests for a large number of the existing rules have been converted to this new framework. The new testing framework allows for simple all-in-one tests that are easier to read and much simpler to write. Additionally the regression tests have been reworked, and are now enabled in Travis CI, which will require regeneration of the expected output if new tests are added using rake regen_regression. See the readme for additional details on running tests.

v10.2.2

Compare Source

Full Changelog

Implemented enhancements:

  • Align rake setup better with CLI options to resolve bugs with tags in Rake #​533 (tas50)

v10.2.1

Compare Source

Full Changelog

Implemented enhancements:

v10.2.0

Compare Source

Full Changelog

Implemented enhancements:

  • Add FC066/FC067/FC068 to check metadata chef_version, license, and supports #​528 (tas50)

Fixed bugs:

  • Don't trigger FC007 on a shorthand recipe includes #​526 (tas50)
  • Fix already initialized constant warning with --search-gems #​529 (nvwls)

v10.1.1

Compare Source

Full Changelog

Fixed bugs:

v10.1.0

Compare Source

Full Changelog

Implemented enhancements:

  • Remove FC023 which is no longer considered best practice #​523 (tas50)
  • Add basic testing of the metadata_field api #​522 (tas50)
  • Add a more robust cookbook_base_path helper to the API #​520 (tas50)
  • Update various tags to better align the rules with the tag categories #​517 (tas50)

v10.0.0

Compare Source

Full Changelog

Implemented enhancements:

v9.0.0

Compare Source

Full Changelog

Implemented enhancements:

v8.2.0

Compare Source

Full Changelog

Implemented enhancements:

  • Add 12.17.44 metadata (and make it the default) #​505 (tas50)
  • Add 12.16.42 metadata and make it the default #​497 (tas50)

v8.1.0

Compare Source

Full Changelog

Implemented enhancements:

v8.0.0

Compare Source

Full Changelog

Implemented enhancements:

v7.1.0

Compare Source

Full Changelog

Implemented enhancements:

  • Add Chef 12.13.37 metadata and make it the default #​479 (tas50)
  • Add 12.12.13 metadata and fix metadata generation #​472 (tas50)

Fixed bugs:

v7.0.1

Compare Source

Full Changelog

Implemented enhancements:

v7.0.0

Compare Source

Full Changelog

Implemented enhancements:

  • Remove support for Ruby 2.0 #​465 (tas50)
  • Remove chef version support for Chef 0.7, 0.8, 0.9, and 0.10 #​464 (tas50)
  • Add chef 12.11.18 metadata and make it the default #​461 (tas50)
  • FC032 allow the new :before timing on resource notifications in Chef >= 12.6.0 #​441 (gnjack)
  • New cookbook_maintainer api methods #​248 (miguelcnf)

v6.3.0

Compare Source

Please keep in mind that Foodcritic is considered EOL. This release is being made to reduce the side of dependencies in Chef Workstation. Users of Foodcritic should migrate to Cookstyle which ships with nearly 200 Chef cookbook cops and autocorrects code.

  • Removed the dependency on cucumber-core and its many dependencies by vendoring the gherkin tag processing logic from cucumber-core 3.x
  • Fix FC123 to properly look for files in subdirectories within the /files directory

v6.2.0

Compare Source

  • Updated Chef Infra metadata to 15.4 and 14.14 to add new resource properties and actions
  • Fixed the detection of :'symbol' action in notifications on Ruby 2.6+

v6.1.1

Compare Source

  • Resolved failure in FC123 when a cookbook does not include a files directory

v6.1.0

Compare Source

  • Updated Chef Infra Client metadata for 15.1 to include the new chocolatey_feature resources as well as new properties in the launchd and chocolatey_source resources
  • Added new rule to detect large files shipped in a cookbook: FC123: Content of a cookbook file is larger than 1MB. Thanks @​mattray
  • Allow configuring the size of the AST cache with a new --ast-cache-size command line option. Thanks @​Babar
  • Fix false positives in FC019 by chaning the Chef internal methods we check against. Thanks @​TravisWhitehead

v6.0.1

Compare Source

Full Changelog

Implemented enhancements:

Fixed bugs:

v6.0.0

Compare Source

  • Removed Chef 13 metadata
  • Added metadata for Chef 14.12.9 and 15.0.293
  • Reenabled FC121 which detects the usage of cookbooks made obsolete by Chef 14

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants