Hi, you are probably right. Here we go:
as I am using puppet apply, I have in my site.pp: include role::fips_tool in fips_tool there is, among other code: ... class { profile::software::apache: php_version => '7.3', default_redirect_to => 'http://my.host.name', maindir => '/srv/labor/', keep_log_days => 30, } class { profile::software::wordpress: php_version => '7.3', } ... The offending code from profile::software::apache: class profile::software::apache ( String $php_version = '7.0', String $default_redirect_to = 'https://my.host.name', String $maindir = '/srv/www/', Integer $keep_log_days = 30, ) { ... ensure_packages([ "php$php_version-xml", "php$php_version-zip", "php$php_version-curl", "php$php_version-mbstring", "libapache2-mod-php$php_version", ], { require => [Class['apt::update'], Apt::Source['sury_php'], ] } ) ...} and from profile::software::wordpress.pp: class profile::software::wordpress ( String $php_version = '7.0', ){ require profile::software::mysql require profile::software::apache ... ensure_packages([ 'php7.1-mysql', 'php7.1-common', "libapache2-mod-php$php_version", "php$php_version-gd", "php$php_version-mysql", ], { require => [Class['apt::update'], Apt::Source['sury_php']], notify => Class['apache::service'] }) ... } On the dev Vagrant machine, I run this calling: sudo puppet apply /etc/puppetlabs/code/environments/dev/manifests/ Code runs without a problem: Notice: Scope(Class[Profile::Software::Tool_packages]): VirtualBox Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/dev/modules-external/ssh/manifests/hostkeys.pp, line: 39, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/dev/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/dev/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/dev/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the collection will be ignored (file: /etc/puppetlabs/code/environments/dev/modules-external/ssh/manifests/knownhosts.pp, line: 9, column: 7) Notice: Scope(Class[Profile::Software::Certbot]): setting Let's encrypt staging environment!!! Warning: Scope(Class[Apache::Mod::Status]): Class apache::mod::status: Using Allow Warning: Scope(Class[Apache::Mod::Status]): is deprecated in Apache 2.4 Notice: Scope(Class[Java_ng]): Selected repository: ppa:oracle, selected version: 8 Notice: Compiled catalog for stretch.localdomain in environment dev in 5.74 seconds Notice: Applied catalog in 3.20 seconds On the live VM I checkout the exakt same code from GIT, running it with: puppet apply /etc/puppetlabs/code/environments/production/manifests/ but the output is: Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/production/modules-external/ssh/manifests/hostkeys.pp, line: 39, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/production/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/production/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the export is ignored (file: /etc/puppetlabs/code/environments/production/modules-external/ssh/manifests/hostkeys.pp, line: 32, column: 7) Warning: You cannot collect exported resources without storeconfigs being set; the collection will be ignored (file: /etc/puppetlabs/code/environments/production/modules-external/ssh/manifests/knownhosts.pp, line: 9, column: 7) Error: Evaluation Error: Error while evaluating a Function Call, Duplicate declaration: Package[libapache2-mod-php7.3] is already declared at (file: /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/apache.pp, line: 78); cannot redeclare (file: /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/wordpress.pp, line: 24) (file: /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/wordpress.pp, line: 24, column: 3) on node my.host.name I recreated my Vagrant machine, works like a charm. Both machines run Puppet 6.2.0 on Debian 9.7 Sorry for the extensive post, this is because I do not have any clue where to look. Thanks, regards Jochen Am Mittwoch, 30. Januar 2019 22:40:26 UTC+1 schrieb Ben Ford: > > Sharing the code that you're working with will make it possible for people > to help solve your problem. > > On Wed, Jan 30, 2019 at 10:22 AM Jochen Haeberle <jochen....@gmail.com > <javascript:>> wrote: > >> Hi @all, >> >> does anyone have an idea what could be happening? I think this might be >> some sort of configuration error on the node, on the other hand, puppet >> obviously seems able to compile a catalog. >> What could be the reason for such a difference in behaviour on Debian 9.7 >> either on Vagrant or VMware? >> >> Thanks for any hints, regards >> >> Jochen >> >> Am Dienstag, 29. Januar 2019 00:02:42 UTC+1 schrieb Jochen Haeberle: >>> >>> Hi, >>> >>> I am using serverless puppet apply on some nodes. I prepared a set of >>> manifests using forge plugins. I developed everything using Vagrant quite >>> fine. >>> >>> Now I put my code via git on a debian 9.7 VM with puppet 6.2 and am >>> getting the following errors: >>> >>> Error: Evaluation Error: Error while evaluating a Function Call, >>> Duplicate declaration: Package[libapache2-mod-php7.3] is already declared >>> at (file: >>> /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/apache.pp, >>> >>> line: 78); cannot redeclare (file: >>> /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/wordpress.pp, >>> >>> line: 24) (file: >>> /etc/puppetlabs/code/environments/production/modules/profile/manifests/software/wordpress.pp, >>> >>> line: 24, column: 3) >>> >>> Both instances use the stdlib function ensure_packages. If I remove one >>> of the instances, I will get the error with another package. >>> >>> puppetlabs/stdlib and all other modules are up to date, thanks to r10k, >>> Code is working on a fresh vagrant machine. >>> >>> What can be the culprit of this? I have no idea where to look for this >>> problem. >>> >>> Thanks in advance vor any hints, regards >>> >>> Jochen >> >> -- >> 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...@googlegroups.com <javascript:>. >> To view this discussion on the web visit >> https://groups.google.com/d/msgid/puppet-users/4e0cd8c4-577f-42a6-a664-e6f4015fca5d%40googlegroups.com >> >> <https://groups.google.com/d/msgid/puppet-users/4e0cd8c4-577f-42a6-a664-e6f4015fca5d%40googlegroups.com?utm_medium=email&utm_source=footer> >> . >> For more options, visit https://groups.google.com/d/optout. >> > -- 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/d79b17e4-9eb8-455b-89a1-afdf86f743b2%40googlegroups.com. For more options, visit https://groups.google.com/d/optout.