accept any case of boolean strings
* previously the str2bool function did not accept 'TRUE' as a bool type. This causes the function to now accept TRUE, FALSE strings as a boolean type in order to be converted to a proper boolean. * This would also cause Y,N, YES, NO to be accepted as boolean types as well.
This commit is contained in:
parent
6a1afae97e
commit
f2f2db4795
3 changed files with 7 additions and 7 deletions
|
@ -623,7 +623,7 @@ Returns a new string where runs of the same character that occur in this set are
|
||||||
|
|
||||||
#### `str2bool`
|
#### `str2bool`
|
||||||
|
|
||||||
Converts a string to a boolean. This attempts to convert strings that contain values such as '1', 't', 'y', and 'yes' to 'true' and strings that contain values such as '0', 'f', 'n', and 'no' to 'false'. *Type*: rvalue.
|
Converts a string to a boolean regardless of case. This attempts to convert strings that contain values such as '1', 't', 'y', 'Y', 'YES','yes', and 'TRUE' to 'true' and strings that contain values such as '0', 'f','F', 'N','n', 'NO','FALSE', and 'no' to 'false'. *Type*: rvalue.
|
||||||
|
|
||||||
#### `str2saltedsha512`
|
#### `str2saltedsha512`
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
module Puppet::Parser::Functions
|
module Puppet::Parser::Functions
|
||||||
newfunction(:str2bool, :type => :rvalue, :doc => <<-EOS
|
newfunction(:str2bool, :type => :rvalue, :doc => <<-EOS
|
||||||
This converts a string to a boolean. This attempt to convert strings that
|
This converts a string to a boolean. This attempt to convert strings that
|
||||||
contain things like: y, 1, t, true to 'true' and strings that contain things
|
contain things like: Y,y, 1, T,t, TRUE,true to 'true' and strings that contain things
|
||||||
like: 0, f, n, false, no to 'false'.
|
like: 0, F,f, N,n, false, FALSE, no to 'false'.
|
||||||
EOS
|
EOS
|
||||||
) do |arguments|
|
) do |arguments|
|
||||||
|
|
||||||
|
@ -32,8 +32,8 @@ like: 0, f, n, false, no to 'false'.
|
||||||
# We yield false in this case.
|
# We yield false in this case.
|
||||||
#
|
#
|
||||||
when /^$/, '' then false # Empty string will be false ...
|
when /^$/, '' then false # Empty string will be false ...
|
||||||
when /^(1|t|y|true|yes)$/ then true
|
when /^(1|t|y|true|yes)$/i then true
|
||||||
when /^(0|f|n|false|no)$/ then false
|
when /^(0|f|n|false|no)$/i then false
|
||||||
when /^(undef|undefined)$/ then false # This is not likely to happen ...
|
when /^(undef|undefined)$/ then false # This is not likely to happen ...
|
||||||
else
|
else
|
||||||
raise(Puppet::ParseError, 'str2bool(): Unknown type of boolean given')
|
raise(Puppet::ParseError, 'str2bool(): Unknown type of boolean given')
|
||||||
|
|
|
@ -10,13 +10,13 @@ describe 'str2bool' do
|
||||||
it { is_expected.to run.with_params('one').and_raise_error(Puppet::ParseError, /Unknown type of boolean given/) }
|
it { is_expected.to run.with_params('one').and_raise_error(Puppet::ParseError, /Unknown type of boolean given/) }
|
||||||
|
|
||||||
describe 'when testing values that mean "true"' do
|
describe 'when testing values that mean "true"' do
|
||||||
[ '1', 't', 'y', 'true', 'yes', true ].each do |value|
|
[ 'TRUE','1', 't', 'y', 'true', 'yes', true ].each do |value|
|
||||||
it { is_expected.to run.with_params(value).and_return(true) }
|
it { is_expected.to run.with_params(value).and_return(true) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'when testing values that mean "false"' do
|
describe 'when testing values that mean "false"' do
|
||||||
[ '', '0', 'f', 'n', 'false', 'no', false, 'undef', 'undefined' ].each do |value|
|
[ 'FALSE','', '0', 'f', 'n', 'false', 'no', false, 'undef', 'undefined' ].each do |value|
|
||||||
it { is_expected.to run.with_params(value).and_return(false) }
|
it { is_expected.to run.with_params(value).and_return(false) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue