Merge de08460ef6
into 9302714509
This commit is contained in:
commit
59911fd4b6
39
.gitlab-ci.yml
Normal file
39
.gitlab-ci.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
---
|
||||||
|
stages:
|
||||||
|
- test
|
||||||
|
- deploy
|
||||||
|
|
||||||
|
# Jobs are defined below
|
||||||
|
Syntax Check:
|
||||||
|
tags:
|
||||||
|
- puppet agent
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- scripts/syntax_check.sh
|
||||||
|
|
||||||
|
Lint Check:
|
||||||
|
tags:
|
||||||
|
- puppet agent
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- scripts/lint_check.sh
|
||||||
|
|
||||||
|
# Unless TCP port 8170 is open to the PE master, this job must execute on the
|
||||||
|
# PE Monolithic Master itself.
|
||||||
|
Deploy to Puppet:
|
||||||
|
tags:
|
||||||
|
- puppet monolithic master
|
||||||
|
stage: deploy
|
||||||
|
variables:
|
||||||
|
URL: https://puppet:8170/code-manager
|
||||||
|
only:
|
||||||
|
- development
|
||||||
|
- testing
|
||||||
|
- production
|
||||||
|
- /^playground/
|
||||||
|
script:
|
||||||
|
- scripts/puppet_deploy.sh
|
||||||
|
|
||||||
|
# vim:tabstop=2
|
||||||
|
# vim:shiftwidth=2
|
||||||
|
# vim:expandtab
|
19
Gemfile
Normal file
19
Gemfile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
source ENV['GEM_SOURCE'] || 'https://rubygems.org'
|
||||||
|
|
||||||
|
if puppetversion = ENV['PUPPET_GEM_VERSION']
|
||||||
|
gem 'puppet', puppetversion, require: false
|
||||||
|
else
|
||||||
|
gem 'puppet', require: false
|
||||||
|
end
|
||||||
|
|
||||||
|
gem 'puppet-lint', '~> 2.0'
|
||||||
|
gem 'puppet-lint-absolute_classname-check'
|
||||||
|
gem 'puppet-lint-alias-check'
|
||||||
|
gem 'puppet-lint-empty_string-check'
|
||||||
|
gem 'puppet-lint-file_ensure-check'
|
||||||
|
gem 'puppet-lint-file_source_rights-check'
|
||||||
|
gem 'puppet-lint-leading_zero-check'
|
||||||
|
gem 'puppet-lint-trailing_comma-check'
|
||||||
|
gem 'puppet-lint-undef_in_function-check'
|
||||||
|
gem 'puppet-lint-unquoted_string-check'
|
||||||
|
gem 'puppet-lint-variable_contains_upcase'
|
72
scripts/lint_check.sh
Executable file
72
scripts/lint_check.sh
Executable file
@ -0,0 +1,72 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Error out if there are any failures
|
||||||
|
set -e
|
||||||
|
set -o pipefail
|
||||||
|
set -u
|
||||||
|
|
||||||
|
# Notes
|
||||||
|
# xargs -P2 is used to run 2 parallel processes at once. This speeds up
|
||||||
|
# performance on multi-core systems.
|
||||||
|
|
||||||
|
if [ -e /proc/cpuinfo ]; then
|
||||||
|
cores=$(awk 'BEGIN { c = 0 }; $1 == "processor" { c++ }; END { print c }' /proc/cpuinfo)
|
||||||
|
else
|
||||||
|
cores=2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Use Puppet Enterprise Ruby to check ruby and yaml files
|
||||||
|
export PATH="/opt/puppetlabs/puppet/bin:/opt/puppetlabs/bin:$PATH"
|
||||||
|
|
||||||
|
# Localize Gems on a per-job basis to prevent conflicts
|
||||||
|
gem_home="$(gem env gempath | cut -d: -f1)"
|
||||||
|
# Trim off the leading part of $HOME
|
||||||
|
gem_suffix=${gem_home##*/.gem/}
|
||||||
|
# Set GEM_HOME to a job specific location
|
||||||
|
export GEM_HOME="${HOME}/jobs/${CI_JOB_NAME:-lint}/gem/${gem_suffix}"
|
||||||
|
|
||||||
|
# If we need to install a gem, do so into HOME
|
||||||
|
# e.g. /home/gitlab-runner/.gem/ruby/2.1.0
|
||||||
|
export PATH="${GEM_HOME}/bin:$PATH"
|
||||||
|
|
||||||
|
echo '######## BEGIN DEPENDENCY SETUP #########'
|
||||||
|
|
||||||
|
# Display the gem environment
|
||||||
|
gem env
|
||||||
|
|
||||||
|
if ! (which bundle 2>&1 >/dev/null); then
|
||||||
|
gem install bundler --no-ri --no-rdoc
|
||||||
|
fi
|
||||||
|
|
||||||
|
# List the files changes from $BASEBRANCH on stdout
|
||||||
|
files_changed() {
|
||||||
|
# File status flags:
|
||||||
|
# M modified - File has been modified
|
||||||
|
# C copy-edit - File has been copied and modified
|
||||||
|
# R rename-edit - File has been renamed and modified
|
||||||
|
# A added - File has been added
|
||||||
|
# D deleted - File has been deleted
|
||||||
|
# U unmerged - File has conflicts after a merge
|
||||||
|
git diff --name-status "${BASEBRANCH:=production}" \
|
||||||
|
| awk '$1 ~ /^[MCRA]$/' \
|
||||||
|
| cut -f2-
|
||||||
|
}
|
||||||
|
|
||||||
|
# Install dependencies
|
||||||
|
bundle install
|
||||||
|
|
||||||
|
echo '######## END DEPENDENCY SETUP #########'
|
||||||
|
echo
|
||||||
|
echo
|
||||||
|
echo '######## BEGIN LINT CHECKS #########'
|
||||||
|
# Lint only the manifest files changed
|
||||||
|
files_changed \
|
||||||
|
| awk '/manifests\/.*\.(pp)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
bundle exec puppet-lint
|
||||||
|
|
||||||
|
echo '######## END LINT CHECKS #########'
|
||||||
|
|
||||||
|
# vim:tabstop=2
|
||||||
|
# vim:shiftwidth=2
|
||||||
|
# vim:expandtab
|
60
scripts/puppet_deploy.sh
Executable file
60
scripts/puppet_deploy.sh
Executable file
@ -0,0 +1,60 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -u
|
||||||
|
|
||||||
|
export PATH="/opt/puppetlabs/bin:$PATH"
|
||||||
|
# Allow these environment variable to be overriden
|
||||||
|
: ${URL:='https://puppet:8170/code-manager'}
|
||||||
|
# CI_BUILD_REF_NAME is a variable set by gitlab
|
||||||
|
: ${ENVIRONMENT:="$CI_BUILD_REF_NAME"}
|
||||||
|
|
||||||
|
err() {
|
||||||
|
echo "$1" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ -z "${PUPPET_TOKEN:-}" ]; then
|
||||||
|
err "ERROR: PUPPET_TOKEN environment variable must be set!"
|
||||||
|
err "SUGGESTION: Did you push to origin instead of upstream?"
|
||||||
|
err "PUPPET_TOKEN must be set as an environment variable in CI"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! [ -x /opt/puppetlabs/bin/puppet-code ]; then
|
||||||
|
err "ERROR: /opt/puppetlabs/bin/puppet-code does not exist"
|
||||||
|
err "SUGGESTION: Install the puppet client tools"
|
||||||
|
err "https://docs.puppet.com/pe/2016.4/install_pe_client_tools.html#install-on-a-linux-workstation"
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Save the token to a temporary file so we can use it with puppet code deploy
|
||||||
|
scratch="$(mktemp -d)"
|
||||||
|
remove_scratch() {
|
||||||
|
[ -e "${scratch:-}" ] && rm -rf "$scratch"
|
||||||
|
}
|
||||||
|
trap remove_scratch EXIT
|
||||||
|
# Subsequent calls to mktemp should be inside our scratch dir
|
||||||
|
export TMPDIR="$scratch"
|
||||||
|
|
||||||
|
tokenfile="$(mktemp)"
|
||||||
|
echo -n "$PUPPET_TOKEN" > "$tokenfile"
|
||||||
|
|
||||||
|
# Turn on debug logging after the token has been written to the file system
|
||||||
|
set -x
|
||||||
|
# Deploy the code
|
||||||
|
puppet-code deploy \
|
||||||
|
--service-url "$URL" \
|
||||||
|
--token-file "$tokenfile" \
|
||||||
|
--wait "${ENVIRONMENT}"
|
||||||
|
rval=$?
|
||||||
|
set +x
|
||||||
|
|
||||||
|
if [ $rval -ne 0 ]; then
|
||||||
|
echo "ERROR: puppet-code deploy failed with exit code $rval" >&2
|
||||||
|
exit $rval
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Exiting with exit value $rval"
|
||||||
|
exit $rval
|
||||||
|
|
||||||
|
# vim:tabstop=2
|
||||||
|
# vim:shiftwidth=2
|
||||||
|
# vim:expandtab
|
76
scripts/syntax_check.sh
Executable file
76
scripts/syntax_check.sh
Executable file
@ -0,0 +1,76 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Error out if there are any failures
|
||||||
|
set -e
|
||||||
|
set -o pipefail
|
||||||
|
set -u
|
||||||
|
|
||||||
|
# Notes
|
||||||
|
# xargs -P2 is used to run 2 parallel processes at once. This speeds up
|
||||||
|
# performance on multi-core systems.
|
||||||
|
|
||||||
|
if [ -e /proc/cpuinfo ]; then
|
||||||
|
cores=$(awk 'BEGIN { c = 0 }; $1 == "processor" { c++ }; END { print c }' /proc/cpuinfo)
|
||||||
|
else
|
||||||
|
cores=2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Use Puppet Enterprise Ruby to check ruby and yaml files
|
||||||
|
export PATH="/opt/puppetlabs/puppet/bin:$PATH"
|
||||||
|
|
||||||
|
# List the files changes from $BASEBRANCH on stdout
|
||||||
|
files_changed() {
|
||||||
|
# File status flags:
|
||||||
|
# M modified - File has been modified
|
||||||
|
# C copy-edit - File has been copied and modified
|
||||||
|
# R rename-edit - File has been renamed and modified
|
||||||
|
# A added - File has been added
|
||||||
|
# D deleted - File has been deleted
|
||||||
|
# U unmerged - File has conflicts after a merge
|
||||||
|
git diff --name-status "${BASEBRANCH:=production}" \
|
||||||
|
| awk '$1 ~ /^[MCRA]$/' \
|
||||||
|
| cut -f2-
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check the Puppetfile
|
||||||
|
echo -n "Checking Puppetfile ... "
|
||||||
|
ruby -c Puppetfile
|
||||||
|
|
||||||
|
files_changed \
|
||||||
|
| awk '/\.(sh)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
bash -n
|
||||||
|
|
||||||
|
# Check all YAML files
|
||||||
|
# See: http://stackoverflow.com/questions/3971822/yaml-syntax-validator
|
||||||
|
files_changed \
|
||||||
|
| awk '/\.(yml|yaml)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
ruby -r yaml -e 'YAML.load_file(ARGV[0])'
|
||||||
|
|
||||||
|
# Check all JSON files
|
||||||
|
files_changed \
|
||||||
|
| awk '/\.(json)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
ruby -r json -e 'JSON.load(File.read(ARGV[0]))'
|
||||||
|
|
||||||
|
files_changed \
|
||||||
|
| awk '/\.(rb)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
ruby -c
|
||||||
|
|
||||||
|
# Check all erb files
|
||||||
|
files_changed \
|
||||||
|
| awk '/\.(erb)$/' \
|
||||||
|
| xargs -l --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
bash -c 'erb -P -x -T- $0 | ruby -c'
|
||||||
|
|
||||||
|
# Check all Puppet manifest files
|
||||||
|
files_changed \
|
||||||
|
| awk '/manifests\/.*\.(pp)$/' \
|
||||||
|
| xargs --no-run-if-empty -t -P$cores -n1 \
|
||||||
|
puppet parser validate
|
||||||
|
|
||||||
|
# vim:tabstop=2
|
||||||
|
# vim:shiftwidth=2
|
||||||
|
# vim:expandtab
|
Loading…
Reference in New Issue
Block a user