It *may* have been using passed variables in templates.

I don't quite remember, but something was certainly interpolating strangely.

I tend to quote everything:

For undefined variable $::foo...

if $::foo != 'true' { ... } -> Explodes
if "$::foo" != 'true' { ... } -> Works

And makes sense. Of course Undefined is certainly not equal to "true"
but who's counting.

Trevor

On Fri, Dec 16, 2011 at 3:34 PM, Craig White <craig.wh...@ttiltd.com> wrote:
> perhaps not puppet but facter which I think always returns things as strings 
> - definitely a point of confusion but understandable when you think about it.
>
> Craig
>
> On Dec 16, 2011, at 1:15 PM, Trevor Vaughan wrote:
>
>> I tend to quote all used of 'false' and 'true' mainly because
>> sometimes the guts of puppet seem to give me back a string no matter
>> what I want and a bareword won't work.
>>
>> I don't have examples offhand and it's possible that this was fixed
>> some time in the past.
>>
>> Trevor
>>
>> On Fri, Dec 16, 2011 at 2:16 PM, Brice Figureau
>> <brice-pup...@daysofwonder.com> wrote:
>>> On 16/12/11 19:48, Tim Mooney wrote:
>>>> In regard to: Re: [Puppet Users] new user: need Conditional statement...:
>>>>
>>>>>> Obviously I had a syntax error here because case statement is not
>>>>>> happy within the resource.
>>>>>
>>>>> That's why the documentation says to use a selector.
>>>>>
>>>>>> So, what's a recommended puppet way to do something like this? thx in
>>>>>> advance.
>>>>>
>>>>> file {
>>>>>  "somefile" :
>>>>>    ensure => $hasfile ? {
>>>>>                "true"  => present,
>>>>>                default  => absent
>>>>>                    },
>>>>>    source => "puppet:///somefile",
>>>>>    owner => "root",
>>>>> }
>>>>>
>>>>> Please note that "true" is not strictly equivalent to the bareword true
>>>>> in the puppet language :)
>>>>
>>>> Ah, perfect segue.  I had been meaning to follow up to John Bollinger
>>>> when he earlier posted something similar that also had 'true' quoted.
>>>>
>>>> I've been through the style guide and several other areas in the
>>>> documentation and I can't find any recommendations on whether it's better
>>>> to use bare
>>>>
>>>>       true
>>>>       false
>>>>
>>>> or whether it's better to quote them.  This is specifically for use in
>>>> parameterized classes.  For example:
>>>>
>>>> foo.bar.edu.pp:
>>>>
>>>> node 'foo.bar.edu' {
>>>>
>>>>    class {'rhel':
>>>>      version      => '5',
>>>>      ipv6_enabled => true,
>>>>    }
>>>> }
>>>>
>>>> rhel/manifests/init.pp:
>>>>
>>>> class rhel($version, $ipv6_enabled='default') {
>>>>    include rhel::common
>>>>
>>>>    case $ipv6_enabled {
>>>>      true: {
>>>>          class {'network': ipv6 => true }
>>>>      }
>>>>      false: {
>>>>          class {'network': ipv6 => false }
>>>>      }
>>>>      default: {
>>>>        case $version {
>>>>          '5': {
>>>>              class {'network': ipv6 => false }
>>>>          }
>>>>          '6': {
>>>>              class {'network': ipv6 => true }
>>>>          }
>>>>          default: { fail("only version 5 and 6 of rhel are currently 
>>>> supported")}
>>>>        }
>>>>      }
>>>>    }
>>>> }
>>>>
>>>>
>>>> In other words, our default for RHEL 5 is ipv6 disabled, on RHEL 6 it's
>>>> ipv6 enabled, but the default can be overridden for either.
>>>>
>>>> The problem is that we had to be very careful to make certain that we
>>>> didn't quote true or false in some places and leave them as barewords
>>>> elsewhere, or it just wouldn't work.  Mixing quoted & nonquoted gave us
>>>> unreliable and unexpected results.
>>>
>>> Exactly. If you intend your options to be boolean use the barewords true
>>> and false.
>>>
>>>> This brings me back to the questions: where in the docs is this covered,
>>>> and what are the recommendations for whether we should (or shouldn't) be
>>>> quoting true & false when passing them around into parameterized classes
>>>> and testing them in selectors?
>>>
>>> I don't know if it's covered in the documentation.
>>>
>>> Puppet has the notion of true/false (ie the boolean). Any puppet
>>> conditional expression can evaluate to either true or false.
>>>
>>> On the other hande "true" is a string containing the word true. "false"
>>> is a string containing the word false. It is not a boolean.
>>>
>>> But that's where things get difficult:
>>>
>>> if "false" {
>>>  notice("false is true")
>>> }
>>>
>>> This will print "false is true".
>>>
>>> The same for
>>> $str = "false"
>>> if $str {
>>>  notice("false is true")
>>> }
>>>
>>> But,
>>> case $str {
>>>        true: { notice("true") }
>>>        false: { notice("false as bool") }
>>>        "false": { notice("false as str") }
>>> }
>>>
>>> will print "false as str". So "false" != false and is not == to true.
>>>
>>> But when converted as a boolean any strings becomes true, and that's
>>> what happen in our if example.
>>>
>>> We track this issue in the following ticket:
>>> http://projects.puppetlabs.com/issues/5648
>>>
>>> --
>>> Brice Figureau
>>> My Blog: http://www.masterzen.fr/
>>>
>>> --
>>> You received this message because you are subscribed to the Google Groups 
>>> "Puppet Users" group.
>>> To post to this group, send email to puppet-users@googlegroups.com.
>>> To unsubscribe from this group, send email to 
>>> puppet-users+unsubscr...@googlegroups.com.
>>> For more options, visit this group at 
>>> http://groups.google.com/group/puppet-users?hl=en.
>>>
>>
>>
>>
>> --
>> Trevor Vaughan
>> Vice President, Onyx Point, Inc
>> (410) 541-6699
>> tvaug...@onyxpoint.com
>>
>> -- This account not approved for unencrypted proprietary information --
>>
>> --
>> You received this message because you are subscribed to the Google Groups 
>> "Puppet Users" group.
>> To post to this group, send email to puppet-users@googlegroups.com.
>> To unsubscribe from this group, send email to 
>> puppet-users+unsubscr...@googlegroups.com.
>> For more options, visit this group at 
>> http://groups.google.com/group/puppet-users?hl=en.
>>
>
> --
> Craig White ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ craig.wh...@ttiltd.com
> 1.800.869.6908 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ www.ttiassessments.com
>
> Need help communicating between generations at work to achieve your desired 
> success? Let us help!
>
> --
> You received this message because you are subscribed to the Google Groups 
> "Puppet Users" group.
> To post to this group, send email to puppet-users@googlegroups.com.
> To unsubscribe from this group, send email to 
> puppet-users+unsubscr...@googlegroups.com.
> For more options, visit this group at 
> http://groups.google.com/group/puppet-users?hl=en.
>



-- 
Trevor Vaughan
Vice President, Onyx Point, Inc
(410) 541-6699
tvaug...@onyxpoint.com

-- This account not approved for unencrypted proprietary information --

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-users@googlegroups.com.
To unsubscribe from this group, send email to 
puppet-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/puppet-users?hl=en.

Reply via email to