mirror of
git://code.qt.io/qt/qt5.git
synced 2026-03-31 02:41:31 +08:00
Docker Provisioning: Install Docker-based test servers on macOS
Build and cache docker images based on the configurations in testserver. 1. Move the shared Docker files to common/shared/testserver 2. Deploy boot2docker image into VirtualBox via docker-machine commands. 3. Build and tag the docker images by the SHA-1 of server context. Change-Id: Ic5a588e5cc5e753ec4c4e2e1bc79917bbd03f95d Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
This commit is contained in:
@@ -0,0 +1,9 @@
|
||||
FROM ubuntu:16.04
|
||||
RUN apt-get update && apt-get install -y gdebi-core=0.9.5.7ubuntu1 wget avahi-daemon
|
||||
RUN wget http://ppa.launchpad.net/dajhorn/dante/ubuntu/pool/main/d/dante/dante-server_1.4.1-1_amd64.deb
|
||||
RUN gdebi -n dante-server_1.4.1-1_amd64.deb
|
||||
EXPOSE 1080-1081
|
||||
|
||||
# install configurations and test data
|
||||
COPY danted /etc/init.d/
|
||||
COPY danted-authenticating /etc/init.d/
|
||||
93
coin/provisioning/common/shared/testserver/danted/danted
Executable file
93
coin/provisioning/common/shared/testserver/danted/danted
Executable file
@@ -0,0 +1,93 @@
|
||||
#! /bin/sh
|
||||
### BEGIN INIT INFO
|
||||
# Provides: danted
|
||||
# Required-Start: $remote_fs $syslog
|
||||
# Required-Stop: $remote_fs $syslog
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 0 1 6
|
||||
# Short-Description: SOCKS (v4 and v5) proxy daemon (danted)
|
||||
### END INIT INFO
|
||||
#
|
||||
# dante SOCKS server init.d file. Based on /etc/init.d/skeleton:
|
||||
# Version: @(#)skeleton 1.8 03-Mar-1998 miquels@cistron.nl
|
||||
|
||||
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
|
||||
DAEMON=/usr/sbin/danted
|
||||
NAME=danted
|
||||
DESC="Dante SOCKS daemon"
|
||||
PIDFILE=/var/run/$NAME.pid
|
||||
CONFFILE=/etc/$NAME.conf
|
||||
|
||||
test -f $DAEMON || exit 0
|
||||
|
||||
set -e
|
||||
|
||||
# This function makes sure that the Dante server can write to the pid-file.
|
||||
touch_pidfile ()
|
||||
{
|
||||
if [ -r $CONFFILE ]; then
|
||||
uid="`sed -n -e 's/[[:space:]]//g' -e 's/#.*//' -e '/^user\.privileged/{s/[^:]*://p;q;}' \
|
||||
$CONFFILE`"
|
||||
if [ -n "$uid" ]; then
|
||||
touch $PIDFILE
|
||||
chown $uid $PIDFILE
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
. /lib/lsb/init-functions
|
||||
|
||||
case "$1" in
|
||||
start)
|
||||
if ! egrep -cve '^ *(#|$)' \
|
||||
-e '^(logoutput|user\.((not)?privileged|libwrap)):' $CONFFILE > /dev/null
|
||||
then
|
||||
echo "Not starting $DESC: not configured."
|
||||
exit 0
|
||||
fi
|
||||
echo -n "Starting $DESC: "
|
||||
touch_pidfile
|
||||
start-stop-daemon --start --quiet --oknodo --pidfile $PIDFILE --exec $DAEMON -- -D
|
||||
echo "$NAME."
|
||||
;;
|
||||
stop)
|
||||
echo -n "Stopping $DESC: "
|
||||
start-stop-daemon --stop --quiet --oknodo --pidfile $PIDFILE --exec $DAEMON
|
||||
echo "$NAME."
|
||||
;;
|
||||
reload|force-reload)
|
||||
#
|
||||
# If the daemon can reload its config files on the fly
|
||||
# for example by sending it SIGHUP, do it here.
|
||||
#
|
||||
# If the daemon responds to changes in its config file
|
||||
# directly anyway, make this a do-nothing entry.
|
||||
#
|
||||
echo "Reloading $DESC configuration files."
|
||||
start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --exec $DAEMON -- -D
|
||||
;;
|
||||
restart)
|
||||
#
|
||||
# If the "reload" option is implemented, move the "force-reload"
|
||||
# option to the "reload" entry above. If not, "force-reload" is
|
||||
# just the same as "restart".
|
||||
#
|
||||
echo -n "Restarting $DESC: "
|
||||
start-stop-daemon --stop --quiet --pidfile $PIDFILE --exec $DAEMON
|
||||
sleep 1
|
||||
touch_pidfile
|
||||
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- -D
|
||||
echo "$NAME."
|
||||
;;
|
||||
status)
|
||||
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
|
||||
;;
|
||||
*)
|
||||
N=/etc/init.d/$NAME
|
||||
# echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2
|
||||
echo "Usage: $N {start|stop|restart|force-reload}" >&2
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
|
||||
exit 0
|
||||
97
coin/provisioning/common/shared/testserver/danted/danted-authenticating
Executable file
97
coin/provisioning/common/shared/testserver/danted/danted-authenticating
Executable file
@@ -0,0 +1,97 @@
|
||||
#! /bin/sh
|
||||
### BEGIN INIT INFO
|
||||
# Provides: danted-authenticating
|
||||
# Required-Start: $remote_fs $syslog
|
||||
# Required-Stop: $remote_fs $syslog
|
||||
# Default-Start: 2 3 4 5
|
||||
# Default-Stop: 0 1 6
|
||||
# Short-Description: SOCKS (v4 and v5) proxy daemon (danted)
|
||||
### END INIT INFO
|
||||
#
|
||||
# dante SOCKS server init.d file. Based on /etc/init.d/skeleton:
|
||||
# Version: @(#)skeleton 1.8 03-Mar-1998 miquels@cistron.nl
|
||||
|
||||
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
|
||||
DAEMON=/usr/sbin/danted
|
||||
NAME=danted-authenticating
|
||||
DESC="Dante SOCKS daemon"
|
||||
PIDFILE=/var/run/$NAME.pid
|
||||
CONFFILE=/etc/$NAME.conf
|
||||
DANTED_ARGS="-D -f $CONFFILE"
|
||||
|
||||
test -f $DAEMON || exit 0
|
||||
|
||||
set -e
|
||||
|
||||
# This function makes sure that the Dante server can write to the pid-file.
|
||||
touch_pidfile ()
|
||||
{
|
||||
if [ -r $CONFFILE ]; then
|
||||
uid="`sed -n -e 's/[[:space:]]//g' -e 's/#.*//' -e '/^user\.privileged/{s/[^:]*://p;q;}' \
|
||||
$CONFFILE`"
|
||||
if [ -n "$uid" ]; then
|
||||
touch $PIDFILE
|
||||
chown $uid $PIDFILE
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
. /lib/lsb/init-functions
|
||||
|
||||
case "$1" in
|
||||
start)
|
||||
if ! egrep -cve '^ *(#|$)' \
|
||||
-e '^(logoutput|user\.((not)?privileged|libwrap)):' $CONFFILE > /dev/null
|
||||
then
|
||||
echo "Not starting $DESC: not configured."
|
||||
exit 0
|
||||
fi
|
||||
echo -n "Starting $DESC: "
|
||||
touch_pidfile
|
||||
start-stop-daemon --start --quiet --oknodo --pidfile $PIDFILE \
|
||||
--exec $DAEMON -- $DANTED_ARGS
|
||||
echo "$NAME."
|
||||
;;
|
||||
stop)
|
||||
echo -n "Stopping $DESC: "
|
||||
start-stop-daemon --stop --quiet --oknodo --pidfile $PIDFILE --exec $DAEMON
|
||||
echo "$NAME."
|
||||
;;
|
||||
reload|force-reload)
|
||||
#
|
||||
# If the daemon can reload its config files on the fly
|
||||
# for example by sending it SIGHUP, do it here.
|
||||
#
|
||||
# If the daemon responds to changes in its config file
|
||||
# directly anyway, make this a do-nothing entry.
|
||||
#
|
||||
echo "Reloading $DESC configuration files."
|
||||
start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE \
|
||||
--exec $DAEMON -- $DANTED_ARGS
|
||||
;;
|
||||
restart)
|
||||
#
|
||||
# If the "reload" option is implemented, move the "force-reload"
|
||||
# option to the "reload" entry above. If not, "force-reload" is
|
||||
# just the same as "restart".
|
||||
#
|
||||
echo -n "Restarting $DESC: "
|
||||
start-stop-daemon --stop --quiet --pidfile $PIDFILE --exec $DAEMON
|
||||
sleep 1
|
||||
touch_pidfile
|
||||
start-stop-daemon --start --quiet --pidfile $PIDFILE \
|
||||
--exec $DAEMON -- $DANTED_ARGS
|
||||
echo "$NAME."
|
||||
;;
|
||||
status)
|
||||
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
|
||||
;;
|
||||
*)
|
||||
N=/etc/init.d/$NAME
|
||||
# echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2
|
||||
echo "Usage: $N {start|stop|restart|force-reload}" >&2
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
|
||||
exit 0
|
||||
Reference in New Issue
Block a user