2015-08-07 09:21:41 -04:00
|
|
|
#!/bin/bash
|
Add Puppetfile and install script
This repo will be cloned by the puppet modules and used to install
modules in functional tests. The script uses r10k to deploy modules
from the Puppetfile because this is the Puppet Labs recommended way to
manage puppet environments, and it is a popular method among our users.
We install all modules from git, not the forge, because r10k does not
give us dependency resolution so installing from the forge does not buy
us anything. If the modules have stable branches in git, r10k uses the
stable branch as a ref, otherwise it uses a tag (pinning to a specific
release).
If zuul-cloner is available, the script first installs the external
modules with r10k, then extracts the OpenStack modules from the
Puppetfile to install with zuul-cloner. In the future, this part may be
split out into a JJB job.
Note: because r10k purges the modules directory before installing
modules, and this feature cannot be turned off[1], we must run r10k to
install the external modules before running zuul-cloner to install the
OpenStack modules.
[1] https://github.com/puppetlabs/r10k/issues/172
Change-Id: Ide59ef4bdf53a04957e3593815b7514a0e744e0e
2015-06-30 16:59:52 -07:00
|
|
|
|
2015-08-07 09:21:41 -04:00
|
|
|
set -ex
|
|
|
|
|
2016-03-24 14:39:05 +01:00
|
|
|
if [ -n "${GEM_HOME}" ]; then
|
2015-08-07 09:25:02 -04:00
|
|
|
GEM_BIN_DIR=${GEM_HOME}/bin/
|
2016-06-13 14:11:46 -04:00
|
|
|
export PATH=${PATH}:${GEM_BIN_DIR}
|
2015-08-07 09:25:02 -04:00
|
|
|
fi
|
|
|
|
|
2016-06-07 17:58:23 -04:00
|
|
|
if [ "${PUPPET_MAJ_VERSION}" = 4 ]; then
|
2016-03-22 21:31:18 -04:00
|
|
|
export PUPPET_BASE_PATH=/etc/puppetlabs/code
|
2016-03-28 20:21:34 -07:00
|
|
|
export PATH=${PATH}:/opt/puppetlabs/bin
|
2016-06-09 10:40:05 -04:00
|
|
|
# Workaround to deploy puppet for beaker jobs
|
2016-06-15 14:06:36 +03:00
|
|
|
sudo -E ln -sfn /opt/puppetlabs/bin/puppet /usr/sbin/puppet
|
2016-03-22 21:31:18 -04:00
|
|
|
else
|
|
|
|
export PUPPET_BASE_PATH=/etc/puppet
|
|
|
|
fi
|
|
|
|
|
2015-10-15 09:59:57 -05:00
|
|
|
export SCRIPT_DIR=$(cd `dirname $0` && pwd -P)
|
2016-03-15 18:36:38 -07:00
|
|
|
export PUPPETFILE_DIR=${PUPPETFILE_DIR:-${PUPPET_BASE_PATH}/modules}
|
2015-10-05 16:39:26 -04:00
|
|
|
source $SCRIPT_DIR/functions
|
Add Puppetfile and install script
This repo will be cloned by the puppet modules and used to install
modules in functional tests. The script uses r10k to deploy modules
from the Puppetfile because this is the Puppet Labs recommended way to
manage puppet environments, and it is a popular method among our users.
We install all modules from git, not the forge, because r10k does not
give us dependency resolution so installing from the forge does not buy
us anything. If the modules have stable branches in git, r10k uses the
stable branch as a ref, otherwise it uses a tag (pinning to a specific
release).
If zuul-cloner is available, the script first installs the external
modules with r10k, then extracts the OpenStack modules from the
Puppetfile to install with zuul-cloner. In the future, this part may be
split out into a JJB job.
Note: because r10k purges the modules directory before installing
modules, and this feature cannot be turned off[1], we must run r10k to
install the external modules before running zuul-cloner to install the
OpenStack modules.
[1] https://github.com/puppetlabs/r10k/issues/172
Change-Id: Ide59ef4bdf53a04957e3593815b7514a0e744e0e
2015-06-30 16:59:52 -07:00
|
|
|
|
2016-04-14 14:04:57 -06:00
|
|
|
print_header 'Start (install_modules.sh)'
|
|
|
|
print_header 'Install r10k'
|
2015-08-07 09:21:41 -04:00
|
|
|
gem install r10k --no-ri --no-rdoc
|
|
|
|
|
2015-08-22 11:33:29 -04:00
|
|
|
# make sure there is no puppet module pre-installed
|
|
|
|
rm -rf "${PUPPETFILE_DIR:?}/"*
|
|
|
|
|
2016-04-14 14:04:57 -06:00
|
|
|
print_header 'Install Modules'
|
2015-10-05 16:39:26 -04:00
|
|
|
install_modules
|
Add Puppetfile and install script
This repo will be cloned by the puppet modules and used to install
modules in functional tests. The script uses r10k to deploy modules
from the Puppetfile because this is the Puppet Labs recommended way to
manage puppet environments, and it is a popular method among our users.
We install all modules from git, not the forge, because r10k does not
give us dependency resolution so installing from the forge does not buy
us anything. If the modules have stable branches in git, r10k uses the
stable branch as a ref, otherwise it uses a tag (pinning to a specific
release).
If zuul-cloner is available, the script first installs the external
modules with r10k, then extracts the OpenStack modules from the
Puppetfile to install with zuul-cloner. In the future, this part may be
split out into a JJB job.
Note: because r10k purges the modules directory before installing
modules, and this feature cannot be turned off[1], we must run r10k to
install the external modules before running zuul-cloner to install the
OpenStack modules.
[1] https://github.com/puppetlabs/r10k/issues/172
Change-Id: Ide59ef4bdf53a04957e3593815b7514a0e744e0e
2015-06-30 16:59:52 -07:00
|
|
|
|
2016-04-14 14:04:57 -06:00
|
|
|
print_header 'Module List'
|
2015-08-07 09:21:41 -04:00
|
|
|
puppet module list
|
2016-04-14 14:04:57 -06:00
|
|
|
|
|
|
|
print_header 'Done (install_modules.sh)'
|