enhanced build in docker

php
Marc Wäckerlin 9 years ago
parent 8de5dfa945
commit af88fdd4fd
  1. 14
      build-in-docker.conf
  2. 89
      build-in-docker.sh
  3. 6
      resolve-debbuilddeps.sh

@ -1,7 +1,11 @@
packages+=" npm" packages+=("wheezy:::curl:::npm")
repos+="universe" packages+=("nodejs")
commands+=("npm install -g node" "npm install -g cordova") repos+=("Ubuntu:::universe")
repos+=("wheezy:::'deb http://ftp.is.debian.org/debian wheezy-backports main'")
commands+=("wheezy:::update-alternatives --install /usr/bin/node nodejs /usr/bin/nodejs 100")
commands+=("wheezy:::curl https://www.npmjs.com/install.sh | sh")
commands+=("npm install -g cordova")
if test -n "${ANDROID_HOME}"; then if test -n "${ANDROID_HOME}"; then
envs+=" -e ANDROID_HOME=${ANDROID_HOME}" envs+=("-e ANDROID_HOME=${ANDROID_HOME}")
dirs+=" -v ${ANDROID_HOME}:${ANDROID_HOME}:ro" dirs+=("-v ${ANDROID_HOME}:${ANDROID_HOME}:ro")
fi fi

