commit
027fa8a347
20 changed files with 1068 additions and 64 deletions
|
@ -1,5 +1,7 @@
|
||||||
## [0.?.?](https://github.com/fgrehm/vagrant-lxc/compare/v0.3.4...master) (unreleased)
|
## [0.?.?](https://github.com/fgrehm/vagrant-lxc/compare/v0.3.4...master) (unreleased)
|
||||||
|
|
||||||
|
- Enable Chef for Ubuntu Raring base box
|
||||||
|
- New box format [#89](https://github.com/fgrehm/vagrant-lxc/issues/89)
|
||||||
- BTRFS-friendly base boxes [#81](https://github.com/fgrehm/vagrant-lxc/issues/81)
|
- BTRFS-friendly base boxes [#81](https://github.com/fgrehm/vagrant-lxc/issues/81)
|
||||||
- Extended templates path lookup [#77](https://github.com/fgrehm/vagrant-lxc/issues/77) (tks to @aries1980)
|
- Extended templates path lookup [#77](https://github.com/fgrehm/vagrant-lxc/issues/77) (tks to @aries1980)
|
||||||
- Fix default group on the rake task [#82](https://github.com/fgrehm/vagrant-lxc/issues/82) (tks to @cduez)
|
- Fix default group on the rake task [#82](https://github.com/fgrehm/vagrant-lxc/issues/82) (tks to @cduez)
|
||||||
|
|
227
boxes/common/lxc-template
Executable file
227
boxes/common/lxc-template
Executable file
|
@ -0,0 +1,227 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# This is a modified version of /usr/share/lxc/templates/lxc-ubuntu
|
||||||
|
# that comes with Ubuntu 13.04 changed to suit vagrant-lxc needs
|
||||||
|
|
||||||
|
#
|
||||||
|
# template script for generating ubuntu container for LXC
|
||||||
|
#
|
||||||
|
# This script consolidates and extends the existing lxc ubuntu scripts
|
||||||
|
#
|
||||||
|
|
||||||
|
# Copyright © 2011 Serge Hallyn <serge.hallyn@canonical.com>
|
||||||
|
# Copyright © 2010 Wilhelm Meier
|
||||||
|
# Author: Wilhelm Meier <wilhelm.meier@fh-kl.de>
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License version 2, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
|
||||||
|
# You should have received a copy of the GNU General Public License along
|
||||||
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ -r /etc/default/lxc ]; then
|
||||||
|
. /etc/default/lxc
|
||||||
|
fi
|
||||||
|
|
||||||
|
extract_rootfs()
|
||||||
|
{
|
||||||
|
tarball=$1
|
||||||
|
arch=$2
|
||||||
|
rootfs=$3
|
||||||
|
|
||||||
|
echo "Extracting $tarball ..."
|
||||||
|
mkdir -p $(dirname $rootfs)
|
||||||
|
(cd `dirname $rootfs` && tar xfz $tarball)
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
install_ubuntu()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
release=$2
|
||||||
|
tarball=$3
|
||||||
|
mkdir -p /var/lock/subsys/
|
||||||
|
|
||||||
|
(
|
||||||
|
flock -x 200
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "Cache repository is busy."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
extract_rootfs $tarball $arch $rootfs
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "Failed to copy rootfs"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
|
||||||
|
) 200>/var/lock/subsys/lxc
|
||||||
|
|
||||||
|
return $?
|
||||||
|
}
|
||||||
|
|
||||||
|
copy_configuration()
|
||||||
|
{
|
||||||
|
path=$1
|
||||||
|
rootfs=$2
|
||||||
|
name=$3
|
||||||
|
|
||||||
|
# if there is exactly one veth network entry, make sure it has an
|
||||||
|
# associated hwaddr.
|
||||||
|
nics=`grep -e '^lxc\.network\.type[ \t]*=[ \t]*veth' $path/config | wc -l`
|
||||||
|
if [ $nics -eq 1 ]; then
|
||||||
|
grep -q "^lxc.network.hwaddr" $path/config || sed -i -e "/^lxc\.network\.type[ \t]*=[ \t]*veth/a lxc.network.hwaddr = 00:16:3e:$(openssl rand -hex 3| sed 's/\(..\)/\1:/g; s/.$//')" $path/config
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "Failed to add configuration"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
post_process()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
|
||||||
|
# rmdir /dev/shm for containers that have /run/shm
|
||||||
|
# I'm afraid of doing rm -rf $rootfs/dev/shm, in case it did
|
||||||
|
# get bind mounted to the host's /run/shm. So try to rmdir
|
||||||
|
# it, and in case that fails move it out of the way.
|
||||||
|
if [ ! -L $rootfs/dev/shm ] && [ -d $rootfs/run/shm ] && [ -e $rootfs/dev/shm ]; then
|
||||||
|
mv $rootfs/dev/shm $rootfs/dev/shm.bak
|
||||||
|
ln -s /run/shm $rootfs/dev/shm
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
usage()
|
||||||
|
{
|
||||||
|
cat <<EOF
|
||||||
|
$1 -h|--help [-a|--arch] [--trim] [-d|--debug]
|
||||||
|
[-F | --flush-cache] [-r|--release <release>] [ -S | --auth-key <keyfile>]
|
||||||
|
release: the ubuntu release (e.g. precise): defaults to host release on ubuntu, otherwise uses latest LTS
|
||||||
|
trim: make a minimal (faster, but not upgrade-safe) container
|
||||||
|
arch: the container architecture (e.g. amd64): defaults to host arch
|
||||||
|
auth-key: SSH Public key file to inject into container
|
||||||
|
EOF
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
options=$(getopt -o a:b:hp:r:xn:FS:d:C -l arch:,help,path:,release:,trim,name:,flush-cache,auth-key:,debug:,tarball: -- "$@")
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
usage $(basename $0)
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
eval set -- "$options"
|
||||||
|
|
||||||
|
release=precise # Default to the last Ubuntu LTS release for non-Ubuntu systems
|
||||||
|
if [ -f /etc/lsb-release ]; then
|
||||||
|
. /etc/lsb-release
|
||||||
|
if [ "$DISTRIB_ID" = "Ubuntu" ]; then
|
||||||
|
release=$DISTRIB_CODENAME
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
arch=$(uname -m)
|
||||||
|
|
||||||
|
# Code taken from debootstrap
|
||||||
|
if [ -x /usr/bin/dpkg ] && /usr/bin/dpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/dpkg --print-architecture`
|
||||||
|
elif type udpkg >/dev/null 2>&1 && udpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/udpkg --print-architecture`
|
||||||
|
else
|
||||||
|
arch=$(uname -m)
|
||||||
|
if [ "$arch" = "i686" ]; then
|
||||||
|
arch="i386"
|
||||||
|
elif [ "$arch" = "x86_64" ]; then
|
||||||
|
arch="amd64"
|
||||||
|
elif [ "$arch" = "armv7l" ]; then
|
||||||
|
arch="armel"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
debug=0
|
||||||
|
trim_container=0
|
||||||
|
hostarch=$arch
|
||||||
|
while true
|
||||||
|
do
|
||||||
|
case "$1" in
|
||||||
|
-h|--help) usage $0 && exit 0;;
|
||||||
|
-p|--path) path=$2; shift 2;;
|
||||||
|
-n|--name) name=$2; shift 2;;
|
||||||
|
-T|--tarball) tarball=$2; shift 2;;
|
||||||
|
-r|--release) release=$2; shift 2;;
|
||||||
|
-a|--arch) arch=$2; shift 2;;
|
||||||
|
-x|--trim) trim_container=1; shift 1;;
|
||||||
|
-S|--auth-key) auth_key=$2; shift 2;;
|
||||||
|
-d|--debug) debug=1; shift 1;;
|
||||||
|
--) shift 1; break ;;
|
||||||
|
*) break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ $debug -eq 1 ]; then
|
||||||
|
set -x
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$arch" == "i686" ]; then
|
||||||
|
arch=i386
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $hostarch = "i386" -a $arch = "amd64" ]; then
|
||||||
|
echo "can't create amd64 container on i386"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$path" ]; then
|
||||||
|
echo "'path' parameter is required"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ]; then
|
||||||
|
echo "This script should be run as 'root'"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# detect rootfs
|
||||||
|
config="$path/config"
|
||||||
|
if grep -q '^lxc.rootfs' $config 2>/dev/null ; then
|
||||||
|
rootfs=`grep 'lxc.rootfs =' $config | awk -F= '{ print $2 }'`
|
||||||
|
else
|
||||||
|
rootfs=$path/rootfs
|
||||||
|
fi
|
||||||
|
|
||||||
|
install_ubuntu $rootfs $release $tarball
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "failed to install ubuntu $release"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
copy_configuration $path $rootfs $name $arch
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "failed write configuration file"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
post_process $rootfs $release $trim_container
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "##"
|
||||||
|
echo "# The default user is 'vagrant' with password 'vagrant'!"
|
||||||
|
echo "# Use the 'sudo' command to run tasks as root in the container."
|
||||||
|
echo "##"
|
||||||
|
echo ""
|
49
boxes/common/lxc.conf
Normal file
49
boxes/common/lxc.conf
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
lxc.network.type=veth
|
||||||
|
lxc.network.link=lxcbr0
|
||||||
|
lxc.network.flags=up
|
||||||
|
|
||||||
|
lxc.pivotdir = lxc_putold
|
||||||
|
|
||||||
|
lxc.devttydir = lxc
|
||||||
|
lxc.tty = 4
|
||||||
|
lxc.pts = 1024
|
||||||
|
|
||||||
|
lxc.arch = amd64
|
||||||
|
lxc.cap.drop = sys_module mac_admin mac_override
|
||||||
|
|
||||||
|
# When using LXC with apparmor, uncomment the next line to run unconfined:
|
||||||
|
#lxc.aa_profile = unconfined
|
||||||
|
|
||||||
|
lxc.cgroup.devices.deny = a
|
||||||
|
# Allow any mknod (but not using the node)
|
||||||
|
lxc.cgroup.devices.allow = c *:* m
|
||||||
|
lxc.cgroup.devices.allow = b *:* m
|
||||||
|
# /dev/null and zero
|
||||||
|
lxc.cgroup.devices.allow = c 1:3 rwm
|
||||||
|
lxc.cgroup.devices.allow = c 1:5 rwm
|
||||||
|
# consoles
|
||||||
|
lxc.cgroup.devices.allow = c 5:1 rwm
|
||||||
|
lxc.cgroup.devices.allow = c 5:0 rwm
|
||||||
|
#lxc.cgroup.devices.allow = c 4:0 rwm
|
||||||
|
#lxc.cgroup.devices.allow = c 4:1 rwm
|
||||||
|
# /dev/{,u}random
|
||||||
|
lxc.cgroup.devices.allow = c 1:9 rwm
|
||||||
|
lxc.cgroup.devices.allow = c 1:8 rwm
|
||||||
|
lxc.cgroup.devices.allow = c 136:* rwm
|
||||||
|
lxc.cgroup.devices.allow = c 5:2 rwm
|
||||||
|
# rtc
|
||||||
|
lxc.cgroup.devices.allow = c 254:0 rwm
|
||||||
|
#fuse
|
||||||
|
lxc.cgroup.devices.allow = c 10:229 rwm
|
||||||
|
#tun
|
||||||
|
lxc.cgroup.devices.allow = c 10:200 rwm
|
||||||
|
#full
|
||||||
|
lxc.cgroup.devices.allow = c 1:7 rwm
|
||||||
|
#hpet
|
||||||
|
lxc.cgroup.devices.allow = c 10:228 rwm
|
||||||
|
#kvm
|
||||||
|
lxc.cgroup.devices.allow = c 10:232 rwm
|
||||||
|
|
||||||
|
# mounts point
|
||||||
|
lxc.mount.entry = proc proc proc nodev,noexec,nosuid 0 0
|
||||||
|
lxc.mount.entry = sysfs sys sysfs defaults 0 0
|
4
boxes/common/metadata.json
Normal file
4
boxes/common/metadata.json
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
{
|
||||||
|
"provider": "lxc",
|
||||||
|
"version": "3"
|
||||||
|
}
|
188
boxes/debian/finalize
Executable file
188
boxes/debian/finalize
Executable file
|
@ -0,0 +1,188 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# This is a modified version of /usr/share/lxc/templates/lxc-debian
|
||||||
|
# that comes with Ubuntu 13.04 changed to suit vagrant-lxc needs
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ -r /etc/default/lxc ]; then
|
||||||
|
. /etc/default/lxc
|
||||||
|
fi
|
||||||
|
|
||||||
|
SUITE=${SUITE:-wheezy}
|
||||||
|
MIRROR=${MIRROR:-http://ftp.debian.org/debian}
|
||||||
|
|
||||||
|
configure_debian()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
hostname=$2
|
||||||
|
release=$2
|
||||||
|
|
||||||
|
# squeeze only has /dev/tty and /dev/tty0 by default,
|
||||||
|
# therefore creating missing device nodes for tty1-4.
|
||||||
|
for tty in $(seq 1 4); do
|
||||||
|
if [ ! -e $rootfs/dev/tty$tty ]; then
|
||||||
|
mknod $rootfs/dev/tty$tty c 4 $tty
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# configure the inittab
|
||||||
|
cat <<EOF > $rootfs/etc/inittab
|
||||||
|
id:3:initdefault:
|
||||||
|
si::sysinit:/etc/init.d/rcS
|
||||||
|
l0:0:wait:/etc/init.d/rc 0
|
||||||
|
l1:1:wait:/etc/init.d/rc 1
|
||||||
|
l2:2:wait:/etc/init.d/rc 2
|
||||||
|
l3:3:wait:/etc/init.d/rc 3
|
||||||
|
l4:4:wait:/etc/init.d/rc 4
|
||||||
|
l5:5:wait:/etc/init.d/rc 5
|
||||||
|
l6:6:wait:/etc/init.d/rc 6
|
||||||
|
# Normally not reached, but fallthrough in case of emergency.
|
||||||
|
z6:6:respawn:/sbin/sulogin
|
||||||
|
1:2345:respawn:/sbin/getty 38400 console
|
||||||
|
#c1:12345:respawn:/sbin/getty 38400 tty1 linux
|
||||||
|
c2:12345:respawn:/sbin/getty 38400 tty2 linux
|
||||||
|
c3:12345:respawn:/sbin/getty 38400 tty3 linux
|
||||||
|
c4:12345:respawn:/sbin/getty 38400 tty4 linux
|
||||||
|
p6::ctrlaltdel:/sbin/init 6
|
||||||
|
p0::powerfail:/sbin/init 0
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# disable selinux in debian
|
||||||
|
mkdir -p $rootfs/selinux
|
||||||
|
echo 0 > $rootfs/selinux/enforce
|
||||||
|
|
||||||
|
# configure the network using the dhcp
|
||||||
|
cat <<EOF > $rootfs/etc/network/interfaces
|
||||||
|
auto lo
|
||||||
|
iface lo inet loopback
|
||||||
|
|
||||||
|
auto eth0
|
||||||
|
iface eth0 inet dhcp
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# set the hostname
|
||||||
|
cat <<EOF > $rootfs/etc/hostname
|
||||||
|
$hostname
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# set the host in case it is not set so that sudo does not complain about the host
|
||||||
|
if ! (grep -q $hostname $rootfs/etc/hosts); then
|
||||||
|
chroot $rootfs sed -i -e \
|
||||||
|
"s/^127.0.0.1\(\s\+\)localhost$/127.0.0.1\1localhost\n127.0.0.1\1${hostname}/g" \
|
||||||
|
/etc/hosts >/dev/null 2>&1 || true
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set default locale
|
||||||
|
cat <<EOF > $rootfs/etc/locale.gen
|
||||||
|
en_US.UTF-8 UTF-8
|
||||||
|
EOF
|
||||||
|
echo "default locale set to en_US.UTF-8 UTF-8"
|
||||||
|
chroot $rootfs locale-gen 'en_US.UTF-8' > /dev/null 2>&1
|
||||||
|
chroot $rootfs update-locale LANG='en_US.UTF-8'
|
||||||
|
echo 'update-locale done'
|
||||||
|
|
||||||
|
# remove pointless services in a container
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f checkroot.sh remove
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f umountfs remove
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f hwclock.sh remove
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f hwclockfirst.sh remove
|
||||||
|
|
||||||
|
echo "root:vagrant" | chroot $rootfs chpasswd
|
||||||
|
|
||||||
|
if ! (grep -q vagrant $rootfs/etc/passwd); then
|
||||||
|
chroot $rootfs useradd --create-home -s /bin/bash vagrant
|
||||||
|
echo "vagrant:vagrant" | chroot $rootfs chpasswd
|
||||||
|
chroot $rootfs adduser vagrant sudo >/dev/null 2>&1 || true
|
||||||
|
chroot $rootfs cp /etc/sudoers /etc/sudoers.orig >/dev/null 2>&1 || true
|
||||||
|
chroot $rootfs sed -i -e \
|
||||||
|
's/%sudo\s\+ALL=(ALL\(:ALL\)\?)\s\+ALL/%sudo ALL=NOPASSWD:ALL/g' \
|
||||||
|
/etc/sudoers >/dev/null 2>&1 || true
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanup()
|
||||||
|
{
|
||||||
|
rm -rf ${cache}/partial
|
||||||
|
rm -rf ${cache}/rootfs
|
||||||
|
}
|
||||||
|
|
||||||
|
add_ssh_key()
|
||||||
|
{
|
||||||
|
user=$1
|
||||||
|
|
||||||
|
if [ -n "$auth_key" -a -f "$auth_key" ]; then
|
||||||
|
u_path="/home/${user}/.ssh"
|
||||||
|
root_u_path="$rootfs/$u_path"
|
||||||
|
|
||||||
|
mkdir -p $root_u_path
|
||||||
|
cp $auth_key "$root_u_path/authorized_keys"
|
||||||
|
chroot $rootfs chown -R ${user}: "$u_path"
|
||||||
|
|
||||||
|
echo "Inserted SSH public key from $auth_key into /home/${user}/.ssh/authorized_keys"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
disable_tmp_cleanup() {
|
||||||
|
rootfs=$1
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f checkroot-bootclean.sh remove
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f mountall-bootclean.sh remove
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f mountnfs-bootclean.sh remove
|
||||||
|
}
|
||||||
|
|
||||||
|
release=wheezy # Default to the last Debian stable release
|
||||||
|
|
||||||
|
arch=$(uname -m)
|
||||||
|
|
||||||
|
# Code taken from debootstrap
|
||||||
|
if [ -x /usr/bin/dpkg ] && /usr/bin/dpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/dpkg --print-architecture`
|
||||||
|
elif type udpkg >/dev/null 2>&1 && udpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/udpkg --print-architecture`
|
||||||
|
else
|
||||||
|
arch=$(uname -m)
|
||||||
|
if [ "$arch" = "i686" ]; then
|
||||||
|
arch="i386"
|
||||||
|
elif [ "$arch" = "x86_64" ]; then
|
||||||
|
arch="amd64"
|
||||||
|
elif [ "$arch" = "armv7l" ]; then
|
||||||
|
arch="armel"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ]; then
|
||||||
|
echo "This script should be run as 'root'"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
declare cache=`readlink -f .` \
|
||||||
|
arch=$1 \
|
||||||
|
release=$2 \
|
||||||
|
auth_key=$3
|
||||||
|
|
||||||
|
# detect rootfs
|
||||||
|
cache=`readlink -f .`
|
||||||
|
rootfs="${cache}/rootfs"
|
||||||
|
|
||||||
|
configure_debian $rootfs $release
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "failed to configure debian $release for a container"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
add_ssh_key vagrant
|
||||||
|
|
||||||
|
# vagrant and / or plugins might mount some shared folders under /tmp by default
|
||||||
|
# (like puppet manifests) and we need to make sure no shared folder gets its
|
||||||
|
# contents removed because of it. For more information, please check:
|
||||||
|
# https://github.com/fgrehm/vagrant-lxc/issues/68
|
||||||
|
disable_tmp_cleanup $rootfs
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "##"
|
||||||
|
echo "# The default user is 'vagrant' with password 'vagrant'!"
|
||||||
|
echo "# Use the 'sudo' command to run tasks as root in the container."
|
||||||
|
echo "##"
|
||||||
|
echo ""
|
367
boxes/ubuntu/finalize
Executable file
367
boxes/ubuntu/finalize
Executable file
|
@ -0,0 +1,367 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# This is a modified version of /usr/share/lxc/templates/lxc-ubuntu
|
||||||
|
# that comes with Ubuntu 13.04 changed to suit vagrant-lxc needs
|
||||||
|
|
||||||
|
#
|
||||||
|
# template script for generating ubuntu container for LXC
|
||||||
|
#
|
||||||
|
# This script consolidates and extends the existing lxc ubuntu scripts
|
||||||
|
#
|
||||||
|
|
||||||
|
# Copyright © 2011 Serge Hallyn <serge.hallyn@canonical.com>
|
||||||
|
# Copyright © 2010 Wilhelm Meier
|
||||||
|
# Author: Wilhelm Meier <wilhelm.meier@fh-kl.de>
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License version 2, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
|
||||||
|
# You should have received a copy of the GNU General Public License along
|
||||||
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ -r /etc/default/lxc ]; then
|
||||||
|
. /etc/default/lxc
|
||||||
|
fi
|
||||||
|
|
||||||
|
configure_ubuntu()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
release=$2
|
||||||
|
hostname=$2
|
||||||
|
|
||||||
|
# configure the network using the dhcp
|
||||||
|
cat <<EOF > $rootfs/etc/network/interfaces
|
||||||
|
# This file describes the network interfaces available on your system
|
||||||
|
# and how to activate them. For more information, see interfaces(5).
|
||||||
|
|
||||||
|
# The loopback network interface
|
||||||
|
auto lo
|
||||||
|
iface lo inet loopback
|
||||||
|
|
||||||
|
auto eth0
|
||||||
|
iface eth0 inet dhcp
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# set the hostname
|
||||||
|
cat <<EOF > $rootfs/etc/hostname
|
||||||
|
$hostname
|
||||||
|
EOF
|
||||||
|
# set minimal hosts
|
||||||
|
cat <<EOF > $rootfs/etc/hosts
|
||||||
|
127.0.0.1 localhost
|
||||||
|
127.0.1.1 $hostname
|
||||||
|
|
||||||
|
# The following lines are desirable for IPv6 capable hosts
|
||||||
|
::1 ip6-localhost ip6-loopback
|
||||||
|
fe00::0 ip6-localnet
|
||||||
|
ff00::0 ip6-mcastprefix
|
||||||
|
ff02::1 ip6-allnodes
|
||||||
|
ff02::2 ip6-allrouters
|
||||||
|
EOF
|
||||||
|
|
||||||
|
if [ ! -f $rootfs/etc/init/container-detect.conf ]; then
|
||||||
|
# suppress log level output for udev
|
||||||
|
sed -i "s/=\"err\"/=0/" $rootfs/etc/udev/udev.conf
|
||||||
|
|
||||||
|
# remove jobs for consoles 5 and 6 since we only create 4 consoles in
|
||||||
|
# this template
|
||||||
|
rm -f $rootfs/etc/init/tty{5,6}.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! (grep -q vagrant $rootfs/etc/passwd); then
|
||||||
|
chroot $rootfs useradd --create-home -s /bin/bash vagrant
|
||||||
|
echo "vagrant:vagrant" | chroot $rootfs chpasswd
|
||||||
|
fi
|
||||||
|
|
||||||
|
# make sure we have the current locale defined in the container
|
||||||
|
chroot $rootfs locale-gen en_US.UTF-8
|
||||||
|
chroot $rootfs update-locale LANG=en_US.UTF-8
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# finish setting up the user in the container by injecting ssh key and
|
||||||
|
# adding sudo group membership.
|
||||||
|
# passed-in user is 'vagrant'
|
||||||
|
finalize_user()
|
||||||
|
{
|
||||||
|
user=$1
|
||||||
|
|
||||||
|
sudo_version=$(chroot $rootfs dpkg-query -W -f='${Version}' sudo)
|
||||||
|
|
||||||
|
if chroot $rootfs dpkg --compare-versions $sudo_version gt "1.8.3p1-1"; then
|
||||||
|
groups="sudo"
|
||||||
|
else
|
||||||
|
groups="sudo admin"
|
||||||
|
fi
|
||||||
|
|
||||||
|
for group in $groups; do
|
||||||
|
chroot $rootfs groupadd --system $group >/dev/null 2>&1 || true
|
||||||
|
chroot $rootfs adduser ${user} $group >/dev/null 2>&1 || true
|
||||||
|
done
|
||||||
|
|
||||||
|
chroot $rootfs cp /etc/sudoers /etc/sudoers.orig >/dev/null 2>&1 || true
|
||||||
|
chroot $rootfs sed -i -e 's/%sudo\s\+ALL=(ALL:ALL)\s\+ALL/%sudo ALL=NOPASSWD:ALL/g' /etc/sudoers >/dev/null 2>&1 || true
|
||||||
|
|
||||||
|
if [ -n "$auth_key" -a -f "$auth_key" ]; then
|
||||||
|
u_path="/home/${user}/.ssh"
|
||||||
|
root_u_path="$rootfs/$u_path"
|
||||||
|
|
||||||
|
mkdir -p $root_u_path
|
||||||
|
cp $auth_key "$root_u_path/authorized_keys"
|
||||||
|
chroot $rootfs chown -R ${user}: "$u_path"
|
||||||
|
|
||||||
|
echo "Inserted SSH public key from $auth_key into /home/${user}/.ssh/authorized_keys"
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
write_sourceslist()
|
||||||
|
{
|
||||||
|
# $1 => path to the rootfs
|
||||||
|
# $2 => architecture we want to add
|
||||||
|
# $3 => whether to use the multi-arch syntax or not
|
||||||
|
|
||||||
|
case $2 in
|
||||||
|
amd64|i386)
|
||||||
|
MIRROR=${MIRROR:-http://archive.ubuntu.com/ubuntu}
|
||||||
|
SECURITY_MIRROR=${SECURITY_MIRROR:-http://security.ubuntu.com/ubuntu}
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
MIRROR=${MIRROR:-http://ports.ubuntu.com/ubuntu-ports}
|
||||||
|
SECURITY_MIRROR=${SECURITY_MIRROR:-http://ports.ubuntu.com/ubuntu-ports}
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
if [ -n "$3" ]; then
|
||||||
|
cat >> "$1/etc/apt/sources.list" << EOF
|
||||||
|
deb [arch=$2] $MIRROR ${release} main restricted universe multiverse
|
||||||
|
deb [arch=$2] $MIRROR ${release}-updates main restricted universe multiverse
|
||||||
|
deb [arch=$2] $SECURITY_MIRROR ${release}-security main restricted universe multiverse
|
||||||
|
EOF
|
||||||
|
else
|
||||||
|
cat >> "$1/etc/apt/sources.list" << EOF
|
||||||
|
deb $MIRROR ${release} main restricted universe multiverse
|
||||||
|
deb $MIRROR ${release}-updates main restricted universe multiverse
|
||||||
|
deb $SECURITY_MIRROR ${release}-security main restricted universe multiverse
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
trim()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
release=$2
|
||||||
|
|
||||||
|
# provide the lxc service
|
||||||
|
cat <<EOF > $rootfs/etc/init/lxc.conf
|
||||||
|
# fake some events needed for correct startup other services
|
||||||
|
|
||||||
|
description "Container Upstart"
|
||||||
|
|
||||||
|
start on startup
|
||||||
|
|
||||||
|
script
|
||||||
|
rm -rf /var/run/*.pid
|
||||||
|
rm -rf /var/run/network/*
|
||||||
|
/sbin/initctl emit stopped JOB=udevtrigger --no-wait
|
||||||
|
/sbin/initctl emit started JOB=udev --no-wait
|
||||||
|
end script
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# fix buggus runlevel with sshd
|
||||||
|
cat <<EOF > $rootfs/etc/init/ssh.conf
|
||||||
|
# ssh - OpenBSD Secure Shell server
|
||||||
|
#
|
||||||
|
# The OpenSSH server provides secure shell access to the system.
|
||||||
|
|
||||||
|
description "OpenSSH server"
|
||||||
|
|
||||||
|
start on filesystem
|
||||||
|
stop on runlevel [!2345]
|
||||||
|
|
||||||
|
expect fork
|
||||||
|
respawn
|
||||||
|
respawn limit 10 5
|
||||||
|
umask 022
|
||||||
|
# replaces SSHD_OOM_ADJUST in /etc/default/ssh
|
||||||
|
oom never
|
||||||
|
|
||||||
|
pre-start script
|
||||||
|
test -x /usr/sbin/sshd || { stop; exit 0; }
|
||||||
|
test -e /etc/ssh/sshd_not_to_be_run && { stop; exit 0; }
|
||||||
|
test -c /dev/null || { stop; exit 0; }
|
||||||
|
|
||||||
|
mkdir -p -m0755 /var/run/sshd
|
||||||
|
end script
|
||||||
|
|
||||||
|
# if you used to set SSHD_OPTS in /etc/default/ssh, you can change the
|
||||||
|
# 'exec' line here instead
|
||||||
|
exec /usr/sbin/sshd
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat <<EOF > $rootfs/etc/init/console.conf
|
||||||
|
# console - getty
|
||||||
|
#
|
||||||
|
# This service maintains a console on tty1 from the point the system is
|
||||||
|
# started until it is shut down again.
|
||||||
|
|
||||||
|
start on stopped rc RUNLEVEL=[2345]
|
||||||
|
stop on runlevel [!2345]
|
||||||
|
|
||||||
|
respawn
|
||||||
|
exec /sbin/getty -8 38400 /dev/console
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat <<EOF > $rootfs/lib/init/fstab
|
||||||
|
# /lib/init/fstab: cleared out for bare-bones lxc
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# remove pointless services in a container
|
||||||
|
chroot $rootfs /usr/sbin/update-rc.d -f ondemand remove
|
||||||
|
|
||||||
|
chroot $rootfs /bin/bash -c 'cd /etc/init; for f in $(ls u*.conf); do mv $f $f.orig; done'
|
||||||
|
chroot $rootfs /bin/bash -c 'cd /etc/init; for f in $(ls tty[2-9].conf); do mv $f $f.orig; done'
|
||||||
|
chroot $rootfs /bin/bash -c 'cd /etc/init; for f in $(ls plymouth*.conf); do mv $f $f.orig; done'
|
||||||
|
chroot $rootfs /bin/bash -c 'cd /etc/init; for f in $(ls hwclock*.conf); do mv $f $f.orig; done'
|
||||||
|
chroot $rootfs /bin/bash -c 'cd /etc/init; for f in $(ls module*.conf); do mv $f $f.orig; done'
|
||||||
|
|
||||||
|
# if this isn't lucid, then we need to twiddle the network upstart bits :(
|
||||||
|
if [ $release != "lucid" ]; then
|
||||||
|
sed -i 's/^.*emission handled.*$/echo Emitting lo/' $rootfs/etc/network/if-up.d/upstart
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
post_process()
|
||||||
|
{
|
||||||
|
rootfs=$1
|
||||||
|
release=$2
|
||||||
|
trim_container=$3
|
||||||
|
|
||||||
|
if [ $trim_container -eq 1 ]; then
|
||||||
|
trim $rootfs $release
|
||||||
|
elif [ ! -f $rootfs/etc/init/container-detect.conf ]; then
|
||||||
|
# Make sure we have a working resolv.conf
|
||||||
|
cresolvonf="${rootfs}/etc/resolv.conf"
|
||||||
|
mv $cresolvonf ${cresolvonf}.lxcbak
|
||||||
|
cat /etc/resolv.conf > ${cresolvonf}
|
||||||
|
|
||||||
|
# for lucid, if not trimming, then add the ubuntu-virt
|
||||||
|
# ppa and install lxcguest
|
||||||
|
if [ $release = "lucid" ]; then
|
||||||
|
chroot $rootfs apt-get update
|
||||||
|
chroot $rootfs apt-get install --force-yes -y python-software-properties
|
||||||
|
chroot $rootfs add-apt-repository ppa:ubuntu-virt/ppa
|
||||||
|
fi
|
||||||
|
|
||||||
|
chroot $rootfs apt-get update
|
||||||
|
chroot $rootfs apt-get install --force-yes -y lxcguest
|
||||||
|
|
||||||
|
# Restore old resolv.conf
|
||||||
|
rm -f ${cresolvonf}
|
||||||
|
mv ${cresolvonf}.lxcbak ${cresolvonf}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# If the container isn't running a native architecture, setup multiarch
|
||||||
|
if [ -x "$(ls -1 ${rootfs}/usr/bin/qemu-*-static 2>/dev/null)" ]; then
|
||||||
|
dpkg_version=$(chroot $rootfs dpkg-query -W -f='${Version}' dpkg)
|
||||||
|
if chroot $rootfs dpkg --compare-versions $dpkg_version ge "1.16.2"; then
|
||||||
|
chroot $rootfs dpkg --add-architecture ${hostarch}
|
||||||
|
else
|
||||||
|
mkdir -p ${rootfs}/etc/dpkg/dpkg.cfg.d
|
||||||
|
echo "foreign-architecture ${hostarch}" > ${rootfs}/etc/dpkg/dpkg.cfg.d/lxc-multiarch
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Save existing value of MIRROR and SECURITY_MIRROR
|
||||||
|
DEFAULT_MIRROR=$MIRROR
|
||||||
|
DEFAULT_SECURITY_MIRROR=$SECURITY_MIRROR
|
||||||
|
|
||||||
|
# Write a new sources.list containing both native and multiarch entries
|
||||||
|
> ${rootfs}/etc/apt/sources.list
|
||||||
|
write_sourceslist $rootfs $arch "native"
|
||||||
|
|
||||||
|
MIRROR=$DEFAULT_MIRROR
|
||||||
|
SECURITY_MIRROR=$DEFAULT_SECURITY_MIRROR
|
||||||
|
write_sourceslist $rootfs $hostarch "multiarch"
|
||||||
|
|
||||||
|
# Finally update the lists and install upstart using the host architecture
|
||||||
|
chroot $rootfs apt-get update
|
||||||
|
chroot $rootfs apt-get install --force-yes -y --no-install-recommends upstart:${hostarch} mountall:${hostarch} iproute:${hostarch} isc-dhcp-client:${hostarch}
|
||||||
|
fi
|
||||||
|
|
||||||
|
# rmdir /dev/shm for containers that have /run/shm
|
||||||
|
# I'm afraid of doing rm -rf $rootfs/dev/shm, in case it did
|
||||||
|
# get bind mounted to the host's /run/shm. So try to rmdir
|
||||||
|
# it, and in case that fails move it out of the way.
|
||||||
|
if [ ! -L $rootfs/dev/shm ] && [ -d $rootfs/run/shm ] && [ -e $rootfs/dev/shm ]; then
|
||||||
|
mv $rootfs/dev/shm $rootfs/dev/shm.bak
|
||||||
|
ln -s /run/shm $rootfs/dev/shm
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
release=precise # Default to the last Ubuntu LTS release for non-Ubuntu systems
|
||||||
|
if [ -f /etc/lsb-release ]; then
|
||||||
|
. /etc/lsb-release
|
||||||
|
if [ "$DISTRIB_ID" = "Ubuntu" ]; then
|
||||||
|
release=$DISTRIB_CODENAME
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
arch=$(uname -m)
|
||||||
|
|
||||||
|
# Code taken from debootstrap
|
||||||
|
if [ -x /usr/bin/dpkg ] && /usr/bin/dpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/dpkg --print-architecture`
|
||||||
|
elif type udpkg >/dev/null 2>&1 && udpkg --print-architecture >/dev/null 2>&1; then
|
||||||
|
arch=`/usr/bin/udpkg --print-architecture`
|
||||||
|
else
|
||||||
|
arch=$(uname -m)
|
||||||
|
if [ "$arch" = "i686" ]; then
|
||||||
|
arch="i386"
|
||||||
|
elif [ "$arch" = "x86_64" ]; then
|
||||||
|
arch="amd64"
|
||||||
|
elif [ "$arch" = "armv7l" ]; then
|
||||||
|
arch="armel"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ]; then
|
||||||
|
echo "This script should be run as 'root'"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
declare cache=`readlink -f .` \
|
||||||
|
arch=$1 \
|
||||||
|
release=$2 \
|
||||||
|
auth_key=$3
|
||||||
|
|
||||||
|
# detect rootfs
|
||||||
|
cache=`readlink -f .`
|
||||||
|
rootfs="${cache}/rootfs"
|
||||||
|
|
||||||
|
configure_ubuntu $rootfs $release
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "failed to configure ubuntu $release for a container"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
post_process $rootfs $release $trim_container
|
||||||
|
|
||||||
|
finalize_user vagrant
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "##"
|
||||||
|
echo "# The default user is 'vagrant' with password 'vagrant'!"
|
||||||
|
echo "# Use the 'sudo' command to run tasks as root in the container."
|
||||||
|
echo "##"
|
||||||
|
echo ""
|
|
@ -11,6 +11,8 @@ module Vagrant
|
||||||
|
|
||||||
config = env[:machine].provider_config
|
config = env[:machine].provider_config
|
||||||
|
|
||||||
|
config.customize 'utsname', env[:machine].id
|
||||||
|
|
||||||
env[:ui].info I18n.t("vagrant_lxc.messages.starting")
|
env[:ui].info I18n.t("vagrant_lxc.messages.starting")
|
||||||
env[:machine].provider.driver.start(config.customizations)
|
env[:machine].provider.driver.start(config.customizations)
|
||||||
raise Vagrant::Errors::VMFailedToBoot if !wait_for_boot
|
raise Vagrant::Errors::VMFailedToBoot if !wait_for_boot
|
||||||
|
|
|
@ -14,6 +14,7 @@ module Vagrant
|
||||||
env[:machine].provider.driver.create(
|
env[:machine].provider.driver.create(
|
||||||
container_name,
|
container_name,
|
||||||
env[:lxc_template_src],
|
env[:lxc_template_src],
|
||||||
|
env[:lxc_template_config],
|
||||||
env[:lxc_template_opts]
|
env[:lxc_template_opts]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@ module Vagrant
|
||||||
module Action
|
module Action
|
||||||
# Prepare arguments to be used for lxc-create
|
# Prepare arguments to be used for lxc-create
|
||||||
class HandleBoxMetadata
|
class HandleBoxMetadata
|
||||||
|
SUPPORTED_VERSIONS = [2, 3]
|
||||||
def initialize(app, env)
|
def initialize(app, env)
|
||||||
@app = app
|
@app = app
|
||||||
@logger = Log4r::Logger.new("vagrant::lxc::action::handle_box_metadata")
|
@logger = Log4r::Logger.new("vagrant::lxc::action::handle_box_metadata")
|
||||||
|
@ -22,6 +23,10 @@ module Vagrant
|
||||||
@env[:lxc_template_opts] = template_opts
|
@env[:lxc_template_opts] = template_opts
|
||||||
@env[:lxc_template_src] = template_src
|
@env[:lxc_template_src] = template_src
|
||||||
|
|
||||||
|
if template_config_file.exist?
|
||||||
|
@env[:lxc_template_config] = template_config_file.to_s
|
||||||
|
end
|
||||||
|
|
||||||
@app.call env
|
@app.call env
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -29,9 +34,15 @@ module Vagrant
|
||||||
@template_src ||= @box.directory.join('lxc-template').to_s
|
@template_src ||= @box.directory.join('lxc-template').to_s
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def template_config_file
|
||||||
|
@template_config_file ||= @box.directory.join('lxc.conf')
|
||||||
|
end
|
||||||
|
|
||||||
def template_opts
|
def template_opts
|
||||||
@template_opts ||= @box.metadata.fetch('template-opts', {}).dup.merge!(
|
@template_opts ||= @box.metadata.fetch('template-opts', {}).dup.merge!(
|
||||||
'--tarball' => rootfs_tarball,
|
'--tarball' => rootfs_tarball,
|
||||||
|
# TODO: Deprecate this, the rootfs should be ready for vagrant-lxc
|
||||||
|
# SSH access at this point
|
||||||
'--auth-key' => Vagrant.source_root.join('keys', 'vagrant.pub').expand_path.to_s
|
'--auth-key' => Vagrant.source_root.join('keys', 'vagrant.pub').expand_path.to_s
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -41,8 +52,10 @@ module Vagrant
|
||||||
end
|
end
|
||||||
|
|
||||||
def validate_box
|
def validate_box
|
||||||
if @box.metadata.fetch('version').to_i != 2
|
unless SUPPORTED_VERSIONS.include? @box.metadata.fetch('version').to_i
|
||||||
raise Errors::InvalidBoxVersion.new name: @box.name
|
raise Errors::IncompatibleBox.new name: @box.name,
|
||||||
|
found: @box.metadata.fetch('version').to_i,
|
||||||
|
supported: SUPPORTED_VERSIONS.join(' and ')
|
||||||
end
|
end
|
||||||
|
|
||||||
unless File.exists?(template_src)
|
unless File.exists?(template_src)
|
||||||
|
|
|
@ -45,6 +45,9 @@ module Vagrant
|
||||||
box_dir = @env[:machine].box.directory
|
box_dir = @env[:machine].box.directory
|
||||||
FileUtils.cp box_dir.join('lxc-template').to_s, @env['package.directory'].to_s
|
FileUtils.cp box_dir.join('lxc-template').to_s, @env['package.directory'].to_s
|
||||||
FileUtils.cp box_dir.join('metadata.json').to_s, @env['package.directory'].to_s
|
FileUtils.cp box_dir.join('metadata.json').to_s, @env['package.directory'].to_s
|
||||||
|
if (conf = box_dir.join('lxc.conf')).exist?
|
||||||
|
FileUtils.cp conf.to_s, @env['package.directory'].to_s
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -30,15 +30,15 @@ module Vagrant
|
||||||
end
|
end
|
||||||
|
|
||||||
def rootfs_path
|
def rootfs_path
|
||||||
Pathname.new(base_path.join('config').read.match(/^lxc\.rootfs\s+=\s+(.+)$/)[1])
|
Pathname.new(base_path.join('rootfs'))
|
||||||
end
|
end
|
||||||
|
|
||||||
def create(name, template_path, template_options = {})
|
def create(name, template_path, config_file, template_options = {})
|
||||||
@cli.name = @container_name = name
|
@cli.name = @container_name = name
|
||||||
|
|
||||||
import_template(template_path) do |template_name|
|
import_template(template_path) do |template_name|
|
||||||
@logger.debug "Creating container..."
|
@logger.debug "Creating container..."
|
||||||
@cli.create template_name, template_options
|
@cli.create template_name, config_file, template_options
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -65,6 +65,7 @@ module Vagrant
|
||||||
extra = ['-o', ENV['LXC_START_LOG_FILE'], '-l', 'DEBUG']
|
extra = ['-o', ENV['LXC_START_LOG_FILE'], '-l', 'DEBUG']
|
||||||
end
|
end
|
||||||
customizations = customizations + @customizations
|
customizations = customizations + @customizations
|
||||||
|
customizations += [['rootfs', rootfs_path.to_s]]
|
||||||
|
|
||||||
@cli.transition_to(:running) { |c| c.start(customizations, (extra || nil)) }
|
@cli.transition_to(:running) { |c| c.start(customizations, (extra || nil)) }
|
||||||
end
|
end
|
||||||
|
|
|
@ -46,13 +46,18 @@ module Vagrant
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def create(template, template_opts = {})
|
def create(template, config_file, template_opts = {})
|
||||||
|
if config_file
|
||||||
|
config_opts = ['-f', config_file]
|
||||||
|
end
|
||||||
|
|
||||||
extra = template_opts.to_a.flatten
|
extra = template_opts.to_a.flatten
|
||||||
extra.unshift '--' unless extra.empty?
|
extra.unshift '--' unless extra.empty?
|
||||||
|
|
||||||
run :create,
|
run :create,
|
||||||
'--template', template,
|
'--template', template,
|
||||||
'--name', @name,
|
'--name', @name,
|
||||||
|
*(config_opts),
|
||||||
*extra
|
*extra
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -14,8 +14,8 @@ module Vagrant
|
||||||
class RootFSTarballMissing < Vagrant::Errors::VagrantError
|
class RootFSTarballMissing < Vagrant::Errors::VagrantError
|
||||||
error_key(:lxc_invalid_box_version)
|
error_key(:lxc_invalid_box_version)
|
||||||
end
|
end
|
||||||
class InvalidBoxVersion < Vagrant::Errors::VagrantError
|
class IncompatibleBox < Vagrant::Errors::VagrantError
|
||||||
error_key(:lxc_invalid_box_version)
|
error_key(:lxc_incompatible_box)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -33,6 +33,10 @@ en:
|
||||||
For more information on the failure, enable detailed logging by setting
|
For more information on the failure, enable detailed logging by setting
|
||||||
the environment variable VAGRANT_LOG to DEBUG.
|
the environment variable VAGRANT_LOG to DEBUG.
|
||||||
|
|
||||||
|
lxc_incompatible_box: |-
|
||||||
|
The base box you are trying to use is not compatible with the installed
|
||||||
|
vagrant-lxc version. Supported box versions are %{supported} but %{found} was found.
|
||||||
|
|
||||||
lxc_template_file_missing: |-
|
lxc_template_file_missing: |-
|
||||||
The template file used for creating the container was not found for %{name}
|
The template file used for creating the container was not found for %{name}
|
||||||
box.
|
box.
|
||||||
|
|
|
@ -50,7 +50,7 @@ describe Vagrant::LXC::Action::HandleBoxMetadata do
|
||||||
metadata['version'] = '1'
|
metadata['version'] = '1'
|
||||||
expect {
|
expect {
|
||||||
subject.call(env)
|
subject.call(env)
|
||||||
}.to raise_error(Vagrant::LXC::Errors::InvalidBoxVersion)
|
}.to raise_error(Vagrant::LXC::Errors::IncompatibleBox)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'raises an error if the rootfs tarball cant be found' do
|
it 'raises an error if the rootfs tarball cant be found' do
|
||||||
|
|
|
@ -14,18 +14,21 @@ describe Vagrant::LXC::Action::SetupPackageFiles do
|
||||||
|
|
||||||
before do
|
before do
|
||||||
box.directory.mkdir
|
box.directory.mkdir
|
||||||
[box.directory.join('lxc-template'), box.directory.join('metadata.json'), rootfs_path].each do |file|
|
files = %w( lxc-template metadata.json lxc.conf ).map { |f| box.directory.join(f) }
|
||||||
|
(files + [rootfs_path]).each do |file|
|
||||||
file.open('w') { |f| f.puts file.to_s }
|
file.open('w') { |f| f.puts file.to_s }
|
||||||
end
|
end
|
||||||
|
|
||||||
subject.stub(recover: true) # Prevents files from being removed on specs
|
subject.stub(recover: true) # Prevents files from being removed on specs
|
||||||
subject.call(env)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
after do
|
after do
|
||||||
FileUtils.rm_rf(tmp_path.to_s)
|
FileUtils.rm_rf(tmp_path.to_s)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'when all files exist' do
|
||||||
|
before { subject.call(env) }
|
||||||
|
|
||||||
it 'copies box lxc-template to package directory' do
|
it 'copies box lxc-template to package directory' do
|
||||||
env['package.directory'].join('lxc-template').should be_file
|
env['package.directory'].join('lxc-template').should be_file
|
||||||
end
|
end
|
||||||
|
@ -34,8 +37,23 @@ describe Vagrant::LXC::Action::SetupPackageFiles do
|
||||||
env['package.directory'].join('metadata.json').should be_file
|
env['package.directory'].join('metadata.json').should be_file
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'copies box lxc.conf to package directory' do
|
||||||
|
env['package.directory'].join('lxc-template').should be_file
|
||||||
|
end
|
||||||
|
|
||||||
it 'moves the compressed rootfs to package directory' do
|
it 'moves the compressed rootfs to package directory' do
|
||||||
env['package.directory'].join(rootfs_path.basename).should be_file
|
env['package.directory'].join(rootfs_path.basename).should be_file
|
||||||
env['package.rootfs'].should_not be_file
|
env['package.rootfs'].should_not be_file
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when lxc.conf file is not present' do
|
||||||
|
before do
|
||||||
|
box.directory.join('lxc.conf').delete
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'does not blow up' do
|
||||||
|
expect { subject.call(env) }.to_not raise_error
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -38,13 +38,14 @@ describe Vagrant::LXC::Driver::CLI do
|
||||||
describe 'create' do
|
describe 'create' do
|
||||||
let(:template) { 'quantal-64' }
|
let(:template) { 'quantal-64' }
|
||||||
let(:name) { 'quantal-container' }
|
let(:name) { 'quantal-container' }
|
||||||
|
let(:config_file) { 'config' }
|
||||||
let(:template_args) { { '--extra-param' => 'param', '--other' => 'value' } }
|
let(:template_args) { { '--extra-param' => 'param', '--other' => 'value' } }
|
||||||
|
|
||||||
subject { described_class.new(name) }
|
subject { described_class.new(name) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
subject.stub(:run) { |*args| @run_args = args }
|
subject.stub(:run) { |*args| @run_args = args }
|
||||||
subject.create(template, template_args)
|
subject.create(template, config_file, template_args)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'issues a lxc-create with provided template, container name and hash of arguments' do
|
it 'issues a lxc-create with provided template, container name and hash of arguments' do
|
||||||
|
@ -52,6 +53,7 @@ describe Vagrant::LXC::Driver::CLI do
|
||||||
:create,
|
:create,
|
||||||
'--template', template,
|
'--template', template,
|
||||||
'--name', name,
|
'--name', name,
|
||||||
|
'-f', config_file,
|
||||||
'--',
|
'--',
|
||||||
'--extra-param', 'param',
|
'--extra-param', 'param',
|
||||||
'--other', 'value'
|
'--other', 'value'
|
||||||
|
|
|
@ -35,6 +35,7 @@ describe Vagrant::LXC::Driver do
|
||||||
let(:template_name) { 'auto-assigned-template-id' }
|
let(:template_name) { 'auto-assigned-template-id' }
|
||||||
let(:template_path) { '/path/to/lxc-template-from-box' }
|
let(:template_path) { '/path/to/lxc-template-from-box' }
|
||||||
let(:template_opts) { {'--some' => 'random-option'} }
|
let(:template_opts) { {'--some' => 'random-option'} }
|
||||||
|
let(:config_file) { '/path/to/lxc-config-from-box' }
|
||||||
let(:rootfs_tarball) { '/path/to/cache/rootfs.tar.gz' }
|
let(:rootfs_tarball) { '/path/to/cache/rootfs.tar.gz' }
|
||||||
let(:cli) { fire_double('Vagrant::LXC::Driver::CLI', :create => true, :name= => true) }
|
let(:cli) { fire_double('Vagrant::LXC::Driver::CLI', :create => true, :name= => true) }
|
||||||
|
|
||||||
|
@ -42,7 +43,7 @@ describe Vagrant::LXC::Driver do
|
||||||
|
|
||||||
before do
|
before do
|
||||||
subject.stub(:import_template).and_yield(template_name)
|
subject.stub(:import_template).and_yield(template_name)
|
||||||
subject.create name, template_path, template_opts
|
subject.create name, template_path, config_file, template_opts
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'sets the cli object container name' do
|
it 'sets the cli object container name' do
|
||||||
|
@ -52,6 +53,7 @@ describe Vagrant::LXC::Driver do
|
||||||
it 'creates container with the right arguments' do
|
it 'creates container with the right arguments' do
|
||||||
cli.should have_received(:create).with(
|
cli.should have_received(:create).with(
|
||||||
template_name,
|
template_name,
|
||||||
|
config_file,
|
||||||
template_opts
|
template_opts
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -72,6 +74,7 @@ describe Vagrant::LXC::Driver do
|
||||||
describe 'start' do
|
describe 'start' do
|
||||||
let(:customizations) { [['a', '1'], ['b', '2']] }
|
let(:customizations) { [['a', '1'], ['b', '2']] }
|
||||||
let(:internal_customization) { ['internal', 'customization'] }
|
let(:internal_customization) { ['internal', 'customization'] }
|
||||||
|
let(:rootfs) { ['rootfs', subject.rootfs_path.to_s] }
|
||||||
let(:cli) { fire_double('Vagrant::LXC::Driver::CLI', start: true) }
|
let(:cli) { fire_double('Vagrant::LXC::Driver::CLI', start: true) }
|
||||||
|
|
||||||
subject { described_class.new('name', cli) }
|
subject { described_class.new('name', cli) }
|
||||||
|
@ -83,7 +86,7 @@ describe Vagrant::LXC::Driver do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'starts container with configured customizations' do
|
it 'starts container with configured customizations' do
|
||||||
cli.should have_received(:start).with(customizations + [internal_customization], nil)
|
cli.should have_received(:start).with(customizations + [internal_customization, rootfs], nil)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'expects a transition to running state to take place' do
|
it 'expects a transition to running state to take place' do
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
require 'pathname'
|
require 'pathname'
|
||||||
require 'rake/tasklib'
|
require 'rake/tasklib'
|
||||||
|
|
||||||
class BuildGenericBoxTask < ::Rake::TaskLib
|
class BuildGenericBoxTaskV2 < ::Rake::TaskLib
|
||||||
include ::Rake::DSL
|
include ::Rake::DSL
|
||||||
|
|
||||||
attr_reader :name
|
attr_reader :name
|
||||||
|
@ -39,7 +39,7 @@ class BuildGenericBoxTask < ::Rake::TaskLib
|
||||||
if script.readable?
|
if script.readable?
|
||||||
sh "sudo #{script} #{args.join(' ')}"
|
sh "sudo #{script} #{args.join(' ')}"
|
||||||
else
|
else
|
||||||
STDERR.puts "cannot execute #{install_path} (not found?)"
|
STDERR.puts "cannot execute #{script_name} (not found?)"
|
||||||
exit 1
|
exit 1
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -110,13 +110,13 @@ class BuildGenericBoxTask < ::Rake::TaskLib
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class BuildDebianBoxTask < BuildGenericBoxTask
|
class BuildDebianBoxTaskV2 < BuildGenericBoxTaskV2
|
||||||
def initialize(name, release, arch, opts = {})
|
def initialize(name, release, arch, opts = {})
|
||||||
super(name, 'debian', release, arch, opts)
|
super(name, 'debian', release, arch, opts)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class BuildUbuntuBoxTask < BuildGenericBoxTask
|
class BuildUbuntuBoxTaskV2 < BuildGenericBoxTaskV2
|
||||||
def initialize(name, release, arch, opts = {})
|
def initialize(name, release, arch, opts = {})
|
||||||
super(name, 'ubuntu', release, arch, opts)
|
super(name, 'ubuntu', release, arch, opts)
|
||||||
end
|
end
|
||||||
|
@ -127,24 +127,25 @@ puppet = ENV['PUPPET'] == '1'
|
||||||
babushka = ENV['BABUSHKA'] == '1'
|
babushka = ENV['BABUSHKA'] == '1'
|
||||||
|
|
||||||
namespace :boxes do
|
namespace :boxes do
|
||||||
|
namespace :v2 do
|
||||||
namespace :ubuntu do
|
namespace :ubuntu do
|
||||||
namespace :build do
|
namespace :build do
|
||||||
|
|
||||||
desc 'Build an Ubuntu Precise 64 bits box'
|
desc 'Build an Ubuntu Precise 64 bits box'
|
||||||
BuildUbuntuBoxTask.
|
BuildUbuntuBoxTaskV2.
|
||||||
new(:precise64,
|
new(:precise64,
|
||||||
:precise, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
:precise, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
desc 'Build an Ubuntu Quantal 64 bits box'
|
desc 'Build an Ubuntu Quantal 64 bits box'
|
||||||
BuildUbuntuBoxTask.
|
BuildUbuntuBoxTaskV2.
|
||||||
new(:quantal64,
|
new(:quantal64,
|
||||||
:quantal, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
:quantal, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
# FIXME: Find out how to install chef on raring
|
# FIXME: Find out how to install chef on raring
|
||||||
desc 'Build an Ubuntu Raring 64 bits box'
|
desc 'Build an Ubuntu Raring 64 bits box'
|
||||||
BuildUbuntuBoxTask.
|
BuildUbuntuBoxTaskV2.
|
||||||
new(:raring64,
|
new(:raring64,
|
||||||
:raring, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
:raring, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
desc 'Build all Ubuntu boxes'
|
desc 'Build all Ubuntu boxes'
|
||||||
task :all => %w( precise64 quantal64 raring64 )
|
task :all => %w( precise64 quantal64 raring64 )
|
||||||
|
@ -155,17 +156,17 @@ namespace :boxes do
|
||||||
namespace :debian do
|
namespace :debian do
|
||||||
namespace :build do
|
namespace :build do
|
||||||
desc 'Build an Debian Squeeze 64 bits box'
|
desc 'Build an Debian Squeeze 64 bits box'
|
||||||
BuildDebianBoxTask.
|
BuildDebianBoxTaskV2.
|
||||||
new(:squeeze64,
|
new(:squeeze64,
|
||||||
:squeeze, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
:squeeze, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
desc 'Build an Debian Wheezy 64 bits box'
|
desc 'Build an Debian Wheezy 64 bits box'
|
||||||
BuildDebianBoxTask.
|
BuildDebianBoxTaskV2.
|
||||||
new(:wheezy64,
|
new(:wheezy64,
|
||||||
:wheezy, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
:wheezy, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
desc 'Build an Debian Sid/unstable 64 bits box'
|
desc 'Build an Debian Sid/unstable 64 bits box'
|
||||||
BuildDebianBoxTask.
|
BuildDebianBoxTaskV2.
|
||||||
new(:sid64,
|
new(:sid64,
|
||||||
:sid, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
:sid, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
@ -176,4 +177,5 @@ namespace :boxes do
|
||||||
|
|
||||||
desc 'Build all base boxes for release'
|
desc 'Build all base boxes for release'
|
||||||
task :build_all => %w( ubuntu:build:all debian:build:all )
|
task :build_all => %w( ubuntu:build:all debian:build:all )
|
||||||
|
end
|
||||||
end
|
end
|
113
tasks/boxes.v3.rake
Normal file
113
tasks/boxes.v3.rake
Normal file
|
@ -0,0 +1,113 @@
|
||||||
|
require 'pathname'
|
||||||
|
require 'rake/tasklib'
|
||||||
|
load 'tasks/boxes.v2.rake'
|
||||||
|
|
||||||
|
class BuildGenericBoxTaskV3 < BuildGenericBoxTaskV2
|
||||||
|
def build
|
||||||
|
check_if_box_has_been_built!
|
||||||
|
|
||||||
|
FileUtils.mkdir_p 'boxes/temp' unless File.exist? 'base/temp'
|
||||||
|
check_for_partially_built_box!
|
||||||
|
|
||||||
|
pwd = Dir.pwd
|
||||||
|
sh 'mkdir -p boxes/temp/'
|
||||||
|
Dir.chdir 'boxes/temp' do
|
||||||
|
download
|
||||||
|
install_cfg_engines
|
||||||
|
finalize
|
||||||
|
prepare_package_contents pwd
|
||||||
|
sh 'sudo rm -rf rootfs'
|
||||||
|
sh "tar -czf tmp-package.box ./*"
|
||||||
|
end
|
||||||
|
|
||||||
|
sh 'mkdir -p boxes/output'
|
||||||
|
sh "cp boxes/temp/tmp-package.box boxes/output/#{@file}"
|
||||||
|
sh "rm -rf boxes/temp"
|
||||||
|
end
|
||||||
|
|
||||||
|
def finalize
|
||||||
|
require 'vagrant'
|
||||||
|
auth_key = Vagrant.source_root.join('keys', 'vagrant.pub').expand_path.to_s
|
||||||
|
run 'finalize', @arch, @release, auth_key
|
||||||
|
end
|
||||||
|
|
||||||
|
def prepare_package_contents(pwd)
|
||||||
|
run 'cleanup'
|
||||||
|
sh 'sudo rm -f rootfs.tar.gz'
|
||||||
|
sh 'sudo tar --numeric-owner -czf rootfs.tar.gz ./rootfs/*'
|
||||||
|
sh "sudo chown #{ENV['USER']}:#{`id -gn`.strip} rootfs.tar.gz"
|
||||||
|
sh "cp #{pwd}/boxes/common/lxc-template ."
|
||||||
|
sh "cp #{pwd}/boxes/common/lxc.conf ."
|
||||||
|
sh "cp #{pwd}/boxes/common/metadata.json ."
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class BuildDebianBoxTaskV3 < BuildGenericBoxTaskV3
|
||||||
|
def initialize(name, release, arch, opts = {})
|
||||||
|
super(name, 'debian', release, arch, opts)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class BuildUbuntuBoxTaskV3 < BuildGenericBoxTaskV3
|
||||||
|
def initialize(name, release, arch, opts = {})
|
||||||
|
super(name, 'ubuntu', release, arch, opts)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
chef = ENV['CHEF'] == '1'
|
||||||
|
puppet = ENV['PUPPET'] == '1'
|
||||||
|
babushka = ENV['BABUSHKA'] == '1'
|
||||||
|
|
||||||
|
namespace :boxes do
|
||||||
|
namespace :v3 do
|
||||||
|
namespace :ubuntu do
|
||||||
|
namespace :build do
|
||||||
|
|
||||||
|
desc 'Build an Ubuntu Precise 64 bits box'
|
||||||
|
BuildUbuntuBoxTaskV3.
|
||||||
|
new(:precise64,
|
||||||
|
:precise, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
desc 'Build an Ubuntu Quantal 64 bits box'
|
||||||
|
BuildUbuntuBoxTaskV3.
|
||||||
|
new(:quantal64,
|
||||||
|
:quantal, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
# FIXME: Find out how to install chef on raring
|
||||||
|
desc 'Build an Ubuntu Raring 64 bits box'
|
||||||
|
BuildUbuntuBoxTaskV3.
|
||||||
|
new(:raring64,
|
||||||
|
:raring, 'amd64', chef: chef, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
desc 'Build all Ubuntu boxes'
|
||||||
|
task :all => %w( precise64 quantal64 raring64 )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# FIXME: Find out how to install chef on debian boxes
|
||||||
|
namespace :debian do
|
||||||
|
namespace :build do
|
||||||
|
desc 'Build an Debian Squeeze 64 bits box'
|
||||||
|
BuildDebianBoxTaskV3.
|
||||||
|
new(:squeeze64,
|
||||||
|
:squeeze, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
desc 'Build an Debian Wheezy 64 bits box'
|
||||||
|
BuildDebianBoxTaskV3.
|
||||||
|
new(:wheezy64,
|
||||||
|
:wheezy, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
desc 'Build an Debian Sid/unstable 64 bits box'
|
||||||
|
BuildDebianBoxTaskV3.
|
||||||
|
new(:sid64,
|
||||||
|
:sid, 'amd64', chef: false, puppet: puppet, babushka: babushka)
|
||||||
|
|
||||||
|
desc 'Build all Debian boxes'
|
||||||
|
task :all => %w( squeeze64 wheezy64 sid64 )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
desc 'Build all base boxes for release'
|
||||||
|
task :build_all => %w( ubuntu:build:all debian:build:all )
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue