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 TOP_BUILDDIR="$TOP_SRCDIR"
33 if test -n "$VPATH"; then
34 # We'll have to guess.
35 if test -d ../t; then
36 TOP_BUILDDIR="$( readlink -f .. )"
37 else if test -d t; then
38 TOP_BUILDDIR="$( readlink -f . )"
39 fi; fi
40 fi
42 TESTDIR="$( mktemp -d )"
43 trap "rm -rf '$TESTDIR'; test -z \$SYSDBD_PID || kill \$SYSDBD_PID" EXIT
45 mkdir "$TESTDIR/backend"
46 cp "$TOP_BUILDDIR/t/integration/.libs/mock_timeseries.so" "$TESTDIR"
47 cp "$TOP_BUILDDIR/t/integration/.libs/mock_plugin.so" "$TESTDIR/backend"
49 mkdir "$TESTDIR/store"
50 cp "$TOP_BUILDDIR/src/plugins/store/.libs/network.so" "$TESTDIR/store"
52 cp "$TOP_BUILDDIR"/src/sysdb "$TESTDIR"
53 cp "$TOP_BUILDDIR"/src/sysdbd "$TESTDIR"
55 MEMCHECK="valgrind --quiet --tool=memcheck --error-exitcode=1"
56 MEMCHECK="$MEMCHECK --trace-children=yes"
57 MEMCHECK="$MEMCHECK --track-fds=yes"
58 MEMCHECK="$MEMCHECK --leak-check=full"
59 MEMCHECK="$MEMCHECK --suppressions=$TOP_SRCDIR/t/valgrind.suppress"
60 MEMCHECK="$MEMCHECK --gen-suppressions=all"
62 SYSDBD_CONF="$TESTDIR/sysdbd.conf"
64 SOCKET_FILE="$TESTDIR/sock"
65 PLUGIN_DIR="$TESTDIR"
67 CA_KEY=""
68 CA_CERT=""
69 SERVER_KEY=""
70 SERVER_CERT=""
71 CLIENT_KEY=""
72 CLIENT_CERT=""
74 SYSDB_USER="$( id -un )"
76 function run_sysdb() {
77 $MEMCHECK "$TESTDIR/sysdb" -U $SYSDB_USER "$@"
78 }
80 function run_sysdb_nouser() {
81 $MEMCHECK "$TESTDIR/sysdb" "$@"
82 }
84 function run_sysdbd() {
85 $MEMCHECK "$TESTDIR/sysdbd" "$@" &
86 SYSDBD_PID=$!
87 }
89 function run_sysdbd_foreground() {
90 $MEMCHECK "$TESTDIR/sysdbd" "$@"
91 }
93 function stop_sysdbd() {
94 if test -z "$SYSDBD_PID"; then
95 echo "Cannot stop sysdbd; PID unknown" >&2
96 exit 1
97 fi
98 kill $SYSDBD_PID
99 wait $SYSDBD_PID
100 SYSDBD_PID=''
101 }
103 function wait_for_sysdbd() {
104 local socket="$SOCKET_FILE"
105 if test -n "$1"; then
106 socket="$1"
107 fi
108 local i
109 for (( i=0; i<10; i++ )); do
110 if test -e "$socket"; then
111 break
112 fi
113 sleep 1
114 done
115 if test $i -eq 10; then
116 echo 'SysDBd did not start within 10 seconds' >&2
117 exit 1
118 fi
119 }
121 function wait_for_sysdbd_tcp() {
122 local host="$1"
123 local port="$2"
124 local i
125 for (( i=0; i<10; i++ )); do
126 if echo | nc "$host" "$port"; then
127 break
128 fi
129 sleep 1
130 done
131 if test $i -eq 10; then
132 echo 'SysDBd did not start within 10 seconds' >&2
133 exit 1
134 fi
135 }
137 function setup_ssl() {
138 CA_KEY="$TESTDIR/cacert.key"
139 CA_CERT="$TESTDIR/cacert.cert"
140 openssl genrsa -out "$CA_KEY" 2048
141 openssl req -batch -subj '/CN=Some CA' \
142 -x509 -new -key "$CA_KEY" -out "$CA_CERT" -days 1
144 SERVER_KEY="$TESTDIR/server.key"
145 SERVER_CERT="$TESTDIR/server.cert"
146 openssl genrsa -out "$SERVER_KEY" 2048
147 openssl req -batch -subj '/CN=localhost' \
148 -new -out "${SERVER_CERT}.csr" -key "$SERVER_KEY"
149 openssl x509 -req -in "${SERVER_CERT}.csr" -out "$SERVER_CERT" -days 1 \
150 -CAkey "$CA_KEY" -CA "$CA_CERT" -CAcreateserial \
151 -CAserial ${TESTDIR}/serial
153 CLIENT_KEY="$TESTDIR/client.key"
154 CLIENT_CERT="$TESTDIR/client.cert"
155 openssl genrsa -out "$CLIENT_KEY" 2048
156 openssl req -batch -subj "/CN=$SYSDB_USER" \
157 -new -out "${CLIENT_CERT}.csr" -key "$CLIENT_KEY"
158 openssl x509 -req -in "${CLIENT_CERT}.csr" -out "$CLIENT_CERT" -days 1 \
159 -CAkey "$CA_KEY" -CA "$CA_CERT" -CAcreateserial \
160 -CAserial ${TESTDIR}/serial
161 }
163 # vim: set tw=78 sw=4 ts=4 noexpandtab :