X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=src%2Fgns%2Ftest_gns_cname_lookup.sh;h=d97a4fe5e681650a38086dc7f13a6b8dac9a9432;hb=a12b8c2c4cbf952c8c305cde193bb25c13a0912b;hp=1b91701ccc79d88ca341b0d34b46851bd1366725;hpb=4f74276f13db3b2817df19e62ab92f5f1068295a;p=oweals%2Fgnunet.git diff --git a/src/gns/test_gns_cname_lookup.sh b/src/gns/test_gns_cname_lookup.sh index 1b91701cc..d97a4fe5e 100755 --- a/src/gns/test_gns_cname_lookup.sh +++ b/src/gns/test_gns_cname_lookup.sh @@ -1,8 +1,30 @@ -#!/bin/bash +#!/bin/sh +# This file is in the public domain. trap "gnunet-arm -e -c test_gns_lookup.conf" SIGINT -rm -rf `gnunet-config -c test_gns_lookup.conf -s PATHS -o GNUNET_HOME -f` -TEST_DOMAIN_PLUS="www.gnu" -TEST_DOMAIN_DNS="www3.gnu" + +LOCATION=$(which gnunet-config) +if [ -z $LOCATION ] +then + LOCATION="gnunet-config" +fi +$LOCATION --version 1> /dev/null +if test $? != 0 +then + echo "GNUnet command line tools cannot be found, check environmental variables PATH and GNUNET_PREFIX" + exit 77 +fi + +# permissive DNS resolver we will use for the test +DNS_RESOLVER="8.8.8.8" +if ! nslookup gnunet.org $DNS_RESOLVER > /dev/null 2>&1 +then + echo "Cannot reach DNS, skipping test" + exit 77 +fi + + +rm -rf `gnunet-config -c test_gns_lookup.conf -f -s paths -o GNUNET_TEST_HOME` + TEST_IP_PLUS="127.0.0.1" TEST_IP_DNS="131.159.74.67" TEST_RECORD_CNAME_SERVER="server" @@ -11,34 +33,51 @@ TEST_RECORD_CNAME_DNS="gnunet.org" TEST_RECORD_NAME_SERVER="server" TEST_RECORD_NAME_PLUS="www" TEST_RECORD_NAME_DNS="www3" -which timeout &> /dev/null && DO_TIMEOUT="timeout 5" +MY_EGO="myego" +TEST_DOMAIN_PLUS="www.$MY_EGO" +TEST_DOMAIN_DNS="www3.$MY_EGO" +which timeout > /dev/null 2>&1 && DO_TIMEOUT="timeout 15" gnunet-arm -s -c test_gns_lookup.conf -gnunet-identity -C testego -c test_gns_lookup.conf -gnunet-namestore -p -z testego -a -n $TEST_RECORD_NAME_DNS -t CNAME -V $TEST_RECORD_CNAME_DNS -e never -c test_gns_lookup.conf -gnunet-namestore -p -z testego -a -n $TEST_RECORD_NAME_PLUS -t CNAME -V $TEST_RECORD_CNAME_PLUS -e never -c test_gns_lookup.conf -gnunet-namestore -p -z testego -a -n $TEST_RECORD_CNAME_SERVER -t A -V $TEST_IP_PLUS -e never -c test_gns_lookup.conf -RES_CNAME=`$DO_TIMEOUT gnunet-gns --raw -z testego -u www.gnu -t A -c test_gns_lookup.conf` -RES_CNAME_DNS=`$DO_TIMEOUT gnunet-gns --raw -z testego -u www3.gnu -t A -c test_gns_lookup.conf` -gnunet-namestore -p -z testego -d -n $TEST_RECORD_NAME_DNS -t CNAME -V $TEST_RECORD_CNAME_DNS -e never -c test_gns_lookup.conf -gnunet-namestore -p -z testego -d -n $TEST_RECORD_NAME_PLUS -t CNAME -V $TEST_RECORD_CNAME_PLUS -e never -c test_gns_lookup.conf -gnunet-namestore -p -z testego -d -n $TEST_RECORD_CNAME_SERVER -t A -V $TEST_IP_PLUS -e never -c test_gns_lookup.conf -gnunet-identity -D testego -c test_gns_lookup.conf +gnunet-identity -C $MY_EGO -c test_gns_lookup.conf +gnunet-namestore -p -z $MY_EGO -a -n $TEST_RECORD_NAME_DNS -t CNAME -V $TEST_RECORD_CNAME_DNS -e never -c test_gns_lookup.conf +gnunet-namestore -p -z $MY_EGO -a -n $TEST_RECORD_NAME_PLUS -t CNAME -V $TEST_RECORD_CNAME_PLUS -e never -c test_gns_lookup.conf +gnunet-namestore -p -z $MY_EGO -a -n $TEST_RECORD_CNAME_SERVER -t A -V $TEST_IP_PLUS -e never -c test_gns_lookup.conf +RES_CNAME=`$DO_TIMEOUT gnunet-gns --raw -u $TEST_DOMAIN_PLUS -t A -c test_gns_lookup.conf` +RES_CNAME_RAW=`$DO_TIMEOUT gnunet-gns --raw -u $TEST_DOMAIN_PLUS -t CNAME -c test_gns_lookup.conf` +RES_CNAME_DNS=`$DO_TIMEOUT gnunet-gns --raw -u $TEST_DOMAIN_DNS -t A -c test_gns_lookup.conf` +TESTEGOZONE=`gnunet-identity -c test_gns_lookup.conf -d | awk '{print $3}'` +gnunet-namestore -p -z $MY_EGO -d -n $TEST_RECORD_NAME_DNS -t CNAME -V $TEST_RECORD_CNAME_DNS -e never -c test_gns_lookup.conf +gnunet-namestore -p -z $MY_EGO -d -n $TEST_RECORD_NAME_PLUS -t CNAME -V $TEST_RECORD_CNAME_PLUS -e never -c test_gns_lookup.conf +gnunet-namestore -p -z $MY_EGO -d -n $TEST_RECORD_CNAME_SERVER -t A -V $TEST_IP_PLUS -e never -c test_gns_lookup.conf +gnunet-identity -D $MY_EGO -c test_gns_lookup.conf gnunet-arm -e -c test_gns_lookup.conf +rm -rf `gnunet-config -c test_gns_lookup.conf -f -s paths -o GNUNET_TEST_HOME` + +# make cmp case-insensitive by converting to lower case first +RES_CNAME_RAW=`echo $RES_CNAME_RAW | tr [A-Z] [a-z]` +TESTEGOZONE=`echo $TESTEGOZONE | tr [A-Z] [a-z]` +if [ "$RES_CNAME_RAW" = "server.$TESTEGOZONE" ] +then + echo "PASS: CNAME resolution from GNS" +else + echo "FAIL: CNAME resolution from GNS, got $RES_CNAME_RAW, expected server.$TESTEGOZONE." + exit 1 +fi -if [ "$RES_CNAME" == "$TEST_IP_PLUS" ] +if [ "$RES_CNAME" = "$TEST_IP_PLUS" ] then - echo "PASS: IP resulution from GNS" + echo "PASS: IP resolution from GNS" else - echo "FAIL: IP resolution from GNS, got $RES_CNAME." + echo "FAIL: IP resolution from GNS, got $RES_CNAME, expected $TEST_IP_PLUS." exit 1 fi -if [ "$RES_CNAME_DNS" == "$TEST_IP_DNS" ] +if [ "$RES_CNAME_DNS" = "$TEST_IP_DNS" ] then - echo "PASS: IP resulution from DNS" + echo "PASS: IP resolution from DNS" exit 0 else - echo "FAIL: IP resulution from DNS, got $RES_IP." + echo "FAIL: IP resolution from DNS, got $RES_IP, expected $TEST_IP_DNS." exit 1 fi