From 07212bded6157e12e7cfea91b2265572d3bd5ab8 Mon Sep 17 00:00:00 2001 From: Yury Bushmelev Date: Tue, 3 Dec 2024 08:49:42 +0800 Subject: [PATCH 1/2] Add Binary type to lexer type tokens list --- lib/puppet-lint/lexer.rb | 2 +- spec/unit/puppet-lint/lexer_spec.rb | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/lib/puppet-lint/lexer.rb b/lib/puppet-lint/lexer.rb index 504103ff..32ef92ea 100644 --- a/lib/puppet-lint/lexer.rb +++ b/lib/puppet-lint/lexer.rb @@ -123,7 +123,7 @@ def heredoc_queue [:WHITESPACE, %r{\A(#{WHITESPACE_RE}+)}], # FIXME: Future breaking change, the following :TYPE tokens conflict with # the :TYPE keyword token. - [:TYPE, %r{\A(Any|Array|Boolean|Callable|CatalogEntry|Class|Collection|Data|Default|Enum|Error|Float|Hash|Integer|NotUndef|Numeric|Optional|Pattern|Regexp|Resource|Runtime|Scalar|Sensitive|String|Struct|Tuple|Type|Undef|Variant)\b}], # rubocop:disable Layout/LineLength + [:TYPE, %r{\A(Any|Array|Binary|Boolean|Callable|CatalogEntry|Class|Collection|Data|Default|Enum|Error|Float|Hash|Integer|NotUndef|Numeric|Optional|Pattern|Regexp|Resource|Runtime|Scalar|Sensitive|String|Struct|Tuple|Type|Undef|Variant)\b}], # rubocop:disable Layout/LineLength [:CLASSREF, %r{\A(((::){0,1}[A-Z][-\w]*)+)}], [:NUMBER, %r{\A\b((?:0[xX][0-9A-Fa-f]+|0?\d+(?:\.\d+)?(?:[eE]-?\d+)?))\b}], [:FUNCTION_NAME, %r{#{NAME_RE}(?=\()}], diff --git a/spec/unit/puppet-lint/lexer_spec.rb b/spec/unit/puppet-lint/lexer_spec.rb index 54832b2d..7e637cf3 100644 --- a/spec/unit/puppet-lint/lexer_spec.rb +++ b/spec/unit/puppet-lint/lexer_spec.rb @@ -1396,6 +1396,12 @@ expect(token.type).to eq(:TYPE) expect(token.value).to eq('Error') end + + it 'matches Binary type' do + token = lexer.tokenise('Binary').first + expect(token.type).to eq(:TYPE) + expect(token.value).to eq('Binary') + end end context ':HEREDOC without interpolation' do From 19888c4ee5d26c2160a11168a3a169ff5309c9aa Mon Sep 17 00:00:00 2001 From: Yury Bushmelev Date: Tue, 3 Dec 2024 08:49:52 +0800 Subject: [PATCH 2/2] Simplify type matcher tests with shared examples --- spec/unit/puppet-lint/lexer_spec.rb | 34 ++++++++++------------------- 1 file changed, 12 insertions(+), 22 deletions(-) diff --git a/spec/unit/puppet-lint/lexer_spec.rb b/spec/unit/puppet-lint/lexer_spec.rb index 7e637cf3..5b6e92df 100644 --- a/spec/unit/puppet-lint/lexer_spec.rb +++ b/spec/unit/puppet-lint/lexer_spec.rb @@ -1359,6 +1359,14 @@ end context ':TYPE' do + shared_examples 'a type matcher' do |type| + it "matches #{type}" do + token = lexer.tokenise(type).first + expect(token.type).to eq(:TYPE) + expect(token.value).to eq(type) + end + end + it 'matches Data Types' do token = lexer.tokenise('Integer').first expect(token.type).to eq(:TYPE) @@ -1378,30 +1386,12 @@ end describe 'Platform Types' do - it 'matches Callable' do - token = lexer.tokenise('Callable').first - expect(token.type).to eq(:TYPE) - expect(token.value).to eq('Callable') - end - - it 'matches Sensitive' do - token = lexer.tokenise('Sensitive').first - expect(token.type).to eq(:TYPE) - expect(token.value).to eq('Sensitive') - end + it_behaves_like 'a type matcher', 'Callable' + it_behaves_like 'a type matcher', 'Sensitive' end - it 'matches Error type' do - token = lexer.tokenise('Error').first - expect(token.type).to eq(:TYPE) - expect(token.value).to eq('Error') - end - - it 'matches Binary type' do - token = lexer.tokenise('Binary').first - expect(token.type).to eq(:TYPE) - expect(token.value).to eq('Binary') - end + it_behaves_like 'a type matcher', 'Error' + it_behaves_like 'a type matcher', 'Binary' end context ':HEREDOC without interpolation' do