/usr/share/postgresql-common/testsuite is in postgresql-common 165+deb8u3.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 | #!/bin/sh
# Run integration tests (on the installed package). This happens on unshared
# tmpfses, so does not interfere with installed clusters.
#
# (C) 2005-2012 Martin Pitt <mpitt@debian.org>
# (C) 2012-2014 Christoph Berg <myon@debian.org>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# 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.
set -e
# default config
TESTSDIR="$(dirname $0)/t"
: ${PG_UMASKS="022 077"}
help ()
{
echo "postgresql-common testsuite"
echo "Syntax: $0 [options] [test ...]"
echo " -f number run tests starting at this number"
echo " -i install packages for versions specified by -v"
echo " -s start a shell in the testbed on failure"
echo " -u 'umask ...' umasks to run testsuite with [default: 022 077]"
echo " -v 'version ...' PostgreSQL versions to test [default: client versions installed]"
exit ${1:-0}
}
# option parsing
while getopts "hf:isu:v:" opt ; do
case $opt in
f) FROM="$OPTARG" ;;
i) INSTALL=1 ;;
h) help ;;
s) RUN_SHELL=1 ;;
u) PG_UMASKS="$OPTARG" ;;
v) export PG_VERSIONS="$OPTARG" ;; # used in t/TestLib.pm
*) help 1 ;;
esac
done
if [ "$(id -u)" != 0 ]; then
echo "Error: this test suite needs to be run as root" >&2
exit 1
fi
# install packages for versions specified by -v
# needs network for apt, so run before unshare
if [ "${INSTALL:-}" ] && [ -z "${UNSHARED:-}" ]; then
for v in $PG_VERSIONS; do
apt-get install -y postgresql-contrib-$v \
postgresql-plperl-$v \
postgresql-plpython-$v \
postgresql-plpython3-$v \
postgresql-pltcl-$v \
postgresql-server-dev-$v
done
apt-get install -y libecpg-dev \
locales \
logrotate \
procps \
netcat-openbsd \
hunspell-en-us
fi
# requirements on RedHat:
# perl-Test-Simple perl-Time-HiRes
# re-exec ourselves through unshare
if [ -z "$UNSHARED" ]; then
UNSHARED=1 exec unshare -uimn -- "$0" "$@"
fi
# shift away args
shift $(($OPTIND - 1))
# use the local pgcommon.sh (either in the build tree or /usr/share/postgresql-common)
. ./pgcommon.sh
# install locales
locale_gen \
en_US.UTF-8 UTF-8 \
ru_RU ISO-8859-5 \
ru_RU.UTF-8 UTF-8
# stop currently running clusters
if [ -x "/etc/init.d/postgresql" ]; then
/etc/init.d/postgresql stop
fi
# let everything happen in overlay tmpfses to avoid interfering with already
# existing clusters; this also speeds up testing
mount --make-rprivate / 2> /dev/null || : # reset / to private mounts (systemd changes this to shared)
dirs="/etc/postgresql /etc/postgresql-common /var/lib/postgresql /var/log/postgresql /var/run/postgresql /dev/shm"
created_dirs=""
for d in $dirs; do
if ! [ -d $d ]; then
created_dirs="$created_dirs $d"
mkdir -p $d
fi
mount -n -t tmpfs -o mode=755 tmpfs $d
done
# clean up created directories after us
cleanup () {
umount $dirs
if [ "$created_dirs" ]; then
rmdir --ignore-fail-on-non-empty -p $created_dirs
fi
}
trap "cleanup" 0 HUP INT QUIT ILL ABRT PIPE TERM
chown root:postgres /var/log/postgresql
chmod 1775 /var/log/postgresql
chown postgres:postgres /var/run/postgresql
chmod 2775 /var/run/postgresql
chmod 1777 /dev/shm
# the RPM packages enable the logging_collector by default, which the testsuite
# doesn't like. We disable it unconditionally here.
echo "logging_collector = off" >> /etc/postgresql-common/createcluster.conf
# reset core limit for pg_ctl tests
ulimit -S -c 0
# start localhost interface
if [ -x /bin/ip ]; then
ip link set dev lo up || true
else
ifconfig lo up || true
fi
# set environment
unset TMPDIR
unset LC_ALL
export LANG=en_US.utf8
# set variables which cause taint check errors
export IFS=' '
export CDPATH=/usr
export ENV=/nonexisting
export BASH_ENV=/nonexisting
if [ $# -eq 0 ]; then
set -- $TESTSDIR/*.t
fi
for U in $PG_UMASKS; do
case $U in
022) TYPE="default" ;;
077) TYPE="tight" ;;
*) TYPE="custom" ;;
esac
echo "====== Running all tests with $TYPE umask $U ======="
umask $U
for T; do
TBASE=${T##*/}
[ "$FROM" ] && [ "${TBASE%%_*}" -lt "$FROM" ] && continue
echo "=== Running test $TBASE ... ==="
perl $T || {
EXIT=$?
if [ "${RUN_SHELL:-}" ]; then
echo "*** $TBASE failed with status $EXIT, dropping you into a shell in the testbed ***"
${SHELL:-/bin/sh}
fi
exit $EXIT
}
done
done
|