13.1.1 (2018-04-12)
- 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.
13.1.0 (2018-04-12)
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.
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.
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.
FC116
- Cookbook depends on the deprecated compat_resource cookbookFC120
- Do not set the name property directly on a resourceFC122
- Use the build_essential resource instead of the recipe
13.0.1 (2018-04-11)
- 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
13.0.0 (2018-03-07)
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.
- 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.
- 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.
12.3.0 (2018-01-18)
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
12.2.2 (2017-12-13)
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
12.2.1 (2017-11-14)
Fixed bugs:
- Fixed FC104 alerting for any resource with a :create action instead of just ruby_block resources
12.2.0 (2017-11-14)
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
12.1.0 (2017-10-31)
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
12.0.1 (2017-10-19)
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
12.0.0 (2017-10-18)
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
11.4.0 (2017-09-13)
Implemented enhancements:
- Added metadata for Chef 13.3.42 and 13.4.19 to include the latest new resources shipped in chef-client
11.3.1 (2017-08-17)
Fixed bugs:
- Allow EncryptedDataBagItem.load_secret in FC086
11.3.0 (2017-07-12)
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.
11.2.0 (2017-06-12)
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 includesFC078
. To enable it again:foodcritic -t any .
- Added a Dockerfile for running Foodcritic in Docker.
11.1.0 (2017-05-18)
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
11.0.0 (2017-04-24)
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
, andword_list_values
- Deprecated API methods
checks_for_chef_solo
andchef_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
andsupermarket
tag to FC078. - Updated the
field
andfield_value
API methods to correctly recognize additional formats of data in the metdata.
10.4.1 (2017-04-17)
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 existingnode.platform?
usage. This rule has also been renamed and tags updated since the use ofnode.platform?
is a style issue and not a correctness issue. Bothnode.platform?
andplatform?
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
10.4.0 (2017-04-13)
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"
10.3.1 (2017-04-10)
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
10.3.0 (2017-04-10)
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.
10.2.2 (2017-03-31)
Implemented enhancements:
v10.2.1 (2017-03-31)
Implemented enhancements:
v10.2.0 (2017-03-30)
Implemented enhancements:
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 (2017-03-29)
Fixed bugs:
v10.1.0 (2017-03-29)
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 (2017-03-14)
Implemented enhancements:
- Add 12.19 metadata as default and remove 12.0 - 12.5.1 #516 (tas50)
- Remove FC003 from Foodcritic #512 (tas50)
v9.0.0 (2017-01-31)
Implemented enhancements:
- Add 12.18.31 metadata and make it the default #508 (tas50)
- Test on Ruby 2.4 and fix failing tests #507 (tas50)
- Support Chef RFC 17 compliant templates #485 (hagihala)
- More sane default CLI values #462 (tas50)
v8.2.0 (2017-01-09)
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 (2016-10-20)
Implemented enhancements:
- Add Chef client 12.15.19 metadata #493 (tas50)
- Clarify exclude path instructions in the CLI help #489 (unixorn)
v8.0.0 (2016-09-23)
Implemented enhancements:
- Require Ruby 2.2.2 #487 (tas50)
- Add 12.14.89 metadata and make it the default #486 (tas50)
- Remove Chef 11 metadata and rule support #481 (tas50)
v7.1.0 (2016-08-17)
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:
- Add missing assigment attributes #478 (ofir-petrushka)
v7.0.1 (2016-07-06)
Implemented enhancements:
v7.0.0 (2016-07-05)
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 (2016-05-16)
Implemented enhancements:
v6.2.0 (2016-04-26)
Implemented enhancements:
v6.1.1 (2016-04-08)
Implemented enhancements:
v6.1.0 (2016-04-06)
Implemented enhancements:
- Don't require cucumber and rubocop to run rake #444 (jkeiser)
- Add 12.8.1 metadata + update metadata process #438 (tas50)
- Add metadata for Chef 12.7.2 and update instructions #427 (tas50)
Fixed bugs:
v6.0.1 (2016-02-22)
Implemented enhancements:
- Check for URLs that are helpful to the Supermarket #421 (nathenharvey)
Fixed bugs:
v6.0.0 (2016-01-14)
Implemented enhancements:
- Cookbook version is specified in metadata #347
- FC035 - Templates, Style #62
- Add Chef 12.6.0 metadata #417 (tas50)
- New Rule 61 - valid cookbook version #405 (lamont-granquist)
- Require Oracle as a RHEL equiv #404 (tas50)
- Suggest updating from definitions to custom resources #403 (tas50)
- add checks for correct use of use_inline_resources #402 (lamont-granquist)
- Add new tags for rules #401 (tas50)
- Rename FC045 since Chef 12 requires name metadata #399 (tas50)
- Add Chef 12.5.1 metadata #397 (tas50)
- Add self-dependency warning #328 (lamont-granquist)
Fixed bugs:
- Time to cut a release? #344
- FC048: Warn within a provider block, refs #365 #413 (acrmp)
- use_inline_resources checks apply to Chef 11+ #410 (tas50)
- fix for edge condition with 061 #408 (lamont-granquist)
- Rake options override default options #382 (pkang)
Closed issues:
- Chef Docs vs Foodcritic 4.x #354
- Github pages have drifted from foodcritic.io #332
- FC001 is re-enabled thus http://www.foodcritic.io/ is out-of-date #330
v5.0.0 (2015-09-17)
Implemented enhancements:
- Support for a magic comment to temporarily disable a rule #259
- FC007 false positive on depending on the cookbook currently being parsed #242
- Create a rule for "execute resource used to install packages" #180
- New Rule Proposal: uid/gid should be integer #53
- merge default options before check instead of during intialization #321 (ranjib)
Fixed bugs:
- Fix FC031 and FC045 and metadata.rb vs metadata.json issues #369
- FC007 false positive on depending on the cookbook currently being parsed #242
- FC010 Test failures due to missing search support #199
- 'lazy' causes false-positive in FC009 - on previous line #189
- FC051 tries to validate temp files of the editors #172
v4.0.0 (2014-06-11)
v3.0.3 (2013-10-13)
v3.0.2 (2013-10-05)
v3.0.1 (2013-09-25)
Implemented enhancements:
- Roles rules #19
v3.0.0 (2013-09-14)
Implemented enhancements:
- Provide a comprehensive list of
tags
somewhere on the docs #63
Fixed bugs:
- FC001, FC019 shouldn't match on node.run_state #66
v2.2.0 (2013-07-10)
v2.1.0 (2013-04-16)
Implemented enhancements:
- New Rule Proposal: ||= considered harmful with attributes #52
- Would like to be able to exempt rules in cookbooks #10
v2.0.1 (2013-03-31)
v2.0.0 (2013-03-24)
Implemented enhancements:
- New Rule: Check for existence of 'name' in metadata.rb #64
- New Rule: action ":none" vs ":nothing" #61
Fixed bugs:
- Incorrectly decoding attributes within a block #76
- FC003 doesn't match unless statements #58
- FC019 triggered on internal recipe hash key as symbol instead of node #54
v1.7.0 (2012-12-27)
Fixed bugs:
v1.6.1 (2012-08-30)
v1.6.0 (2012-08-28)
Implemented enhancements:
- Thoughts on more style-y lint checks #15
Fixed bugs:
v1.5.0 (2012-08-20)
v1.5.1 (2012-08-20)
Fixed bugs:
- FC007 should not be triggered by include_recipe "#{cookbook_name}::blah" #44
- FC022 block name check appears to be too simplistic #29
v1.4.0 (2012-06-15)
v1.3.1 (2012-06-09)
Implemented enhancements:
- catch pry breakpoints #36
Fixed bugs:
- resource_attributes should show all of the relevant part of the AST #31
- FC003 is triggered, despite being handled #26
v1.3.0 (2012-05-21)
v1.2.0 (2012-04-21)
v1.1.0 (2012-03-25)
Fixed bugs:
- ruby segfault / foodcritic 1.0.0 / nokogiri 1.5.2 #18
v1.0.1 (2012-03-15)
Implemented enhancements:
- rules in code? #8
v1.0.0 (2012-03-04)
Implemented enhancements:
- Foodcritic doesn't have a -v #16
Fixed bugs:
- FC003: Recognise updated chef-solo-search #17
- foodcritic v10 and v11 have conflicting yajl-ruby dependencies with chef #14
v0.11.1 (2012-02-29)
Implemented enhancements:
- Want "all" arg to '-f' option. #11
Fixed bugs:
- Epic fail fail? #13
v0.11.0 (2012-02-22)
Fixed bugs:
v0.10.0 (2012-02-20)
v0.9.0 (2012-01-26)
v0.8.1 (2012-01-20)
v0.8.0 (2012-01-19)
Fixed bugs:
- Don't raise FC003 warning if chef-solo-search is installed #7
v0.7.0 (2011-12-31)
v0.6.0 (2011-12-18)
Fixed bugs:
- Bundler fails to resolve JSON version #6
v0.5.2 (2011-12-15)
v0.5.1 (2011-12-14)
v0.5.0 (2011-12-13)
v0.4.0 (2011-12-10)
v0.3.0 (2011-12-04)
v0.2.0 (2011-12-01)
v0.1.0 (2011-11-30)
- This Change Log was automatically generated by github_changelog_generator