@ -2,11 +2,11 @@
# build and test everything in a fresh docker installation # build and test everything in a fresh docker installation
img="ubuntu:latest" img="ubuntu:latest"
repos="" repos=()
keys="" keys=()
envs="" envs=()
dirs="-v $(pwd):/workdir" dirs=("-v $(pwd):/workdir")
packages="" packages=()
targets="all check distcheck" targets="all check distcheck"
commands=() commands=()
if test -e ./build-in-docker.conf; then if test -e ./build-in-docker.conf; then
@ -20,6 +20,7 @@ while test $# -gt 0; do
echo "$0 [OPTIONS]" echo "$0 [OPTIONS]"
echo echo
echo "OPTIONS:" echo "OPTIONS:"
echo
echo " -h, --help show this help" echo " -h, --help show this help"
echo " -i, --image <image> use given docker image instead of ${img}" echo " -i, --image <image> use given docker image instead of ${img}"
echo " -t, --targets targets specify build targets, default: ${targets}" echo " -t, --targets targets specify build targets, default: ${targets}"
@ -28,7 +29,20 @@ while test $# -gt 0; do
echo " -e, --env <var>=<val> set environment variable in docker" echo " -e, --env <var>=<val> set environment variable in docker"
echo " -d, --dir <dir> access given directory read only" echo " -d, --dir <dir> access given directory read only"
echo " -p, --package <pkg> install extra debian packages" echo " -p, --package <pkg> install extra debian packages"
echo " -x, --exe <command> execute commands as root in docker" echo " -c, --cmd <command> execute commands as root in docker"
echo
echo " The options -r -k -e -d -p -c can be repeated several times."
echo
echo " The options -r -p -c allow an if-then-else contruct"
echo " depending on the operating system:"
echo " <os>:::<A>:::<B>"
echo " <os>:::<A>"
echo " Read as: On linux type <os> use <A> else use <B>"
echo " That means: If the distributer ID or codename in lsb_release"
echo " matches <os>, then <A> is replaced, else <B> is replaced."
echo " The three colons are for splitting <os> from <A> and <B> part."
echo " E.g.: Install package curl on wheezy and npm on olter systems:"
echo " $0 -p wheezy:::curl:::npm"
echo echo
echo "EXAMPLE:" echo "EXAMPLE:"
echo echo
@ -50,21 +64,21 @@ while test $# -gt 0; do
targets="$1" targets="$1"
;; ;;
(-r|--repo) shift; (-r|--repo) shift;
repos+=" $1" repos+=("$1")
;; ;;
(-k|--key) shift; (-k|--key) shift;
keys+=" $1" keys+=("$1")
;; ;;
(-e|--env) shift; (-e|--env) shift;
envs+=" -e $1" envs+=("-e $1")
;; ;;
(-d|--dirs) shift; (-d|--dirs) shift;
dirs+=" -v $1:$1:ro" dirs+=("-v $1:$1:ro")
;; ;;
(-p|--package) shift; (-p|--package) shift;
packages+=" $1" packages+=("$1")
;; ;;
(-x|--exe) shift; (-c|--cmd) shift;
commands+=("$1") commands+=("$1")
;; ;;
(*) (*)
@ -79,28 +93,47 @@ while test $# -gt 0; do
shift shift
done done
function ifthenelse() {
arg="$1"
shift
cmd="$*"
if test "${arg/:::/}" = "${arg}"; then
docker exec ${DOCKER_ID} bash -c "${cmd//ARG/${arg}}"
else
os="${arg%%:::*}"
thenpart="${arg#*:::}"
if test "${thenpart/:::/}" = "${thenpart}"; then
docker exec ${DOCKER_ID} bash -c 'os="'$os'"; if test "${os//$(lsb_release -is)/}${os//$(lsb_release -cs)/}" != "${os}${os}"; then '"${cmd//ARG/${thenpart}}"'; fi'
else
elsepart="${thenpart##*:::}"
thenpart="${thenpart%:::*}"
docker exec ${DOCKER_ID} bash -c 'os="'$os'"; if test "${os//$(lsb_release -is)/}${os//$(lsb_release -cs)/}" != "${os}${os}"; then '"${cmd//ARG/${thenpart}}"'; else '"${cmd//ARG/${elsepart}}"'; fi'
fi
fi
}
set -x set -x
DOCKER_ID=$(docker run -d ${dirs} ${envs} -w /workdir $img sleep infinity) DOCKER_ID=$(docker run -d ${dirs[@]} ${envs[@]} -w /workdir $img sleep infinity)
trap "docker rm -f ${DOCKER_ID}" INT TERM EXIT trap "docker rm -f ${DOCKER_ID}" INT TERM EXIT
docker exec ${DOCKER_ID} apt-get install -y software-properties-common apt-transport-https dpkg-dev
if test -n "${repos}"; then
for repo in ${repos}; do
docker exec ${DOCKER_ID} apt-add-repository ${repo}
done
fi
if test -n "${keys}"; then
for key in ${keys}; do
wget -O- ${key} \
| docker exec -i ${DOCKER_ID} apt-key add -
done
fi
docker exec ${DOCKER_ID} apt-get update docker exec ${DOCKER_ID} apt-get update
if test -n "${packages}"; then docker exec ${DOCKER_ID} apt-get upgrade -y --force-yes
docker exec -i ${DOCKER_ID} apt-get install -y ${packages} if ! docker exec ${DOCKER_ID} apt-get install -y --force-yes python-software-properties apt-transport-https dpkg-dev lsb-release; then
docker exec ${DOCKER_ID} apt-get install -y --force-yes software-properties-common apt-transport-https dpkg-dev lsb-release
fi fi
for repo in "${repos[@]}"; do
ifthenelse "${repo}" "apt-add-repository ARG"
done
for key in "${keys[@]}"; do
wget -O- \
| docker exec -i ${DOCKER_ID} apt-key add -
done
docker exec ${DOCKER_ID} apt-get update
for package in "${packages[@]}"; do
ifthenelse "${package}" "apt-get install -y --force-yes ARG"
done
for command in "${commands[@]}"; do for command in "${commands[@]}"; do
docker exec -i ${DOCKER_ID} ${command} ifthenelse "${command}" "ARG"
done done
docker exec ${DOCKER_ID} ./resolve-debbuilddeps.sh docker exec ${DOCKER_ID} ./resolve-debbuilddeps.sh
docker exec -u $(id -u) ${DOCKER_ID} svn upgrade || true docker exec -u $(id -u) ${DOCKER_ID} svn upgrade || true

@ -16,7 +16,11 @@ if test -n "${SCHROOTNAME}"; then
SUDO="schroot -c "${SCHROOTNAME}" -u root -d / --" SUDO="schroot -c "${SCHROOTNAME}" -u root -d / --"
else else
DO="" DO=""
SUDO="sudo" if grep -q '/docker/' /proc/1/cgroup; then
SUDO=""
else
SUDO="sudo"
fi
fi fi
function install() { function install() {

Loading…
Cancel
Save