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
109 }
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
125 }
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 \
141 -CAserial ${TESTDIR}/serial
143 CLIENT_KEY="$TESTDIR/client.key"
144 CLIENT_CERT="$TESTDIR/client.cert"
145 openssl genrsa -out "$CLIENT_KEY" 2048
146 openssl req -batch -subj "/CN=$SYSDB_USER" \
147 -new -out "${CLIENT_CERT}.csr" -key "$CLIENT_KEY"
148 openssl x509 -req -in "${CLIENT_CERT}.csr" -out "$CLIENT_CERT" -days 1 \
149 -CAkey "$CA_KEY" -CA "$CA_CERT" -CAcreateserial \
150 -CAserial ${TESTDIR}/serial
151 }
153 # vim: set tw=78 sw=4 ts=4 noexpandtab :