From c9bcaf1d650490693b0204ec79a0cb8c52786d9f Mon Sep 17 00:00:00 2001 From: Dominic Cleal Date: Thu, 23 Jun 2016 12:20:17 +0100 Subject: [PATCH] Ignore function names followed by `=>` symbol Prevents bare words in hashes or resource parameters being interpreted as function calls, as they'll always be followed by `=>`. Fixes #9 --- .../plugins/check_absolute_classname.rb | 2 +- .../relative_classname_inclusion_spec.rb | 17 +++++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/lib/puppet-lint/plugins/check_absolute_classname.rb b/lib/puppet-lint/plugins/check_absolute_classname.rb index 7450294..913d106 100644 --- a/lib/puppet-lint/plugins/check_absolute_classname.rb +++ b/lib/puppet-lint/plugins/check_absolute_classname.rb @@ -2,8 +2,8 @@ def check tokens.each_with_index do |token, token_idx| if token.type == :NAME && ['include','contain','require'].include?(token.value) - next if resource_indexes.any? { |resource| resource[:tokens].include?(token) } s = token.next_code_token + next if s.type == :FARROW in_function = 0 while s.type != :NEWLINE n = s.next_code_token diff --git a/spec/puppet-lint/plugins/check_absolute_classname/relative_classname_inclusion_spec.rb b/spec/puppet-lint/plugins/check_absolute_classname/relative_classname_inclusion_spec.rb index c304c22..e7efd41 100644 --- a/spec/puppet-lint/plugins/check_absolute_classname/relative_classname_inclusion_spec.rb +++ b/spec/puppet-lint/plugins/check_absolute_classname/relative_classname_inclusion_spec.rb @@ -79,6 +79,23 @@ class { 'foobar': } expect(problems).to have(0).problems end end + + context 'when require is a hash key' do + let(:code) do + <<-EOS + $defaults = { + require => Exec['apt_update'], + } + $defaults = { + 'require' => Exec['apt_update'], + } + EOS + end + + it 'should detect no problems' do + expect(problems).to have(0).problems + end + end end context 'with fix enabled' do