On Tuesday, September 25, 2012 4:05:26 AM UTC-5, Nikita Burtsev wrote:
>
> Hello, 
>
> We have a weird problem with includes: 
> err: Could not retrieve catalog from remote server: Error 400 on SERVER: 
> Could not find resource 'Class[Common_software]' for relationship from 
> 'Class[Default_repositories]'
>
> My wild guess would be that "common_software" gets in before 
> "default_repositories" and thus the error message. If i run agent again it 
> sometimes goes away and configuration gets applied, sometimes it does not. 
> I even tried using stages, did not help.
>
> nodes.pp looks like this; 
>
> stage { pre: before => Stage[main] }
>
> node 'basenode' {
>
>         class { 'default_repositories' : stage => pre }
>         <some stuff here>
>         include common_software-site
>        <some more stuff here> 
> } 
>
> We have multiple (read: many) sites with configuration which varies here 
> and there. To make things a bit more sane and to reduce duplication we 
> decided to have common code base we ship to each site which then changes 
> from site to site using inheritance mechanism, so, for example, there is 
> class called "common_software" which defines some resources and then there 
> is "common_software-site" which inherits base class and adds some 
> functionality. 
>
> If I include child class in nodes.pp problem is there, but including 
> parent class fixes the problem.   
>
> Any thoughts on the matter? 
>
>
Yes:

   1. You really should arrange your classes in modules.
   2. Class names must not contain hyphens (-).  They work accidentally in 
   some versions of Puppet, but they do not work in others.  I doubt that's 
   the source of your present problem, but it will likely cause you trouble in 
   the future.
   3. Although it has its use cases, class inheritance is usually *not* the 
   best choice in Puppet.  If you're not using it to override parameters 
   declared in a superclass, or to force parsing of the superclass to make it 
   safe for a parametrized class to use the superclass's variables as 
   parameter defaults, then you are misusing it.  You almost always want 
   composition instead of inheritance (i.e. "include foo" in the body instead 
   of "inherits foo" in the header).
   4. It is safe to explicitly include a superclass and its subclass on the 
   same node, in any order.
   5. It is safe to 'include' a non-parametrized class any number of times.
   6. Puppet parses any given manifest from top to bottom.  In particular, 
   given your node declaration, it will parse the declaration of class 
   'default_repositories' before anything else in the node declaration.  In 
   particular, it will parse that declaration before it parses "include 
   common_software-site"
   7. Puppet parses a class's definition immediately the first time it 
   encounters a declaration of that class.  In your case, that means it will 
   always start parsing the definition of class 'default_repositories' before 
   the definition of class 'common_software-site'.  If it has no other reason 
   to parse class 'common_software' than class 'common_software-site' 
   inheriting from it, then it will (attempt to) parse all of the definition 
   of 'default_repositories' before it parses either of the others.
   8. The appearance of a reference to a class is not a reason to parse 
   that class.
   9. Therefore, if class 'default_repositories' contains a reference to 
   Class['common_software'] but does nothing to ensure that it has been parsed 
   (for example, "include 'common_software'") then I would expect exactly the 
   error you describe.

John

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To view this discussion on the web visit 
https://groups.google.com/d/msg/puppet-users/-/oTOpKAuYlvkJ.
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