Hi Felix,

Thanks for the reply.

Yep - that snippet is representative. I've copied the full thing for you 
below. Granted, it needs some tidying up, but I think it should just work 
as it stands:

class app::reservations {

include tomcat


Exec {
  path => "/usr/bin:/usr/sbin:/bin:/sbin:/usr/local/bin:/usr/local/sbin",
}


tomcat::instance { 'reservations':
  ensure    => present,
  http_port => 8080,
  require   => Class['tomcat'],
}


file { '/srv/tomcat/reservations/webapps/reservations.war':
  ensure => present,
  source => 'puppet:///modules/app/reservations.war',
  owner  => 'tomcat',
  group  => 'adm',
  mode   => '0755',
  notify => Exec['restart-reservations-tomcat'],
  }


exec { 'restart-reservations-tomcat':
  command => '/etc/init.d/tomcat-reservations restart',
}


}


Under normal circumstances, I agree that explicitly including the Tomcat 
class up above the instantiation of the tomcat::instance class should work 
fine. I don't know why it's not working quite as expected. Here's the 
output from Puppet with the --debug flag:

==> app: Debug: importing 
'/opt/puppet/modules/app/manifests/reservations.pp' in environment 
development
==> app: Debug: Automatically imported app:reservations from 
app/reservations in to development
==> app: Debug: importing '/opt/puppet/modules/app/manifests/tomcat.pp' in 
environment development
==> app: Debug: Automatically imported app::tomcat from app/tomcat into 
development
==> app: Debug: importing 
'/opt/puppet/vendor/modules/tomcat/manifests/instance.pp' in environment 
development
==> app: Debug: Automatically imported tomcat::instance from 
tomcat/instance into development
==> app: Warning: Scope(Tomcat::Instance[reservations]): Could not look up 
qualified variable 'tomcat::instance_basedir'; class tomcat has not been 
evaluated
==> app: Warning: Scope(Tomcat::Instance[reservations]): Could not look up 
qualified variable 'tomcat::version'; class tomcat has not been evaluated

Values for both tomcat::version and tomcat::instance_basedir are retrieved 
from a case statement which, ultimately, resides at 
https://github.com/camptocamp/puppet-tomcat/blob/master/manifests/params.pp, 
which either works out a value or just passes in a value, respectively.

So, it looks like the Tomcat module is - at least partially - being 
imported.

I'm a bit stumped now!

Andrew

On Sunday, 19 July 2015 01:06:26 UTC+1, Felix.Frank wrote:
>
>  On 07/19/2015 01:19 AM, Andrew Langhorn wrote:
>  
>  class apps::reservations {
>  
>
>    include tomcat
>  
>   
>    tomcat::instance { ‘reservations’:
>  
>    ensure => present,
>  
>   http_port => 8080,
>  
>    }
>  
>   
>   }
>  
>   
>  However, when I run Puppet against a Vagrant VM, it tells me that the 
> tomcat class hasn’t been evaluated, so it can’t use tomcat::instance 
> (because of underlying failures when using the Tomcat module):
>
>
>   ==> app: Warning: Scope(Tomcat::Instance[reservations]): Could not look 
> up qualified variable 'tomcat::instance_basedir'; class tomcat has not been 
> evaluated
>  
>  
> Hmm, if the resource declaration is lexically preceded by an 'include 
> tomcat' then this should not happen.
>
> In this case, the order in your manifest is really important. Is your 
> snippet truly representative of your actual code?
>
> Regards,
> Felix
>  

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to puppet-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/puppet-users/2d506a73-c86a-4ddd-bfd4-09579565bd04%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to