diff options
author | Schanzenbach, Martin <mschanzenbach@posteo.de> | 2016-12-05 22:18:50 +0100 |
---|---|---|
committer | Schanzenbach, Martin <mschanzenbach@posteo.de> | 2016-12-05 22:18:50 +0100 |
commit | a97e16efa84b72dd51dcb181d4ebdbcc58a111f9 (patch) | |
tree | 6f034a61e50765685c715cfac86ad394530fb829 /src/credential/test_credential_verify.sh | |
parent | 01fcfd11a5e4c170e0b31c60157fb9748c0d3277 (diff) | |
download | gnunet-a97e16efa84b72dd51dcb181d4ebdbcc58a111f9.tar.gz gnunet-a97e16efa84b72dd51dcb181d4ebdbcc58a111f9.zip |
- add better test for verification
Diffstat (limited to 'src/credential/test_credential_verify.sh')
-rwxr-xr-x | src/credential/test_credential_verify.sh | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/src/credential/test_credential_verify.sh b/src/credential/test_credential_verify.sh new file mode 100755 index 000000000..6e5ba4647 --- /dev/null +++ b/src/credential/test_credential_verify.sh | |||
@@ -0,0 +1,62 @@ | |||
1 | #!/bin/bash | ||
2 | trap "gnunet-arm -e -c test_credential_lookup.conf" SIGINT | ||
3 | |||
4 | LOCATION=$(which gnunet-config) | ||
5 | if [ -z $LOCATION ] | ||
6 | then | ||
7 | LOCATION="gnunet-config" | ||
8 | fi | ||
9 | $LOCATION --version 1> /dev/null | ||
10 | if test $? != 0 | ||
11 | then | ||
12 | echo "GNUnet command line tools cannot be found, check environmental variables PATH and GNUNET_PREFIX" | ||
13 | exit 77 | ||
14 | fi | ||
15 | |||
16 | rm -rf `gnunet-config -c test_credential_lookup.conf -s PATHS -o GNUNET_HOME -f` | ||
17 | |||
18 | # (1) Authority.test -> Intermediate.org.user | ||
19 | # (2) Intermediate.org -> Issuer | ||
20 | # (3) Issuer.user -> Subject | ||
21 | |||
22 | |||
23 | which timeout &> /dev/null && DO_TIMEOUT="timeout 30" | ||
24 | gnunet-arm -s -c test_credential_lookup.conf | ||
25 | gnunet-identity -C testissuer -c test_credential_lookup.conf | ||
26 | gnunet-identity -C testsubject -c test_credential_lookup.conf | ||
27 | gnunet-identity -C testintermediate -c test_credential_lookup.conf | ||
28 | gnunet-identity -C testauthority -c test_credential_lookup.conf | ||
29 | |||
30 | TEST_ATTR="user" | ||
31 | INTERMEDIATE_KEY=$(gnunet-identity -d -c test_credential_lookup.conf | grep testintermediate | awk '{print $3}') | ||
32 | SUBJECT_KEY=$(gnunet-identity -d -c test_credential_lookup.conf | grep testsubject | awk '{print $3}') | ||
33 | ISSUER_KEY=$(gnunet-identity -d -c test_credential_lookup.conf | grep testissuer | awk '{print $3}') | ||
34 | CRED=`$DO_TIMEOUT gnunet-credential --issue --ego=testissuer --subject=$SUBJECT_KEY --attribute=$TEST_ATTR -c test_credential_lookup.conf` | ||
35 | |||
36 | TEST_CREDENTIAL="t1" | ||
37 | gnunet-namestore -p -z testsubject -a -n $TEST_CREDENTIAL -t CRED -V "$CRED" -e 5m -c test_credential_lookup.conf | ||
38 | |||
39 | INTERMEDIATE_ATTR="org" | ||
40 | gnunet-namestore -p -z testintermediate -a -n $INTERMEDIATE_ATTR -t ATTR -V "$ISSUER_KEY" -e 5m -c test_credential_lookup.conf | ||
41 | |||
42 | AUTHORITY_ATTR="test" | ||
43 | gnunet-namestore -p -z testauthority -a -n $AUTHORITY_ATTR -t ATTR -V "$INTERMEDIATE_KEY $INTERMEDIATE_ATTR.$TEST_ATTR" -e 5m -c test_credential_lookup.conf | ||
44 | |||
45 | #TODO2 Add -z swich like in gnunet-gns | ||
46 | #RES_CRED=`$DO_TIMEOUT gnunet-credential --verify --issuer=$ISSUER_KEY --attribute="$TEST_ATTR" --subject=$SUBJECT_KEY --credential=$TEST_CREDENTIAL -c test_credential_lookup.conf` | ||
47 | valgrind gnunet-credential --verify --issuer=$AUTHORITY_KEY --attribute=$AUTHORITY_ATTR --subject=$SUBJECT_KEY --credential=$TEST_CREDENTIAL -c test_credential_lookup.conf | ||
48 | |||
49 | #TODO cleanup properly | ||
50 | gnunet-namestore -z testsubject -d -n $TEST_CREDENTIAL -t CRED -e never -c test_credential_lookup.conf | ||
51 | gnunet-arm -e -c test_credential_lookup.conf | ||
52 | |||
53 | #TODO3 proper test | ||
54 | exit 0 | ||
55 | |||
56 | if [ "$RES_CRED" == "Ok!" ] | ||
57 | then | ||
58 | exit 0 | ||
59 | else | ||
60 | echo "FAIL: Failed to verify credential $RES_IP." | ||
61 | exit 1 | ||
62 | fi | ||