Code

t/integration/: Added simple SSL tests.
[sysdb.git] / t / integration / test_lib.sh
1 #
2 # SysDB -- t/integration/test_lib.sh
3 # Copyright (C) 2012 Sebastian 'tokkee' Harl <sh@tokkee.org>
4 # All rights reserved.
5 #
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions
8 # are met:
9 # 1. Redistributions of source code must retain the above copyright
10 #    notice, this list of conditions and the following disclaimer.
11 # 2. Redistributions in binary form must reproduce the above copyright
12 #    notice, this list of conditions and the following disclaimer in the
13 #    documentation and/or other materials provided with the distribution.
14 #
15 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR
19 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20 # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
22 # OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
23 # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
24 # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
25 # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 #
28 # Shell library of test helpers for integration tests.
29 #
31 TOP_SRCDIR="$( readlink -f "$( dirname "$0" )/../.." )"
32 TESTDIR="$( mktemp -d )"
33 trap "rm -rf '$TESTDIR'; test -z \$SYSDBD_PID || kill \$SYSDBD_PID" EXIT
35 mkdir "$TESTDIR/backend"
36 cp "$TOP_SRCDIR/t/integration/.libs/mock_timeseries.so" "$TESTDIR"
37 cp "$TOP_SRCDIR/t/integration/.libs/mock_plugin.so" "$TESTDIR/backend"
39 mkdir "$TESTDIR/store"
40 cp "$TOP_SRCDIR/src/plugins/store/.libs/network.so" "$TESTDIR/store"
42 cp "$TOP_SRCDIR"/src/sysdb "$TESTDIR"
43 cp "$TOP_SRCDIR"/src/sysdbd "$TESTDIR"
45 MEMCHECK="valgrind --quiet --tool=memcheck --error-exitcode=1"
46 MEMCHECK="$MEMCHECK --trace-children=yes"
47 MEMCHECK="$MEMCHECK --track-fds=yes"
48 MEMCHECK="$MEMCHECK --leak-check=full"
49 MEMCHECK="$MEMCHECK --suppressions=$TOP_SRCDIR/t/valgrind.suppress"
50 MEMCHECK="$MEMCHECK --gen-suppressions=all"
52 SYSDBD_CONF="$TESTDIR/sysdbd.conf"
54 SOCKET_FILE="$TESTDIR/sock"
55 PLUGIN_DIR="$TESTDIR"
57 CA_KEY=""
58 CA_CERT=""
59 SERVER_KEY=""
60 SERVER_CERT=""
61 CLIENT_KEY=""
62 CLIENT_CERT=""
64 SYSDB_USER="$( id -un )"
66 function run_sysdb() {
67         $MEMCHECK "$TESTDIR/sysdb" -U $SYSDB_USER "$@"
68 }
70 function run_sysdb_nouser() {
71         $MEMCHECK "$TESTDIR/sysdb" "$@"
72 }
74 function run_sysdbd() {
75         $MEMCHECK "$TESTDIR/sysdbd" "$@" &
76         SYSDBD_PID=$!
77 }
79 function run_sysdbd_foreground() {
80         $MEMCHECK "$TESTDIR/sysdbd" "$@"
81 }
83 function stop_sysdbd() {
84         if test -z "$SYSDBD_PID"; then
85                 echo "Cannot stop sysdbd; PID unknown" >&2
86                 exit 1
87         fi
88         kill $SYSDBD_PID
89         wait $SYSDBD_PID
90         SYSDBD_PID=''
91 }
93 function wait_for_sysdbd() {
94         local socket="$SOCKET_FILE"
95         if test -n "$1"; then
96                 socket="$1"
97         fi
98         local i
99         for (( i=0; i<10; i++ )); do
100                 if test -e "$socket"; then
101                         break
102                 fi
103                 sleep 1
104         done
105         if test $i -eq 10; then
106                 echo 'SysDBd did not start within 10 seconds' >&2
107                 exit 1
108         fi
111 function wait_for_sysdbd_tcp() {
112         local host="$1"
113         local port="$2"
114         local i
115         for (( i=0; i<10; i++ )); do
116                 if echo | nc "$host" "$port"; then
117                         break
118                 fi
119                 sleep 1
120         done
121         if test $i -eq 10; then
122                 echo 'SysDBd did not start within 10 seconds' >&2
123                 exit 1
124         fi
127 function setup_ssl() {
128         CA_KEY="$TESTDIR/cacert.key"
129         CA_CERT="$TESTDIR/cacert.cert"
130         openssl genrsa -out "$CA_KEY" 2048
131         openssl req -batch -subj '/CN=Some CA' \
132                 -x509 -new -key "$CA_KEY" -out "$CA_CERT" -days 1
134         SERVER_KEY="$TESTDIR/server.key"
135         SERVER_CERT="$TESTDIR/server.cert"
136         openssl genrsa -out "$SERVER_KEY" 2048
137         openssl req -batch -subj '/CN=localhost' \
138                 -new -out "${SERVER_CERT}.csr" -key "$SERVER_KEY"
139         openssl x509 -req -in "${SERVER_CERT}.csr" -out "$SERVER_CERT" -days 1 \
140                 -CAkey "$CA_KEY" -CA "$CA_CERT" -CAcreateserial -CAserial serial
142         CLIENT_KEY="$TESTDIR/client.key"
143         CLIENT_CERT="$TESTDIR/client.cert"
144         openssl genrsa -out "$CLIENT_KEY" 2048
145         openssl req -batch -subj "/CN=$SYSDB_USER" \
146                 -new -out "${CLIENT_CERT}.csr" -key "$CLIENT_KEY"
147         openssl x509 -req -in "${CLIENT_CERT}.csr" -out "$CLIENT_CERT" -days 1 \
148                 -CAkey "$CA_KEY" -CA "$CA_CERT" -CAcreateserial -CAserial serial
151 # vim: set tw=78 sw=4 ts=4 noexpandtab :