The tests can now be run as root. This is most likely required in some cases and it should not break things if they are run as root (e.g. inside a VM with no other users). NPM prevents the use of the root user (due to modules getting root access) and uses an unprivileged user to install the modules. As maxctrl has to generate the version information at install time, running `npm install` as root will fail due to missing privileges to the current working directory. To work around this, an explicit step was added. Also changed the maxadmin checks to maxctrl to remove the dependency on the socket file location being writable by non-root users (/var/run/maxscale/ might not be accessible to all users).
36 lines
839 B
Bash
Executable File
36 lines
839 B
Bash
Executable File
#!/bin/bash
|
|
|
|
#
|
|
# This script is run before each test block. It starts MaxScale and waits for it
|
|
# to become responsive.
|
|
#
|
|
|
|
maxscaledir=$MAXSCALE_DIR
|
|
|
|
test -z "$MAXSCALE_DIR" && exit 1
|
|
|
|
rm -r $maxscaledir/lib/maxscale
|
|
rm -r $maxscaledir/cache/maxscale
|
|
rm -r $maxscaledir/run/maxscale
|
|
test -f /tmp/maxadmin.sock && rm /tmp/maxadmin.sock
|
|
|
|
mkdir -m 0755 -p $maxscaledir/lib/maxscale/maxscale.cnf.d
|
|
mkdir -m 0755 -p $maxscaledir/cache/maxscale
|
|
mkdir -m 0755 -p $maxscaledir/run/maxscale
|
|
mkdir -m 0755 -p $maxscaledir/log/maxscale
|
|
|
|
if [ "`whoami`" == "root" ]
|
|
then
|
|
user_opt="-U root"
|
|
fi
|
|
|
|
# Start MaxScale
|
|
$maxscaledir/bin/maxscale $user_opt -f $maxscaledir/maxscale.cnf &>> $maxscaledir/maxscale.output
|
|
|
|
# Wait for MaxScale to start
|
|
for ((i=0;i<150;i++))
|
|
do
|
|
$maxscaledir/bin/maxctrl list servers >& /dev/null && break
|
|
sleep 0.1
|
|
done
|