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"
7 # necessary to make the testing prefix deterministic, so we can access the config files
8 PREFIX=/tmp/test-scalarproduct`date +%H%M%S`
10 # where can we find the peers config files?
11 CFGALICE="-c $PREFIX/0/config"
12 CFGBOB="-c $PREFIX/1/config"
14 # launch two peers in line topology non-interactively
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 &
23 # get bob's peer ID, necessary for alice
24 PEERIDBOB=`gnunet-peerinfo -qs $CFGBOB`
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`
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`))
33 # terminate the testbed
37 if [ "$ISSUES" -eq "0" ]
39 if [ "$RESULT" == "$EXPECTED" ]
42 rm -f test_scalarproduct.log
46 echo "Result $RESULT NOTOK, see $PWD/test_scalarproduct.log for details"