added testcase for negative scalarproducts
[oweals/gnunet.git] / src / scalarproduct / test_scalarproduct.sh
1 #!/bin/bash
2 # compute a simple scalar product
3 # payload for this test:
4 INPUTALICE="-k CCC -e 3,3,-1"
5 INPUTBOB="-k CCC -e 1000,100,24"
6
7 # necessary to make the testing prefix deterministic, so we can access the config files
8 PREFIX=/tmp/test-scalarproduct`date +%H%M%S`
9
10 # where can we find the peers config files?
11 CFGALICE="-c $PREFIX/0/config"
12 CFGBOB="-c $PREFIX/1/config"
13
14 # launch two peers in line topology non-interactively
15 #
16 # interactive mode would terminate the test immediately 
17 # because the rest of the script is already in stdin, 
18 # thus redirecting stdin does not suffice)
19 GNUNET_LOG='scalarproduct;;;;DEBUG' GNUNET_TESTING_PREFIX=$PREFIX ../testbed/gnunet-testbed-profiler -n -c test_scalarproduct.conf -p 2 2>service.log &
20 PID=$!
21 sleep 5
22
23 # get bob's peer ID, necessary for alice
24 PEERIDBOB=`gnunet-peerinfo -qs $CFGBOB`
25
26 GNUNET_LOG='scalarproduct;;;;DEBUG' gnunet-scalarproduct $CFGBOB $INPUTBOB 2>bob.log &
27 RESULT=`GNUNET_LOG='scalarproduct;;;;DEBUG' gnunet-scalarproduct $CFGALICE $INPUTALICE -p $PEERIDBOB 2>alice.log`
28
29 cat alice.log bob.log service.log >> test_scalarproduct.log
30 rm -f alice.log bob.log service.log
31 ISSUES=$((`grep scalarproduct test_scalarproduct.log | grep -c ERROR` + `grep scalarproduct test_scalarproduct.log | grep -c WARNING`))
32
33 # terminate the testbed
34 kill $PID 
35
36 EXPECTED="0CCC"
37 if [ "$ISSUES" -eq "0" ]
38 then
39         if [ "$RESULT" == "$EXPECTED" ]
40         then
41           echo "OK"
42           rm -f test_scalarproduct.log
43           exit 0
44         fi
45 else
46   echo "Result $RESULT NOTOK, see $PWD/test_scalarproduct.log for details"
47   exit 1
48 fi
49