From 940db71b63f8ee91e3d150fa1112506be4a32eeb Mon Sep 17 00:00:00 2001 From: cocker-cc Date: Tue, 18 Jan 2022 11:09:36 +0100 Subject: [PATCH] (PUP-11429) Make split() sensitive-aware Let split() accept Values of Type Sensitive. In this Case the Returnvalue will also be of Type Sensitive. --- lib/puppet/functions/split.rb | 29 ++++++++++++++++++++++++++++- spec/unit/functions/split_spec.rb | 6 ++++++ 2 files changed, 34 insertions(+), 1 deletion(-) diff --git a/lib/puppet/functions/split.rb b/lib/puppet/functions/split.rb index ab7e356c388..64367e2bdea 100644 --- a/lib/puppet/functions/split.rb +++ b/lib/puppet/functions/split.rb @@ -36,6 +36,21 @@ param 'Type[Regexp]', :pattern end + dispatch :split_String_sensitive do + param 'Sensitive[String]', :sensitive + param 'String', :pattern + end + + dispatch :split_Regexp_sensitive do + param 'Sensitive[String]', :sensitive + param 'Regexp', :pattern + end + + dispatch :split_RegexpType_sensitive do + param 'Sensitive[String]', :sensitive + param 'Type[Regexp]', :pattern + end + def split_String(str, pattern) str.split(Regexp.compile(pattern)) end @@ -47,4 +62,16 @@ def split_Regexp(str, pattern) def split_RegexpType(str, pattern) str.split(pattern.regexp) end -end \ No newline at end of file + + def split_String_sensitive(sensitive, pattern) + Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_String(sensitive.unwrap, pattern)) + end + + def split_Regexp_sensitive(sensitive, pattern) + Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_Regexp(sensitive.unwrap, pattern)) + end + + def split_RegexpType_sensitive(sensitive, pattern) + Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_RegexpType(sensitive.unwrap, pattern)) + end +end diff --git a/spec/unit/functions/split_spec.rb b/spec/unit/functions/split_spec.rb index aaf0581395e..8b30f9c20ef 100644 --- a/spec/unit/functions/split_spec.rb +++ b/spec/unit/functions/split_spec.rb @@ -50,4 +50,10 @@ def split(*args) it 'should handle pattern in Regexp Type form with missing regular expression' do expect(split('ab',type_parser.parse('Regexp'))).to eql(['a', 'b']) end + + it 'should handle sensitive String' do + expect(split(Puppet::Pops::Types::PSensitiveType::Sensitive.new('a,b'), ',')).to be_a(Puppet::Pops::Types::PSensitiveType::Sensitive) + expect(split(Puppet::Pops::Types::PSensitiveType::Sensitive.new('a,b'), /,/)).to be_a(Puppet::Pops::Types::PSensitiveType::Sensitive) + expect(split(Puppet::Pops::Types::PSensitiveType::Sensitive.new('a,b'), type_parser.parse('Regexp[/,/]'))).to be_a(Puppet::Pops::Types::PSensitiveType::Sensitive) + end end