2012-11-19 09:43:42 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2012-12-06 16:00:15 +00:00
|
|
|
echo "Building base image"
|
2012-11-19 09:43:42 +00:00
|
|
|
|
2012-12-18 15:44:21 +00:00
|
|
|
DIR=$(dirname `readlink -f $0`)
|
|
|
|
. $DIR/../testing.conf
|
|
|
|
. $DIR/function.sh
|
2012-11-19 09:43:42 +00:00
|
|
|
|
2012-12-06 16:00:15 +00:00
|
|
|
[ `id -u` -eq 0 ] || die "You must be root to run $0"
|
2014-10-10 16:37:13 +00:00
|
|
|
running_any $STRONGSWANHOSTS && die "Please stop test environment before running $0"
|
2012-12-06 16:00:15 +00:00
|
|
|
|
2012-12-09 09:23:37 +00:00
|
|
|
check_commands debootstrap mkfs.ext3 partprobe qemu-img qemu-nbd sfdisk
|
2012-12-09 08:49:04 +00:00
|
|
|
|
2012-12-09 17:40:02 +00:00
|
|
|
# package includes/excludes
|
2018-10-05 15:44:55 +00:00
|
|
|
INC=automake,autoconf,libtool,bison,flex,gperf,pkg-config,gettext,less,locales
|
2014-08-29 14:22:49 +00:00
|
|
|
INC=$INC,build-essential,libgmp-dev,libldap2-dev,libcurl4-openssl-dev,ethtool
|
2012-12-09 17:40:02 +00:00
|
|
|
INC=$INC,libxml2-dev,libtspi-dev,libsqlite3-dev,openssh-server,tcpdump,psmisc
|
2020-08-24 14:19:34 +00:00
|
|
|
INC=$INC,openssl,vim,sqlite3,conntrack,gdb,cmake,libltdl-dev,wget,gnupg,man-db
|
|
|
|
INC=$INC,libboost-thread-dev,libboost-system-dev,git,iperf,htop,valgrind,strace
|
2015-11-20 16:50:29 +00:00
|
|
|
INC=$INC,gnat,gprbuild,acpid,acpi-support-base,libldns-dev,libunbound-dev
|
2017-10-17 09:52:08 +00:00
|
|
|
INC=$INC,dnsutils,libsoup2.4-dev,ca-certificates,unzip,libsystemd-dev
|
2015-12-08 14:22:15 +00:00
|
|
|
INC=$INC,python,python-setuptools,python-dev,python-pip,apt-transport-https
|
2018-09-14 11:43:51 +00:00
|
|
|
INC=$INC,libjson-c-dev,libxslt1-dev,libapache2-mod-wsgi,iptables-dev
|
2018-09-18 15:17:27 +00:00
|
|
|
INC=$INC,libxerces-c-dev,libgcrypt20-dev,traceroute
|
2015-11-20 16:50:29 +00:00
|
|
|
case "$BASEIMGSUITE" in
|
|
|
|
jessie)
|
2018-09-14 11:43:51 +00:00
|
|
|
INC=$INC,libahven4-dev,libxmlada5-dev,libgmpada5-dev
|
|
|
|
INC=$INC,libalog1-dev
|
|
|
|
;;
|
|
|
|
stretch)
|
|
|
|
INC=$INC,libahven5-dev,libxmlada-schema6-dev,libgmpada6-dev
|
|
|
|
INC=$INC,libalog2-dev
|
2015-11-20 16:50:29 +00:00
|
|
|
;;
|
2020-07-28 15:20:31 +00:00
|
|
|
buster)
|
|
|
|
INC=$INC,libahven7-dev,libxmlada-schema8-dev,libgmpada8-dev
|
|
|
|
INC=$INC,libalog4-dev,dbus-user-session
|
|
|
|
;;
|
2015-11-20 16:50:29 +00:00
|
|
|
*)
|
|
|
|
echo_warn "Package list for '$BASEIMGSUITE' might has to be updated"
|
2020-07-28 15:20:31 +00:00
|
|
|
;;
|
2015-11-20 16:50:29 +00:00
|
|
|
esac
|
2018-09-14 12:41:36 +00:00
|
|
|
SERVICES="apache2 dbus isc-dhcp-server slapd bind9 freeradius"
|
2012-12-09 17:40:02 +00:00
|
|
|
INC=$INC,${SERVICES// /,}
|
2018-10-05 16:14:31 +00:00
|
|
|
# packages to install via APT, for SWIMA tests
|
|
|
|
APT="tmux"
|
2018-10-02 10:38:04 +00:00
|
|
|
# additional services to disable
|
|
|
|
SERVICES="$SERVICES systemd-timesyncd.service"
|
2012-12-07 16:54:19 +00:00
|
|
|
|
2012-11-19 09:43:42 +00:00
|
|
|
CACHEDIR=$BUILDDIR/cache
|
|
|
|
APTCACHE=$LOOPDIR/var/cache/apt/archives
|
|
|
|
|
|
|
|
mkdir -p $LOOPDIR
|
|
|
|
mkdir -p $CACHEDIR
|
2012-12-14 14:38:10 +00:00
|
|
|
mkdir -p $IMGDIR
|
2012-12-10 09:05:02 +00:00
|
|
|
rm -f $BASEIMG
|
2012-11-19 09:43:42 +00:00
|
|
|
|
2012-12-10 09:05:02 +00:00
|
|
|
echo "`date`, building $BASEIMG" >>$LOGFILE
|
2012-12-07 16:54:19 +00:00
|
|
|
|
|
|
|
load_qemu_nbd
|
|
|
|
|
2012-12-10 09:05:02 +00:00
|
|
|
log_action "Creating base image $BASEIMG"
|
|
|
|
execute "qemu-img create -f $IMGEXT $BASEIMG ${BASEIMGSIZE}M"
|
2012-12-07 16:54:19 +00:00
|
|
|
|
|
|
|
log_action "Connecting image to NBD device $NBDEV"
|
2012-12-10 09:05:02 +00:00
|
|
|
execute "qemu-nbd -c $NBDEV $BASEIMG"
|
2012-12-09 09:50:28 +00:00
|
|
|
do_on_exit qemu-nbd -d $NBDEV
|
2012-12-07 16:54:19 +00:00
|
|
|
|
|
|
|
log_action "Partitioning disk"
|
2016-04-25 17:31:12 +00:00
|
|
|
sfdisk /dev/nbd0 >>$LOGFILE 2>&1 << EOF
|
2012-12-07 16:54:19 +00:00
|
|
|
;
|
|
|
|
EOF
|
|
|
|
if [ $? != 0 ]
|
|
|
|
then
|
|
|
|
log_status 1
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
log_status 0
|
|
|
|
fi
|
2012-12-09 09:23:37 +00:00
|
|
|
partprobe $NBDEV
|
2012-12-06 15:25:13 +00:00
|
|
|
|
|
|
|
log_action "Creating ext3 filesystem"
|
2012-12-07 16:54:19 +00:00
|
|
|
execute "mkfs.ext3 $NBDPARTITION"
|
2012-12-06 15:25:13 +00:00
|
|
|
|
2012-12-07 16:54:19 +00:00
|
|
|
log_action "Mounting $NBDPARTITION to $LOOPDIR"
|
|
|
|
execute "mount $NBDPARTITION $LOOPDIR"
|
2012-12-09 09:50:28 +00:00
|
|
|
do_on_exit graceful_umount $LOOPDIR
|
2012-12-06 15:25:13 +00:00
|
|
|
|
2012-12-07 16:54:19 +00:00
|
|
|
log_action "Using $CACHEDIR as archive for apt"
|
2012-11-19 09:43:42 +00:00
|
|
|
mkdir -p $APTCACHE
|
|
|
|
execute "mount -o bind $CACHEDIR $APTCACHE"
|
2012-12-07 16:54:19 +00:00
|
|
|
do_on_exit graceful_umount $APTCACHE
|
2012-12-06 18:26:48 +00:00
|
|
|
|
2012-12-10 09:05:02 +00:00
|
|
|
log_action "Running debootstrap ($BASEIMGSUITE, $BASEIMGARCH)"
|
2013-03-22 10:33:51 +00:00
|
|
|
execute "debootstrap --arch=$BASEIMGARCH --include=$INC $BASEIMGSUITE $LOOPDIR $BASEIMGMIRROR"
|
2012-11-19 09:43:42 +00:00
|
|
|
|
2013-11-28 12:51:33 +00:00
|
|
|
execute "mount -t proc none $LOOPDIR/proc" 0
|
2013-02-14 12:32:04 +00:00
|
|
|
do_on_exit graceful_umount $LOOPDIR/proc
|
|
|
|
|
2018-10-05 15:44:55 +00:00
|
|
|
log_action "Generating locales"
|
|
|
|
cat > $LOOPDIR/etc/locale.gen << EOF
|
|
|
|
de_CH.UTF-8 UTF-8
|
|
|
|
en_US.UTF-8 UTF-8
|
|
|
|
EOF
|
|
|
|
execute_chroot "locale-gen"
|
|
|
|
|
2015-12-08 14:22:15 +00:00
|
|
|
log_action "Downloading signing key for custom apt repo"
|
|
|
|
execute_chroot "wget -q $BASEIMGEXTKEY -O /tmp/key"
|
|
|
|
log_action "Installing signing key for custom apt repo"
|
|
|
|
execute_chroot "apt-key add /tmp/key"
|
|
|
|
|
|
|
|
log_action "Enabling custom apt repo"
|
|
|
|
cat > $LOOPDIR/etc/apt/sources.list.d/strongswan.list << EOF
|
|
|
|
deb $BASEIMGEXTREPO $BASEIMGSUITE main
|
|
|
|
EOF
|
|
|
|
log_status $?
|
|
|
|
|
|
|
|
log_action "Prioritize custom apt repo"
|
|
|
|
cat > $LOOPDIR/etc/apt/preferences.d/strongswan.pref << EOF
|
|
|
|
Package: *
|
|
|
|
Pin: origin "$BASEIMGEXTREPOHOST"
|
|
|
|
Pin-Priority: 1001
|
|
|
|
EOF
|
|
|
|
log_status $?
|
|
|
|
|
|
|
|
log_action "Update package sources"
|
|
|
|
execute_chroot "apt-get update"
|
2018-10-05 16:14:31 +00:00
|
|
|
log_action "Install packages via APT"
|
|
|
|
execute_chroot "apt-get -y install $APT"
|
2015-12-08 14:22:15 +00:00
|
|
|
log_action "Install packages from custom repo"
|
|
|
|
execute_chroot "apt-get -y upgrade"
|
|
|
|
|
2012-11-19 09:43:42 +00:00
|
|
|
for service in $SERVICES
|
|
|
|
do
|
2012-12-06 15:25:13 +00:00
|
|
|
log_action "Disabling service $service"
|
2018-09-14 11:43:51 +00:00
|
|
|
execute_chroot "systemctl disable $service"
|
2012-11-19 09:43:42 +00:00
|
|
|
done
|
2012-12-07 16:54:19 +00:00
|
|
|
|
2020-08-24 14:14:07 +00:00
|
|
|
case "$BASEIMGSUITE" in
|
|
|
|
buster)
|
|
|
|
log_action "Switching from iptables-nft to iptables-legacy"
|
|
|
|
execute_chroot "update-alternatives --set iptables /usr/sbin/iptables-legacy" 0
|
|
|
|
execute_chroot "update-alternatives --set ip6tables /usr/sbin/ip6tables-legacy" 0
|
|
|
|
log_status 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2012-12-07 16:54:19 +00:00
|
|
|
log_action "Disabling root password"
|
|
|
|
execute_chroot "passwd -d root"
|