diff options
author | Joshua Powers <josh.powers@canonical.com> | 2017-06-01 16:39:50 -0700 |
---|---|---|
committer | Scott Moser <smoser@brickies.net> | 2017-06-08 15:32:25 -0400 |
commit | ee324391bcb436b1d3a1c44951aa1aa673005cf6 (patch) | |
tree | 18a3d6fb1df19d27bbba9f3569bdadc3b56b3450 | |
parent | f8f519aa63c8e8adb11fa45b85f7264cd84fe796 (diff) | |
download | vyos-cloud-init-ee324391bcb436b1d3a1c44951aa1aa673005cf6.tar.gz vyos-cloud-init-ee324391bcb436b1d3a1c44951aa1aa673005cf6.zip |
tools: add centos scripts to build and test
The added 'run-centos' does:
- Creates centos 6 or 7 lxd container
* Sets http_proxy variable for yum if set locally
* Creates centos user
- Push local tree
* Tar's up working directory
* Pushes to container and untars
- Installs pip and yum dependencies
- As user centos it can then based on flags:
* runs unittests
* run ./packages/brpm
* run ./packages/brpm --srpm
* artifact the built *.rpm
-rwxr-xr-x | tools/run-centos | 218 | ||||
-rwxr-xr-x | tools/setup-centos | 49 |
2 files changed, 267 insertions, 0 deletions
diff --git a/tools/run-centos b/tools/run-centos new file mode 100755 index 00000000..de21d756 --- /dev/null +++ b/tools/run-centos @@ -0,0 +1,218 @@ +#!/bin/bash +# This file is part of cloud-init. See LICENSE file for license information. + +set -u + +VERBOSITY=0 +TEMP_D="" +KEEP=false +CONTAINER="" + +error() { echo "$@" 1>&2; } +fail() { [ $# -eq 0 ] || error "$@"; exit 1; } +errorrc() { local r=$?; error "$@" "ret=$r"; return $r; } + +Usage() { + cat <<EOF +Usage: ${0##*/} [ options ] CentOS version + + This utility can makes it easier to run tests, build rpm and source rpm + generation inside a LXC of the specified version of CentOS. + + options: + -a | --artifact keep .rpm artifacts + -k | --keep keep container after tests + -r | --rpm build .rpm + -s | --srpm build .src.rpm + -u | --unittest run unit tests +EOF +} + +bad_Usage() { Usage 1>&2; [ $# -eq 0 ] || error "$@"; return 1; } +cleanup() { + if [ -n "$CONTAINER" -a "$KEEP" = "false" ]; then + delete_container "$CONTAINER" + fi + [ -z "${TEMP_D}" -o ! -d "${TEMP_D}" ] || rm -Rf "${TEMP_D}" +} + +debug() { + local level=${1}; shift; + [ "${level}" -gt "${VERBOSITY}" ] && return + error "${@}" +} + + +inside_as() { + # inside_as(container_name, user, cmd[, args]) + # executes cmd with args inside container as user in users home dir. + local name="$1" user="$2" + shift 2 + local stuffed="" b64="" + stuffed=$(getopt --shell sh --options "" -- -- "$@") + stuffed=${stuffed# -- } + b64=$(printf "%s\n" "$stuffed" | base64 --wrap=0) + inside "$name" su "$user" -c \ + 'cd; eval set -- "$(echo '$b64' | base64 --decode)" && exec "$@"' +} + +inside() { + local name="$1" + shift + lxc exec "$name" -- "$@" +} + +inject_cloud_init(){ + local name="$1" + tarball_name='cloud-init.tar.gz' + top_d=$(git rev-parse --show-toplevel) || + fail "failed to get top level" + cd "$top_d" || + fail "failed to cd to git top dir" + tar_folder=${PWD##*/} + cd .. + tar -czf "$TEMP_D/$tarball_name" "$tar_folder" || + fail "failed: creating tarball_name" + cd "$tar_folder" || + fail "failed: changing directory" + + user='centos' + tarball="/home/$user/$tarball_name" + inside "$name" useradd "$user" + lxc file push "$TEMP_D/$tarball_name" "$name/home/$user"/ + inside "$name" chown "$user:$user" "$tarball" + inside_as "$name" "$user" tar -C "/home/$user" -xzf "$tarball" || + fail "failed: extracting tarball" +} + +start_container() { + local src="$1" name="$2" + debug 1 "starting container $name from '$src'" + lxc launch "$src" "$name" || { + errorrc "Failed to start container '$name' from '$src'"; + return + } + CONTAINER=$name + + local out="" ret="" + debug 1 "waiting for networking" + out=$(inside "$name" sh -c ' + i=0 + while [ $i -lt 60 ]; do + getent hosts mirrorlist.centos.org && exit 0 + sleep 2 + done' 2>&1) + ret=$? + if [ $ret -ne 0 ]; then + error "Waiting for network in container '$name' failed. [$ret]" + error "$out" + return $ret + fi + + if [ ! -z "${http_proxy-}" ]; then + debug 1 "configuring proxy ${http_proxy}" + inside "$name" sh -c "echo proxy=$http_proxy >> /etc/yum.conf" + fi +} + +delete_container() { + debug 1 "removing container $1 [--keep to keep]" + lxc delete --force "$1" +} + +main() { + local short_opts="ahkrsuv:" + local long_opts="artifact,help,keep,rpm,srpm,unittest,verbose:" + local getopt_out="" + getopt_out=$(getopt --name "${0##*/}" \ + --options "${short_opts}" --long "${long_opts}" -- "$@") && + eval set -- "${getopt_out}" || + { bad_Usage; return; } + + local cur="" next="" + local artifact="" keep="" rpm="" srpm="" unittest="" version="" + + while [ $# -ne 0 ]; do + cur="${1:-}"; next="${2:-}"; + case "$cur" in + -a|--artifact) artifact=1;; + -h|--help) Usage ; exit 0;; + -k|--keep) KEEP=true;; + -r|--rpm) rpm=1;; + -s|--srpm) srpm=1;; + -u|--unittest) unittest=1;; + -v|--verbose) VERBOSITY=$((${VERBOSITY}+1));; + --) shift; break;; + esac + shift; + done + + [ $# -eq 1 ] || { bad_Usage "ERROR: Must provide version!"; return; } + version="$1" + + TEMP_D=$(mktemp -d "${TMPDIR:-/tmp}/${0##*/}.XXXXXX") || + fail "failed to make tempdir" + trap cleanup EXIT + + # program starts here + local uuid="" name="" + uuid=$(uuidgen -t) || { error "no uuidgen"; return 1; } + name="cloud-init-centos-${uuid%%-*}" + + start_container "images:centos/$version" "$name" + # CentOS 6 does not come with tar + if [ "$version" = "6" ]; then + inside "$name" yum install --assumeyes tar || { + errorrc "FAIL: yum install tar failed"; + } + fi + + debug 1 "inserting cloud-init" + inject_cloud_init "$name" || { + errorrc "FAIL: injecting cloud-init into $name failed." + return + } + + # install dependencies + debug 1 "installing dependencies" + inside "$name" /bin/sh <tools/setup-centos || + fail "failed: setting up container $name" + + local errors=0 do_cd="cd $tar_folder" + inside_as "$name" "$user" sh -ec "$do_cd; git checkout .; git status" || + { errorrc "git checkout failed."; errors=$(($errors+1)); } + + if [ -n "$unittest" ]; then + debug 1 "running unit tests." + inside_as "$name" "$user" sh -ec "$do_cd; nosetests tests/unittests" || + { errorrc "nosetests failed."; errors=$(($errors+1)); } + fi + + if [ -n "$srpm" ]; then + debug 1 "building srpm." + inside_as "$name" "$user" sh -ec "$do_cd; ./packages/brpm --srpm" || + { errorrc "brpm --srpm."; errors=$(($errors+1)); } + fi + + if [ -n "$rpm" ]; then + debug 1 "building rpm." + inside_as "$name" "$user" sh -ec "$do_cd; ./packages/brpm" || + { errorrc "brpm failed."; errors=$(($errors+1)); } + fi + + if [ -n "$artifact" ]; then + cmd="ls /home/$user/$tar_folder/*.rpm" + for built_rpm in $(lxc exec "$name" -- sh -c "$cmd"); do + lxc file pull "$name/$built_rpm" . + done + fi + + if [ "$errors" != "0" ]; then + error "there were $errors errors." + return 1 + fi + return 0 +} + +main "$@" +# vi: ts=4 expandtab diff --git a/tools/setup-centos b/tools/setup-centos new file mode 100755 index 00000000..bc5da8a7 --- /dev/null +++ b/tools/setup-centos @@ -0,0 +1,49 @@ +#!/bin/sh +# This file is part of cloud-init. See LICENSE file for license information. +set -fux +export LANG=C + +packages=" + file + git + pyserial + python-argparse + python-cheetah + python-configobj + python-devel + python-jinja2 + python-jsonpatch + python-oauthlib + python-pip + python-prettytable + python-requests + python-six + PyYAML + rpm-build +" + +pips=" + contextlib2 + httpretty + mock + nose + pep8 + unittest2 +" + +error() { echo "$@" 1>&2; } +fail() { [ $# -eq 0 ] || error "$@"; exit 1; } +info() { echo "$@"; } + +pips=$(for p in $pips; do echo "$p"; done | sort -u) +packages=$(for p in $packages; do echo "$p"; done | sort -u) + +if ! rpm -q epel-release >/dev/null; then + yum install --assumeyes epel-release || + fail "failed: yum install epel-release" +fi +yum install --assumeyes $packages || + fail "failed: yum install" "$packages" + +pip install --upgrade $pips || + fail "failed: pip install $pips" |