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.